מחיקת משימה

במאמר הזה נסביר איך מוחקים משימה. ההנחה היא שהגדרתם את Fleet Engine. הגדרת Fleet Engine

עקרונות בסיסיים למחיקת משימות

המערכת עשויה להשתמש ב-Fleet Engine כדי למחוק משימה במקרים הבאים:

  • כדי לבצע פעולות ניקוי בזמן בדיקת ממשקי ה-API של Fleet Engine.
  • כדי למחוק מיידית משימה שכבר לא נדרשת.

כדי למחוק משימה, שולחים בקשה באמצעות gRPC או REST.

  • שיטת DeleteTask(): gRPC או REST
  • DeleteTaskRequest message: gRPC בלבד

משתמשים בפרטי הכניסה המתאימים לחשבון השירות של הפרויקט, כפי שמתואר במאמר Fleet Engine: תפקידים של חשבונות שירות.

דוגמה: delete task

הדוגמה הבאה מראה איך מוחקים משימה ב-Fleet Engine.

static final String PROJECT_ID = "my-delivery-co-gcp-project";
static final String TASK_ID = "task-8241890";

String taskName = "providers/" + PROJECT_ID + "/tasks/" + TASK_ID;

DeliveryServiceBlockingStub deliveryService = DeliveryServiceGrpc.newBlockingStub(channel);

// Delete task request.
DeleteTaskRequest deleteTaskRequest = DeleteTaskRequest.newBuilder()
    .setName(taskName)
    .build();

// Error handling.
try {
  deliveryService.deleteTask(deleteTaskRequest);
} catch (StatusRuntimeException e) {
  Status s = e.getStatus();
  switch (s.getCode()) {
    case NOT_FOUND:           // The task doesn't exist.
      break;
    case FAILED_PRECONDITION: // Task is active and assigned to a delivery vehicle.
      break;
    case PERMISSION_DENIED:
      break;
  }
  return;
}

טיפול בשגיאות

יכול להיות שתקבלו את השגיאה FAILED_PRECONDITION כשתמחקו משימה. במקרה כזה, המשימה פעילה וקושרת לרכב מסירה. כדי להמשיך במחיקה, סוגרים את המשימה.

המאמרים הבאים