[role="xpack"] [testenv="platinum"] [[ml-delete-job]] = Delete {anomaly-jobs} API ++++ Delete jobs ++++ Deletes an existing {anomaly-job}. [[ml-delete-job-request]] == {api-request-title} `DELETE _ml/anomaly_detectors/` [[ml-delete-job-prereqs]] == {api-prereq-title} * If {es} {security-features} are enabled, you must have `manage_ml` or `manage` cluster privileges to use this API. See <> and {ml-docs-setup-privileges}. * Before you can delete a job, you must delete the {dfeeds} that are associated with it. See <>. * Before you can delete a job, you must close it (unless you specify the `force` parameter). See <>. [[ml-delete-job-desc]] == {api-description-title} All job configuration, model state and results are deleted. IMPORTANT: Deleting an {anomaly-job} must be done via this API only. Do not delete the job directly from the `.ml-*` indices using the {es} delete document API. When {es} {security-features} are enabled, make sure no `write` privileges are granted to anyone over the `.ml-*` indices. It is not currently possible to delete multiple jobs using wildcards or a comma separated list. [[ml-delete-job-path-parms]] == {api-path-parms-title} ``:: (Required, string) include::{es-repo-dir}/ml/ml-shared.asciidoc[tag=job-id-anomaly-detection] [[ml-delete-job-query-parms]] == {api-query-parms-title} `force`:: (Optional, boolean) Use to forcefully delete an opened job; this method is quicker than closing and deleting the job. `wait_for_completion`:: (Optional, boolean) Specifies whether the request should return immediately or wait until the job deletion completes. Defaults to `true`. [[ml-delete-job-example]] == {api-examples-title} [source,console] -------------------------------------------------- DELETE _ml/anomaly_detectors/total-requests -------------------------------------------------- // TEST[skip:setup:server_metrics_job] When the job is deleted, you receive the following results: [source,console-result] ---- { "acknowledged": true } ---- In the next example we delete the `total-requests` job asynchronously: [source,console] -------------------------------------------------- DELETE _ml/anomaly_detectors/total-requests?wait_for_completion=false -------------------------------------------------- // TEST[skip:setup:server_metrics_job] When `wait_for_completion` is set to `false`, the response contains the id of the job deletion task: [source,console-result] ---- { "task": "oTUltX4IQMOUUVeiohTt8A:39" } ---- // TESTRESPONSE[s/"task": "oTUltX4IQMOUUVeiohTt8A:39"/"task": $body.task/]