Elasticsearch部署
以下步骤均按照2.4.5版本讲解,请现从官网下载安装包
- 设置服务器Swap优化:
- 打开
/etc/sysctl.conf
文件,在文件最后添加配置vm.swappiness = 1
,并保存。 - 重启服务器
- 执行命令:
sysctl -q vm.swappiness
查看值是vm.swappiness = 1
则配置正确。
- 打开
- Elasticsearch启动需要es用户,若无es用户,新建es用户,执行命令:
adduser es
切换到es用户下执行下列操作。
单机部署
解压安装包
- 通过命令
tar –xvf elasticsearch-2.4.5.tar.gz
将安装包解压到指定目录下。
启动Elasticsearch
- 进入解压后的
elasticsearch-2.4.5/bin
目录。 - 执行命令:
./elasticsearch –d
检查Elasticsearch是否正常启动
-
进入
elasticsearch-2.4.5/logs
目录下,输入命令:tail -fn 100 elasticsearch.log
查看elasticsearch.log日志如下:
-
发现打印出如下日志代表启动成功:
-
输入:
curl http://127.0.0.1:9200
打印如下数据则确认Elasticsearch启动成功:
集群部署
集群部署,在多台服务上执行以下相同的部署步骤:
解压安装包
步骤同单机部署解压步骤
修改配置文件
- 进入解压后的elasticsearch-2.4.5/conf目录
- 使用vi命令编辑elasticsearch.yml
- 找到Cluster节点配置,更改
cluster.name
值,cluster.name
值相同的节点会形成一个集群。 - 找到Node节点配置,
设置node.name的值为:node-主机ip
,设置node.master
的值为true
(主要是为了区别不同的节点,这里采用了node+主机IP标识)。设置效果如下图:
-
找到Network节点配置,设置network.host值为该服务器的ip地址,效果如下图:
-
找到Discovery节点配置,
- 设置
discovery.zen.ping.unicast.hosts
值为:集群中各个elasticsearch服务器ip列表(含自身); - 设置
discovery.zen.minimum_master_nodes
值为: (elasticsearch节点个数/2) + 1。如:有5个服务器节点,此处应该填3;特别注意:若仅部署两个,此处值应为1。
示例配置如下图:
- 设置
启动Elasticsearch
步骤同单机部署
检查Elasticsearch集群是否正常启动
配置并启动完所有节点后,执行:curl -XGET http://ip:9200/_cluster/health?pretty
其中,ip为集群中任一节点的ip接口即可,打印数据中number of nodes
的值与部署的节点数量一致说明集群部署成功,效果如下图:
附录
设置JVM内存大小
Elasticsearch默认最大内存为1g,如果现场需要更大的内存空间可以按照下列操作步骤进行配置:
- 使用root角色,打开/etc/profile文件。
- 在文件最底部新增
ES_HEAP_SIZE
环境变量并保存,其值为要分配的内存大小(不要超过32g),附加行如下所示:
export ES_HEAP_SIZE=2g
- 切换到es用户,重启Elasticsearch。
设置es用户最大打开文件数
非root用户默认最大打开文件数为1024,如果现场需要设置该值可以按照下列操作步骤进行配置:
- 使用root角色,打开
/etc/security/limits.conf
文件。 - 在文件最底部新增行如下:
es hard nofile 65535
es soft nofile 65535
其中,es为执行Elasticsearch的用户,65535为允许打开的最大文件数(现场可以根据情况进行配置)。
- 保存,换到es用户重启Elasticsearch。
设置es用户最大进程数
如果现场需要设置es用户最大进程数,可以按照下列操作步骤进行配置:
- 使用root角色,打开/etc/security/limits.conf文件。
- 在文件最底部新增行如下:
es hard nproc 65535
es soft nproc 65535
其中,es为执行Elasticsearch的用户,65535为es使用的最大进程数 (现场可以根据情况进行配置)。
- 保存,换到es用户重启Elasticsearch。