Machine learning decider
Machine learning decider
The machine learning decider (ml
) calculates the memory required to run machine learning jobs.
The machine learning decider is enabled for policies governing ml
nodes.
For machine learning jobs to open when the cluster is not appropriately scaled, set xpack.ml.max_lazy_ml_nodes
to the largest number of possible machine learning jobs (refer to Advanced machine learning settings for more information). In Elasticsearch Service, this is automatically set.
Configuration settings
Both num_anomaly_jobs_in_queue
and num_analytics_jobs_in_queue
are designed to delay a scale-up event. If the cluster is too small, these settings indicate how many jobs of each type can be unassigned from a node. Both settings are only considered for jobs that can be opened given the current scale. If a job is too large for any node size or if a job can’t be assigned without user intervention (for example, a user calling _stop
against a real-time anomaly detection job), the numbers are ignored for that particular job.
num_anomaly_jobs_in_queue
(Optional, integer) Specifies the number of queued anomaly detection jobs to allow. Defaults to 0
.
num_analytics_jobs_in_queue
(Optional, integer) Specifies the number of queued data frame analytics jobs to allow. Defaults to 0
.
down_scale_delay
(Optional, time value) Specifies the time to delay before scaling down. Defaults to 1 hour. If a scale down is possible for the entire time window, then a scale down is requested. If the cluster requires a scale up during the window, the window is reset.
Examples
This example creates an autoscaling policy named my_autoscaling_policy
that overrides the default configuration of the machine learning decider.
PUT /_autoscaling/policy/my_autoscaling_policy
{
"roles" : [ "ml" ],
"deciders": {
"ml": {
"num_anomaly_jobs_in_queue": 5,
"num_analytics_jobs_in_queue": 3,
"down_scale_delay": "30m"
}
}
}
The API returns the following result:
{
"acknowledged": true
}