| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104 | [[shard-allocation-awareness]]==== Shard allocation awarenessYou can use custom node attributes as _awareness attributes_ to enable {es}to take your physical hardware configuration into account when allocating shards.If {es} knows which nodes are on the same physical server, in the same rack, orin the same zone, it can distribute the primary shard and its replica shards tominimise the risk of losing all shard copies in the event of a failure.When shard allocation awareness is enabled with the`cluster.routing.allocation.awareness.attributes` setting, shards are onlyallocated to nodes that have values set for the specified awarenessattributes. If you use multiple awareness attributes, {es} considerseach attribute separately when allocating shards.The allocation awareness settings can be configured in`elasticsearch.yml` and updated dynamically with the<<cluster-update-settings,cluster-update-settings>> API.NOTE: The number of attribute values determines how many shard copies areallocated in each location. If the number of nodes in each location isunbalanced and there are a lot of replicas, replica shards might be leftunassigned.[[enabling-awareness]]===== Enabling shard allocation awarenessTo enable shard allocation awareness:. Specify the location of each node with a custom node attribute. For example,if you want Elasticsearch to distribute shards across different racks, you mightset an awareness attribute called `rack_id` in each node's `elasticsearch.yml`config file.+[source,yaml]--------------------------------------------------------node.attr.rack_id: rack_one--------------------------------------------------------+You can also set custom attributes when you start a node:+[source,sh]--------------------------------------------------------./bin/elasticsearch -Enode.attr.rack_id=rack_one--------------------------------------------------------. Tell {es} to take one or more awareness attributes into account whenallocating shards by setting`cluster.routing.allocation.awareness.attributes` in *every* master-eligiblenode's `elasticsearch.yml` config file.+--[source,yaml]--------------------------------------------------------cluster.routing.allocation.awareness.attributes: rack_id <1>--------------------------------------------------------<1> Specify multiple attributes as a comma-separated list.--+You can also use the<<cluster-update-settings,cluster-update-settings>> API to set or updatea cluster's awareness attributes.With this example configuration, if you start two nodes with`node.attr.rack_id` set to `rack_one` and create an index with 5 primaryshards and 1 replica of each primary, all primaries and replicas areallocated across the two nodes.If you add two nodes with `node.attr.rack_id` set to `rack_two`,{es} moves shards to the new nodes, ensuring (if possible)that no two copies of the same shard are in the same rack.If `rack_two` fails and takes down both its nodes, by default {es}allocates the lost shard copies to nodes in `rack_one`. To prevent multiplecopies of a particular shard from being allocated in the same location, you canenable forced awareness.[[forced-awareness]]===== Forced awarenessBy default, if one location fails, Elasticsearch assigns all of the missingreplica shards to the remaining locations. While you might have sufficientresources across all locations to host your primary and replica shards, a singlelocation might be unable to host *ALL* of the shards.To prevent a single location from being overloaded in the event of a failure,you can set `cluster.routing.allocation.awareness.force` so no replicas areallocated until nodes are available in another location.For example, if you have an awareness attribute called `zone` and configure nodesin `zone1` and `zone2`, you can use forced awareness to prevent Elasticsearchfrom allocating replicas if only one zone is available:[source,yaml]-------------------------------------------------------------------cluster.routing.allocation.awareness.attributes: zonecluster.routing.allocation.awareness.force.zone.values: zone1,zone2 <1>-------------------------------------------------------------------<1> Specify all possible values for the awareness attribute.With this example configuration, if you start two nodes with `node.attr.zone` setto `zone1` and create an index with 5 shards and 1 replica, Elasticsearch createsthe index and allocates the 5 primary shards but no replicas. Replicas areonly allocated once nodes with `node.attr.zone` set to `zone2` are available.
 |