Elasticsearch在生产环境中的优化

本文分享了Elasticsearch在生产环境中的优化实践经验,包括硬件配置、JVM设置、重要配置调整、避免SWAP使用、句柄数与MMap调整等方面,旨在提升Elasticsearch的性能和稳定性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Elasticsearch在生产环境中, 需要做一系列的优化, 以达到最佳的性能。虽然网上有些优化的建议和经验, 但却不一定有效,下面就结合官网上的介绍和网上的一些指导加上自己在使用过程中的实际处理, 给出更加有说服力的一些意见和建议。

官网的关于生产环境的部署的建议,https://www.elastic.co/guide/en/elasticsearch/guide/current/deploy.html

1. 硬件:https://www.elastic.co/guide/en/elasticsearch/guide/current/hardware.html

内存:设置ES_HEAP_SIZE 为机器内存的1/2, 但不要超过32G.

CPU:官网的意见是, 2~8核足够了, 从我的经验看, 一般是要超过2核的。我的机器用的是32核, top看的话, 也就用了2核多。当然核数多点也无妨的。

磁盘:首选是SSD + RAID0

网络:1 GbE, 10 GbE, 最好不要跨机房,容易造成网络延迟。

2. JVM:https://www.elastic.co/guide/en/elasticsearch/guide/current/_java_virtual_machine.html

除了ES_HEAP_SIZE, 不要擅自改变JVM 的参数, 只要使用ES本身的设置就好了。

3. 重要的配置:https://www.elastic.co/guide/en/elasticsearch/guide/current/important-configuration-changes.html

 ES通常是不需要调优处理的, 如果遇到性能问题, 最好的方法是安排更好的数据布局和增加节点数目。

1)discovery.zen.minimum_master_nodes:(number of master-eligible nodes / 2) + 1

防止一个集群里, 出现多个master,造成数据混乱。

discovery.zen.minimum_master_nodes的数量应该是有资格成为master的node数量的1/2 + 1.

而且随着集群node数量的变化(主要是master-eligible node数量的变化), 需要动态的修改这个参数。可以使用如下的API动态修改。

PUT /_cluster/settings
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值