Circuit breaker errors

Circuit breaker errors

Elasticsearch uses circuit breakers to prevent nodes from running out of JVM heap memory. If Elasticsearch estimates an operation would exceed a circuit breaker, it stops the operation and returns an error.

By default, the parent circuit breaker triggers at 95% JVM memory usage. To prevent errors, we recommend taking steps to reduce memory pressure if usage consistently exceeds 85%.

See this video for a walkthrough of diagnosing circuit breaker errors.

Diagnose circuit breaker errors

Error messages

If a request triggers a circuit breaker, Elasticsearch returns an error with a 429 HTTP status code.

  1. {
  2. 'error': {
  3. 'type': 'circuit_breaking_exception',
  4. 'reason': '[parent] Data too large, data for [<http_request>] would be [123848638/118.1mb], which is larger than the limit of [123273216/117.5mb], real usage: [120182112/114.6mb], new bytes reserved: [3666526/3.4mb]',
  5. 'bytes_wanted': 123848638,
  6. 'bytes_limit': 123273216,
  7. 'durability': 'TRANSIENT'
  8. },
  9. 'status': 429
  10. }

Elasticsearch also writes circuit breaker errors to elasticsearch.log. This is helpful when automated processes, such as allocation, trigger a circuit breaker.

  1. Caused by: org.elasticsearch.common.breaker.CircuitBreakingException: [parent] Data too large, data for [<transport_request>] would be [num/numGB], which is larger than the limit of [num/numGB], usages [request=0/0b, fielddata=num/numKB, in_flight_requests=num/numGB, accounting=num/numGB]

Check JVM memory usage

If you’ve enabled Stack Monitoring, you can view JVM memory usage in Kibana. In the main menu, click Stack Monitoring. On the Stack Monitoring Overview page, click Nodes. The JVM Heap column lists the current memory usage for each node.

You can also use the cat nodes API to get the current heap.percent for each node.

  1. resp = client.cat.nodes(
  2. v=True,
  3. h="name,node*,heap*",
  4. )
  5. print(resp)
  1. response = client.cat.nodes(
  2. v: true,
  3. h: 'name,node*,heap*'
  4. )
  5. puts response
  1. const response = await client.cat.nodes({
  2. v: "true",
  3. h: "name,node*,heap*",
  4. });
  5. console.log(response);
  1. GET _cat/nodes?v=true&h=name,node*,heap*

To get the JVM memory usage for each circuit breaker, use the node stats API.

  1. resp = client.nodes.stats(
  2. metric="breaker",
  3. )
  4. print(resp)
  1. response = client.nodes.stats(
  2. metric: 'breaker'
  3. )
  4. puts response
  1. const response = await client.nodes.stats({
  2. metric: "breaker",
  3. });
  4. console.log(response);
  1. GET _nodes/stats/breaker

Prevent circuit breaker errors

Reduce JVM memory pressure

High JVM memory pressure often causes circuit breaker errors. See High JVM memory pressure.

Avoid using fielddata on text fields

For high-cardinality text fields, fielddata can use a large amount of JVM memory. To avoid this, Elasticsearch disables fielddata on text fields by default. If you’ve enabled fielddata and triggered the fielddata circuit breaker, consider disabling it and using a keyword field instead. See fielddata mapping parameter.

Clear the fielddata cache

If you’ve triggered the fielddata circuit breaker and can’t disable fielddata, use the clear cache API to clear the fielddata cache. This may disrupt any in-flight searches that use fielddata.

  1. resp = client.indices.clear_cache(
  2. fielddata=True,
  3. )
  4. print(resp)
  1. response = client.indices.clear_cache(
  2. fielddata: true
  3. )
  4. puts response
  1. const response = await client.indices.clearCache({
  2. fielddata: "true",
  3. });
  4. console.log(response);
  1. POST _cache/clear?fielddata=true