- Lab
-
Libraries: If you want this lab, consider one of these libraries.
- Cloud

Configure Shard Allocation and Forced Awareness in Elasticsearch
With Elasticsearch, you have the potential to scale your cluster to be highly available. To ensure your data survives a full zone or rack failure, you can spread your data across multiple zones and use shard allocation awareness to ensure that all replica shards are allocated to a different zone than that of their primary shard. This allows another level of fault tolerance beyond just node failure. In this hands-on lab, you are given the opportunity to exercise the following: * Apply node attributes to each data node in a cluster. * Configure shard allocation awareness for a cluster in multiple zones. * Test shard allocation awareness behavior by stopping all nodes in a zone.

Lab Info
Table of Contents
-
Challenge
Configure nodes data-1 and data-2 to have a "zone" node attribute with a value of "1".
Using the Secure Shell (SSH), log in to the
data-1
anddata-2
nodes ascloud_user
via the public IP address.Become the
elastic
user with:sudo su - elastic
In the
/home/elastic/elasticsearch/config/elasticsearch.yml
file, change the following line:#node.attr.rack: r1
to
node.attr.zone: 1
Restart the elasticsearch node with:
pkill -F /home/elastic/elasticsearch/pid /home/elastic/elasticsearch/bin/elasticsearch -d -p pid
-
Challenge
Configure nodes data-3 and data-4 to have a "zone" node attribute with a value of "2".
Using the Secure Shell (SSH), log in to the
data-3
anddata-4
nodes ascloud_user
via the public IP address.Become the
elastic
user with:sudo su - elastic
In the
/home/elastic/elasticsearch/config/elasticsearch.yml
file, change the following line:#node.attr.rack: r1
to
node.attr.zone: 2
Restart the elasticsearch node with:
pkill -F /home/elastic/elasticsearch/pid /home/elastic/elasticsearch/bin/elasticsearch -d -p pid
-
Challenge
Enable shard allocation awareness for the cluster per instructions.
Use the Kibana console tool to execute the following:
PUT _cluster/settings { "persistent": { "cluster.routing.allocation.awareness.attributes": "zone", "cluster.routing.allocation.awareness.force.zone.values": "1,2" } }
-
Challenge
Stop Elasticsearch on nodes data-3 and data-4.
Using the Secure Shell (SSH), log in to the
data-3
anddata-4
nodes ascloud_user
via the public IP address.Become the
elastic
user with:sudo su - elastic
Stop the elasticsearch node with:
pkill -F /home/elastic/elasticsearch/pid
-
Challenge
Ensure that all primary shards are assigned and all replica shards remain unassigned.
Use the Kibana console tool to execute the following:
GET _cat/shards?v
About the author
Real skill practice before real-world application
Hands-on Labs are real environments created by industry experts to help you learn. These environments help you gain knowledge and experience, practice without compromising your system, test without risk, destroy without fear, and let you learn from your mistakes. Hands-on Labs: practice your skills before delivering in the real world.
Learn by doing
Engage hands-on with the tools and technologies you’re learning. You pick the skill, we provide the credentials and environment.
Follow your guide
All labs have detailed instructions and objectives, guiding you through the learning process and ensuring you understand every step.
Turn time into mastery
On average, you retain 75% more of your learning if you take time to practice. Hands-on labs set you up for success to make those skills stick.