1
0

allocation-explain.asciidoc 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201
  1. [[cluster-allocation-explain]]
  2. == Cluster Allocation Explain API
  3. The cluster allocation explanation API is designed to assist in answering the
  4. question "why is this shard unassigned?". To explain the allocation (on
  5. unassigned state) of a shard, issue a request like:
  6. [source,js]
  7. --------------------------------------------------
  8. $ curl -XGET 'http://localhost:9200/_cluster/allocation/explain' -d'{
  9. "index": "myindex",
  10. "shard": 0,
  11. "primary": false
  12. }'
  13. --------------------------------------------------
  14. Specify the `index` and `shard` id of the shard you would like an explanation
  15. for, as well as the `primary` flag to indicate whether to explain a primary or
  16. replica shard.
  17. The response looks like:
  18. [source,js]
  19. --------------------------------------------------
  20. {
  21. "shard" : {
  22. "index" : "myindex",
  23. "index_uuid" : "KnW0-zELRs6PK84l0r38ZA",
  24. "id" : 0,
  25. "primary" : false
  26. },
  27. "assigned" : false, <1>
  28. "shard_state_fetch_pending": false, <2>
  29. "unassigned_info" : {
  30. "reason" : "INDEX_CREATED", <3>
  31. "at" : "2016-03-22T20:04:23.620Z"
  32. },
  33. "allocation_delay_ms" : 0, <4>
  34. "remaining_delay_ms" : 0, <5>
  35. "nodes" : {
  36. "V-Spi0AyRZ6ZvKbaI3691w" : {
  37. "node_name" : "node1",
  38. "node_attributes" : { <6>
  39. "bar" : "baz"
  40. },
  41. "store" : {
  42. "shard_copy" : "NONE" <7>
  43. },
  44. "final_decision" : "NO", <8>
  45. "final_explanation" : "the shard cannot be assigned because one or more allocation decider returns a 'NO' decision",
  46. "weight" : 0.06666675, <9>
  47. "decisions" : [ { <10>
  48. "decider" : "filter",
  49. "decision" : "NO",
  50. "explanation" : "node does not match index include filters [foo:\"bar\"]"
  51. } ]
  52. },
  53. "Qc6VL8c5RWaw1qXZ0Rg57g" : {
  54. "node_name" : "node2",
  55. "node_attributes" : {
  56. "bar" : "baz",
  57. "foo" : "bar"
  58. },
  59. "store" : {
  60. "shard_copy" : "AVAILABLE"
  61. },
  62. "final_decision" : "NO",
  63. "final_explanation" : "the shard cannot be assigned because one or more allocation decider returns a 'NO' decision",
  64. "weight" : -1.3833332,
  65. "decisions" : [ {
  66. "decider" : "same_shard",
  67. "decision" : "NO",
  68. "explanation" : "the shard cannot be allocated on the same node id [Qc6VL8c5RWaw1qXZ0Rg57g] on which it already exists"
  69. } ]
  70. },
  71. "PzdyMZGXQdGhqTJHF_hGgA" : {
  72. "node_name" : "node3",
  73. "node_attributes" : { },
  74. "store" : {
  75. "shard_copy" : "NONE"
  76. },
  77. "final_decision" : "NO",
  78. "final_explanation" : "the shard cannot be assigned because one or more allocation decider returns a 'NO' decision",
  79. "weight" : 2.3166666,
  80. "decisions" : [ {
  81. "decider" : "filter",
  82. "decision" : "NO",
  83. "explanation" : "node does not match index include filters [foo:\"bar\"]"
  84. } ]
  85. }
  86. }
  87. }
  88. --------------------------------------------------
  89. <1> Whether the shard is assigned or unassigned
  90. <2> Whether information about the shard is still being fetched
  91. <3> Reason for the shard originally becoming unassigned
  92. <4> Configured delay before the shard can be allocated
  93. <5> Remaining delay before the shard can be allocated
  94. <6> User-added attributes the node has
  95. <7> The shard copy information for this node and error (if applicable)
  96. <8> Final decision and explanation of whether the shard can be allocated to this node
  97. <9> Weight for how much the allocator would like to allocate the shard to this node
  98. <10> List of node decisions factoring into final decision about the shard
  99. For a shard that is already assigned, the output looks similar to:
  100. [source,js]
  101. --------------------------------------------------
  102. {
  103. "shard" : {
  104. "index" : "only-foo",
  105. "index_uuid" : "KnW0-zELRs6PK84l0r38ZA",
  106. "id" : 0,
  107. "primary" : true
  108. },
  109. "assigned" : true,
  110. "assigned_node_id" : "Qc6VL8c5RWaw1qXZ0Rg57g", <1>
  111. "shard_state_fetch_pending": false,
  112. "allocation_delay_ms" : 0,
  113. "remaining_delay_ms" : 0,
  114. "nodes" : {
  115. "V-Spi0AyRZ6ZvKbaI3691w" : {
  116. "node_name" : "Susan Storm",
  117. "node_attributes" : {
  118. "bar" : "baz"
  119. },
  120. "store" : {
  121. "shard_copy" : "NONE"
  122. },
  123. "final_decision" : "NO",
  124. "final_explanation" : "the shard cannot be assigned because one or more allocation decider returns a 'NO' decision",
  125. "weight" : 1.4499999,
  126. "decisions" : [ {
  127. "decider" : "filter",
  128. "decision" : "NO",
  129. "explanation" : "node does not match index include filters [foo:\"bar\"]"
  130. } ]
  131. },
  132. "Qc6VL8c5RWaw1qXZ0Rg57g" : {
  133. "node_name" : "Slipstream",
  134. "node_attributes" : {
  135. "bar" : "baz",
  136. "foo" : "bar"
  137. },
  138. "store" : {
  139. "shard_copy" : "AVAILABLE"
  140. },
  141. "final_decision" : "ALREADY_ASSIGNED", <2>
  142. "final_explanation" : "the shard is already assigned to this node",
  143. "weight" : 0.0,
  144. "decisions" : [ {
  145. "decider" : "same_shard",
  146. "decision" : "NO",
  147. "explanation" : "the shard cannot be allocated on the same node id [Qc6VL8c5RWaw1qXZ0Rg57g] on which it already exists"
  148. } ]
  149. },
  150. "PzdyMZGXQdGhqTJHF_hGgA" : {
  151. "node_name" : "The Symbiote",
  152. "node_attributes" : { },
  153. "store" : {
  154. "shard_copy" : "NONE"
  155. },
  156. "final_decision" : "NO",
  157. "final_explanation" : "the shard cannot be assigned because one or more allocation decider returns a 'NO' decision",
  158. "weight" : 3.6999998,
  159. "decisions" : [ {
  160. "decider" : "filter",
  161. "decision" : "NO",
  162. "explanation" : "node does not match index include filters [foo:\"bar\"]"
  163. } ]
  164. }
  165. }
  166. }
  167. --------------------------------------------------
  168. <1> Node the shard is currently assigned to
  169. <2> The decision is "ALREADY_ASSIGNED" because the shard is currently assigned to this node
  170. You can also have Elasticsearch explain the allocation of the first unassigned
  171. shard it finds by sending an empty body, such as:
  172. [source,js]
  173. --------------------------------------------------
  174. $ curl -XGET 'http://localhost:9200/_cluster/allocation/explain'
  175. --------------------------------------------------
  176. If you would like to include all decisions that were factored into the final
  177. decision, the `include_yes_decisions` parameter will return all decisions:
  178. [source,js]
  179. --------------------------------------------------
  180. $ curl -XGET 'http://localhost:9200/_cluster/allocation/explain?include_yes_decisions=true'
  181. --------------------------------------------------
  182. Additionally, you can return information gathered by the cluster info service
  183. about disk usage and shard sizes by setting the `include_disk_info` parameter to
  184. `true`:
  185. [source,js]
  186. --------------------------------------------------
  187. $ curl -XGET 'http://localhost:9200/_cluster/allocation/explain?include_disk_info=true'
  188. --------------------------------------------------