I'm terrified of racking up big bills with AWS so I don't work a lot with it, aside from Amazon Simple Email Service (SES). For my ElasticSearch 7.14 cluster that I run alongside with Kibana, I wanted to setup Snapshot and Restore.
My understanding was that with Snapshots, you obtain a copy of your cluster data at that point and you can restore it when you would like to. I already had an AWS account setup before starting with this. For this, you needed to setup a storage repository and then configure via Kibana.
This is how I went about it.
- Create a S3 Bucket (this is the storage repository we will use with Elasticsearch)
- Create an AWS policy to allow the IAM User to access the S3 Bucket
- Create an IAM User and attach the policy we created
- Install the S3 Repository Plugin
- Register the repository with Kibana
- Setup an automatic policy with Kibana / Elasticsearch so it backs up data via cron
Create a S3 Bucket
- Open AWS Console -> S3 -> Create Bucket
- Enter a bucket name: elasticsearch-s3-bucket-snapshot , other defaults are good - make sure you select " Block all public access" and then go ahead with creating the bucket (or saving)
data:image/s3,"s3://crabby-images/52218/5221840b9cf3b32d32ad97a000e2697bab761859" alt="S3 Snapshots for Elasticsearch via Kibana"
Create an AWS policy
- Open AWS Console -> IAM -> Policies
- Click on "Create Policy"
- Switch to JSON editor and paste the following policy (that Elasticsearch recommends for S3 permissions)
{
"Statement": [
{
"Action": [
"s3:ListBucket",
"s3:GetBucketLocation",
"s3:ListBucketMultipartUploads",
"s3:ListBucketVersions"
],
"Effect": "Allow",
"Resource": [
"arn:aws:s3:::snaps.example.com"
]
},
{
"Action": [
"s3:GetObject",
"s3:PutObject",
"s3:DeleteObject",
"s3:AbortMultipartUpload",
"s3:ListMultipartUploadParts"
],
"Effect": "Allow",
"Resource": [
"arn:aws:s3:::snaps.example.com/*"
]
}
],
"Version": "2012-10-17"
}
- Click on "Next: Tags", tags can be default so click next again
- Enter a policy name elasticsearch-s3-policy-snapshot and hit " Create policy"
data:image/s3,"s3://crabby-images/c9ed5/c9ed5fcbee8f9887e002df122e215ebf7e41c237" alt="S3 Snapshots for Elasticsearch via Kibana"
Create an IAM User
- Open AWS Console -> IAM-> Access Management -> Users
- Click on "Add Users"
- Enter an user name elasticsearch-s3-user (customizable), check Programmatic access and click Next: Permissions
data:image/s3,"s3://crabby-images/b3e7d/b3e7d13140f1f089913f307fc08f1c186a4b65ac" alt="S3 Snapshots for Elasticsearch via Kibana"
- Switch to " Attach existing policies directly" , search and select " elasticsearch-s3-policy-snapshot"
- Click " Next: Tags", defaults are fine. Review the details and click Create User.
data:image/s3,"s3://crabby-images/a2587/a258715b5c0c42f25ed94f88d397461fa7f87741" alt="S3 Snapshots for Elasticsearch via Kibana"
- This will generate a "Access Key ID" and "Secret access key" - both of which we will need soon to setup repository in Kibana, so keep them handy. There's a CSV option to download.
data:image/s3,"s3://crabby-images/2e0b9/2e0b9ec78af19e0ae43993fedc40e7a3fdfb8b39" alt="S3 Snapshots for Elasticsearch via Kibana"
Install the S3 Repository Plugin
- On your machine or server, go to where the Elasticsearch bin folder is. Mine was at /usr/share/elasticsearch
- Run
sudo bin/elasticsearch-plugin install repository-s3
, answer with y or Y when asked about permissions - Restart your cluster!
- We will configure the client settins for the plugin. Using elasticsearch-keystore, set the credentials for your IAM User
bin/elasticsearch-keystore add s3.client.default.access_key
# enter your "Access Key ID", hit enter
bin/elasticsearch-keystore add s3.client.default.access_key
# enter your "Secret Access Key", hit enter
Register the repository with Kibana
- Go to your Kibana dashboard -> Management -> Stack Management -> Snapshot & Restore -> Repositories -> " Register a repository"
data:image/s3,"s3://crabby-images/6d133/6d133bad4ef4864abfb611ff56f168c29b1237b5" alt="S3 Snapshots for Elasticsearch via Kibana"
- Name it as elasticsearch-repository-snapshot , select AWS S3 as repository type, click Next. If you don't see AWS S3, make sure you restarted your cluster!
data:image/s3,"s3://crabby-images/fe437/fe437ce90ded668fd8604d406f6f8e6afed7adde" alt="S3 Snapshots for Elasticsearch via Kibana"
- Client name is default (this is part of your keystore secrets s3.client. default.access_key) and your S3 Bucket Name. Review other defaults and hit Register.
data:image/s3,"s3://crabby-images/6f086/6f08650e167d7c9142fb17e133e745a2e67a3a77" alt="S3 Snapshots for Elasticsearch via Kibana"
- Once this is done, it pops up a details screen for the repository. Click on Verify repository
data:image/s3,"s3://crabby-images/90960/90960b89f951729563d600c340ddd6ae3e76294e" alt="S3 Snapshots for Elasticsearch via Kibana"
Setup an automatic policy with Kibana
- On the same screen, switch to Policies -> Create Policy <!--kg-card-begin: markdown-->
- Enter these details
- elasticsearch-weekly-snapshot as the name
- as the snapshot name, appends the date at the end
- Select elasticsearch-repository-snapshot
- Set frequency to every week
- Click Next <!--kg-card-end: markdown-->
data:image/s3,"s3://crabby-images/72652/72652f96ad205ac58c0e52fc92e150aa60718506" alt="S3 Snapshots for Elasticsearch via Kibana"
- Click Next, and on review screen, hit Create Policy
data:image/s3,"s3://crabby-images/64580/6458021cbc6fb273dbae61fb25f3ba5d17c6ea79" alt="S3 Snapshots for Elasticsearch via Kibana"
- You can run the policy and when it's done, you will see the snapshot
data:image/s3,"s3://crabby-images/ef33f/ef33f6d0eefaeb3ab86db7bb4f62521e9c68a587" alt="S3 Snapshots for Elasticsearch via Kibana"
- You should see something like this once snapshot is complete
data:image/s3,"s3://crabby-images/f1edc/f1edcb7f933f71070d1273a0d547d9a7d2fe7299" alt="S3 Snapshots for Elasticsearch via Kibana"
Top comments (0)