The primary use case of our ElasticSearch cluster were basically to provide Operational Intelligence. We sent all of our server metrics and logs into it and it served relatively well as a tool to increase transparency on everything that was going on across all of our environments.
Here are the list of logs we sent through it:
- AWS CloudTrail
- AWS Billing
- AWS ELB access log
- IIS log
- Windows Performance Counters
- Windows Event Log
- Wowza / Shoutcast / Icecast access log (A normalised dataset between the three)
- NLog .Net Application Log
Here are some numbers around the cluster:
- 1 billion-ish records
- 600gb index in total
- ~2000 shards and ~350 indexes (we had 6 shards per index)
- 3x t2.small master nodes, 2x r3.large data nodes and 4x r3.large spot instances.
And so far, this is some of what we have "observed and learned".
- Monitor the load of instances on the cluster continuously. Initially all the servers are loaded in about the same way, but as servers come and go from auto scaling groups, the replication doesn't really balance out the shards too well. This creates "hot spots" and cause one server to be more heavily loaded than the rest.
- Not all log types have the same amount of data rate. It's best to load test and find the optimal index pattern (per week or per day) and number of shards in a "staging cluster" for the ElasticSearch every time a new log type enters the system. Sending queries to a shard too big can lock the cluster up.
- Better be safe than sorry. Err on the side of shards and index being too small than too large. Querying many shards that are allocated too small is going to make the cluster slow. Querying shards that are too big (either the index size or document count) will lock the cluster.
- Scale up before scale out. Big fewer servers work better than smaller many servers.
- Design log buffering mechanism into log delivery. Kinesis and Kafka very good candidates for real time data ingestion. When the cluster was out of control and I had to stop the log ingestion, it's very reassuring to know the logs are still shipped and held some where.
Oh, and check out the template I used to deploy ElasticSearch (and the AWS lego project too while at it):
https://github.com/SleeperSmith/Aws-Lego/blob/master/src/special-blocks/elasticsearch.template
It's not perfect, but it's a good start (imo). Pull Requests are welcome.
Also, check out Bosun from the team at StackExchange which allows you to create alerts from ElasticSearch (ABOUT TIME!):
https://bosun.org/
Thank you for posting its a nice post.
ReplyDeleteBest Web Designing Training in Bangalore
Best SAP Training in Bangalore
Thank you for posting its a nice post.
ReplyDeleteBest Oracle Training in Bangalore
thanks for sharing this blog
ReplyDeletespring mvc interview questions
machine learning online training
servlet interview questions
mytectra.in
wcf interview questions
laravel interview questions
ReplyDeleteaem interview questions salesforce interview questions
oops abab interview questions
itil interview questions informatica interview questions
extjs interview questions
sap bi interview questions
The post was good and really helpful for more stuff click on the link below.
ReplyDeleteShriram earth off mysore road
Do you understand there is a 12 word phrase you can communicate to your man... that will induce deep feelings of love and impulsive attractiveness for you deep inside his heart?
ReplyDeleteBecause hidden in these 12 words is a "secret signal" that triggers a man's impulse to love, idolize and protect you with his entire heart...
12 Words Who Fuel A Man's Desire Instinct
This impulse is so hardwired into a man's genetics that it will drive him to work better than ever before to to be the best lover he can be.
In fact, triggering this all-powerful impulse is absolutely important to having the best ever relationship with your man that the instance you send your man one of these "Secret Signals"...
...You will immediately find him open his mind and soul for you in such a way he's never experienced before and he'll distinguish you as the only woman in the universe who has ever truly tempted him.