Task queue backlog

Task queue backlog

A backlogged task queue can prevent tasks from completing and put the cluster into an unhealthy state. Resource constraints, a large number of tasks being triggered at once, and long running tasks can all contribute to a backlogged task queue.

Diagnose a task queue backlog

Check the thread pool status

A depleted thread pool can result in rejected requests.

Thread pool depletion might be restricted to a specific data tier. If hot spotting is occuring, one node might experience depletion faster than other nodes, leading to performance issues and a growing task backlog.

You can use the cat thread pool API to see the number of active threads in each thread pool and how many tasks are queued, how many have been rejected, and how many have completed.

  1. resp = client.cat.thread_pool(
  2. v=True,
  3. s="t,n",
  4. h="type,name,node_name,active,queue,rejected,completed",
  5. )
  6. print(resp)
  1. response = client.cat.thread_pool(
  2. v: true,
  3. s: 't,n',
  4. h: 'type,name,node_name,active,queue,rejected,completed'
  5. )
  6. puts response
  1. const response = await client.cat.threadPool({
  2. v: "true",
  3. s: "t,n",
  4. h: "type,name,node_name,active,queue,rejected,completed",
  5. });
  6. console.log(response);
  1. GET /_cat/thread_pool?v&s=t,n&h=type,name,node_name,active,queue,rejected,completed

The active and queue statistics are instantaneous while the rejected and completed statistics are cumulative from node startup.

Inspect the hot threads on each node

If a particular thread pool queue is backed up, you can periodically poll the Nodes hot threads API to determine if the thread has sufficient resources to progress and gauge how quickly it is progressing.

  1. resp = client.nodes.hot_threads()
  2. print(resp)
  1. response = client.nodes.hot_threads
  2. puts response
  1. const response = await client.nodes.hotThreads();
  2. console.log(response);
  1. GET /_nodes/hot_threads

Look for long running node tasks

Long-running tasks can also cause a backlog. You can use the task management API to get information about the node tasks that are running. Check the running_time_in_nanos to identify tasks that are taking an excessive amount of time to complete.

  1. resp = client.tasks.list(
  2. pretty=True,
  3. human=True,
  4. detailed=True,
  5. )
  6. print(resp)
  1. const response = await client.tasks.list({
  2. pretty: "true",
  3. human: "true",
  4. detailed: "true",
  5. });
  6. console.log(response);
  1. GET /_tasks?pretty=true&human=true&detailed=true

If a particular action is suspected, you can filter the tasks further. The most common long-running tasks are bulk index- or search-related.

  • Filter for bulk index actions:

    1. resp = client.tasks.list(
    2. human=True,
    3. detailed=True,
    4. actions="indices:data/write/bulk",
    5. )
    6. print(resp)
    1. const response = await client.tasks.list({
    2. human: "true",
    3. detailed: "true",
    4. actions: "indices:data/write/bulk",
    5. });
    6. console.log(response);
    1. GET /_tasks?human&detailed&actions=indices:data/write/bulk
  • Filter for search actions:

    1. resp = client.tasks.list(
    2. human=True,
    3. detailed=True,
    4. actions="indices:data/write/search",
    5. )
    6. print(resp)
    1. const response = await client.tasks.list({
    2. human: "true",
    3. detailed: "true",
    4. actions: "indices:data/write/search",
    5. });
    6. console.log(response);
    1. GET /_tasks?human&detailed&actions=indices:data/write/search

The API response may contain additional tasks columns, including description and header, which provides the task parameters, target, and requestor. You can use this information to perform further diagnosis.

Look for long running cluster tasks

A task backlog might also appear as a delay in synchronizing the cluster state. You can use the cluster pending tasks API to get information about the pending cluster state sync tasks that are running.

  1. resp = client.cluster.pending_tasks()
  2. print(resp)
  1. const response = await client.cluster.pendingTasks();
  2. console.log(response);
  1. GET /_cluster/pending_tasks

Check the timeInQueue to identify tasks that are taking an excessive amount of time to complete.

Resolve a task queue backlog

Increase available resources

If tasks are progressing slowly and the queue is backing up, you might need to take steps to Reduce CPU usage.

In some cases, increasing the thread pool size might help. For example, the force_merge thread pool defaults to a single thread. Increasing the size to 2 might help reduce a backlog of force merge requests.

Cancel stuck tasks

If you find the active task’s hot thread isn’t progressing and there’s a backlog, consider canceling the task.