Allocate

Allocate

Phases allowed: warm, cold.

Updates the index settings to change which nodes are allowed to host the index shards and change the number of replicas.

The allocate action is not allowed in the hot phase. The initial allocation for the index must be done manually or via index templates.

You can configure this action to modify both the allocation rules and number of replicas, only the allocation rules, or only the number of replicas. For more information about how Elasticsearch uses replicas for scaling, see Get ready for production. See Index-level shard allocation filtering for more information about controlling where Elasticsearch allocates shards of a particular index.

Options

You must specify the number of replicas or at least one include, exclude, or require option. An empty allocate action is invalid.

For more information about using custom attributes for shard allocation, see Index-level shard allocation filtering.

number_of_replicas

(Optional, integer) Number of replicas to assign to the index.

total_shards_per_node

(Optional, integer) The maximum number of shards for the index on a single Elasticsearch node. A value of -1 is interpreted as unlimited. See total shards.

include

(Optional, object) Assigns an index to nodes that have at least one of the specified custom attributes.

exclude

(Optional, object) Assigns an index to nodes that have none of the specified custom attributes.

require

(Optional, object) Assigns an index to nodes that have all of the specified custom attributes.

Example

The allocate action in the following policy changes the index’s number of replicas to 2. No more than 200 shards for the index will be placed on any single node. Otherwise the index allocation rules are not changed.

  1. resp = client.ilm.put_lifecycle(
  2. name="my_policy",
  3. policy={
  4. "phases": {
  5. "warm": {
  6. "actions": {
  7. "allocate": {
  8. "number_of_replicas": 2,
  9. "total_shards_per_node": 200
  10. }
  11. }
  12. }
  13. }
  14. },
  15. )
  16. print(resp)
  1. response = client.ilm.put_lifecycle(
  2. policy: 'my_policy',
  3. body: {
  4. policy: {
  5. phases: {
  6. warm: {
  7. actions: {
  8. allocate: {
  9. number_of_replicas: 2,
  10. total_shards_per_node: 200
  11. }
  12. }
  13. }
  14. }
  15. }
  16. }
  17. )
  18. puts response
  1. const response = await client.ilm.putLifecycle({
  2. name: "my_policy",
  3. policy: {
  4. phases: {
  5. warm: {
  6. actions: {
  7. allocate: {
  8. number_of_replicas: 2,
  9. total_shards_per_node: 200,
  10. },
  11. },
  12. },
  13. },
  14. },
  15. });
  16. console.log(response);
  1. PUT _ilm/policy/my_policy
  2. {
  3. "policy": {
  4. "phases": {
  5. "warm": {
  6. "actions": {
  7. "allocate" : {
  8. "number_of_replicas" : 2,
  9. "total_shards_per_node" : 200
  10. }
  11. }
  12. }
  13. }
  14. }
  15. }

Assign index to nodes using a custom attribute

The allocate action in the following policy assigns the index to nodes that have a box_type of hot or warm.

To designate a node’s box_type, you set a custom attribute in the node configuration. For example, set node.attr.box_type: hot in elasticsearch.yml. For more information, see Enabling index-level shard allocation filtering.

  1. resp = client.ilm.put_lifecycle(
  2. name="my_policy",
  3. policy={
  4. "phases": {
  5. "warm": {
  6. "actions": {
  7. "allocate": {
  8. "include": {
  9. "box_type": "hot,warm"
  10. }
  11. }
  12. }
  13. }
  14. }
  15. },
  16. )
  17. print(resp)
  1. response = client.ilm.put_lifecycle(
  2. policy: 'my_policy',
  3. body: {
  4. policy: {
  5. phases: {
  6. warm: {
  7. actions: {
  8. allocate: {
  9. include: {
  10. box_type: 'hot,warm'
  11. }
  12. }
  13. }
  14. }
  15. }
  16. }
  17. }
  18. )
  19. puts response
  1. const response = await client.ilm.putLifecycle({
  2. name: "my_policy",
  3. policy: {
  4. phases: {
  5. warm: {
  6. actions: {
  7. allocate: {
  8. include: {
  9. box_type: "hot,warm",
  10. },
  11. },
  12. },
  13. },
  14. },
  15. },
  16. });
  17. console.log(response);
  1. PUT _ilm/policy/my_policy
  2. {
  3. "policy": {
  4. "phases": {
  5. "warm": {
  6. "actions": {
  7. "allocate" : {
  8. "include" : {
  9. "box_type": "hot,warm"
  10. }
  11. }
  12. }
  13. }
  14. }
  15. }
  16. }

Assign index to nodes based on multiple attributes

The allocate action can also assign indices to nodes based on multiple node attributes. The following action assigns indices based on the box_type and storage node attributes.

  1. resp = client.ilm.put_lifecycle(
  2. name="my_policy",
  3. policy={
  4. "phases": {
  5. "cold": {
  6. "actions": {
  7. "allocate": {
  8. "require": {
  9. "box_type": "cold",
  10. "storage": "high"
  11. }
  12. }
  13. }
  14. }
  15. }
  16. },
  17. )
  18. print(resp)
  1. response = client.ilm.put_lifecycle(
  2. policy: 'my_policy',
  3. body: {
  4. policy: {
  5. phases: {
  6. cold: {
  7. actions: {
  8. allocate: {
  9. require: {
  10. box_type: 'cold',
  11. storage: 'high'
  12. }
  13. }
  14. }
  15. }
  16. }
  17. }
  18. }
  19. )
  20. puts response
  1. const response = await client.ilm.putLifecycle({
  2. name: "my_policy",
  3. policy: {
  4. phases: {
  5. cold: {
  6. actions: {
  7. allocate: {
  8. require: {
  9. box_type: "cold",
  10. storage: "high",
  11. },
  12. },
  13. },
  14. },
  15. },
  16. },
  17. });
  18. console.log(response);
  1. PUT _ilm/policy/my_policy
  2. {
  3. "policy": {
  4. "phases": {
  5. "cold": {
  6. "actions": {
  7. "allocate" : {
  8. "require" : {
  9. "box_type": "cold",
  10. "storage": "high"
  11. }
  12. }
  13. }
  14. }
  15. }
  16. }
  17. }

Assign index to a specific node and update replica settings

The allocate action in the following policy updates the index to have one replica per shard and be allocated to nodes that have a box_type of cold.

To designate a node’s box_type, you set a custom attribute in the node configuration. For example, set node.attr.box_type: cold in elasticsearch.yml. For more information, see Enabling index-level shard allocation filtering.

  1. resp = client.ilm.put_lifecycle(
  2. name="my_policy",
  3. policy={
  4. "phases": {
  5. "warm": {
  6. "actions": {
  7. "allocate": {
  8. "number_of_replicas": 1,
  9. "require": {
  10. "box_type": "cold"
  11. }
  12. }
  13. }
  14. }
  15. }
  16. },
  17. )
  18. print(resp)
  1. response = client.ilm.put_lifecycle(
  2. policy: 'my_policy',
  3. body: {
  4. policy: {
  5. phases: {
  6. warm: {
  7. actions: {
  8. allocate: {
  9. number_of_replicas: 1,
  10. require: {
  11. box_type: 'cold'
  12. }
  13. }
  14. }
  15. }
  16. }
  17. }
  18. }
  19. )
  20. puts response
  1. const response = await client.ilm.putLifecycle({
  2. name: "my_policy",
  3. policy: {
  4. phases: {
  5. warm: {
  6. actions: {
  7. allocate: {
  8. number_of_replicas: 1,
  9. require: {
  10. box_type: "cold",
  11. },
  12. },
  13. },
  14. },
  15. },
  16. },
  17. });
  18. console.log(response);
  1. PUT _ilm/policy/my_policy
  2. {
  3. "policy": {
  4. "phases": {
  5. "warm": {
  6. "actions": {
  7. "allocate" : {
  8. "number_of_replicas": 1,
  9. "require" : {
  10. "box_type": "cold"
  11. }
  12. }
  13. }
  14. }
  15. }
  16. }
  17. }