【转】Linux 安装 Elasticsearch5.6.x 详细步骤以及问题解决方案

转载出处:https://www.cnblogs.com/lizichao1991/p/7809156.html

第一步:环境

linux 系统 Java 1.8.0_151 elasticsearch-5.6.3

第二步:下载

2.1 JDK的下载可以去官网上直接下载,再次声明一下不要下载最新版本 JAVA 9 版本本人在次已经踩过坑了

2.2 ES 去官网直接下载,本人使用的是 5.6.3 版本;因为版本的不同安装head插件的时候安装步骤不同;好像是从5.0 以后的版本安装head 插件的步骤就不一样了;下面会详细介绍。

第三步:安装

3.1 安装JDK环境

请查看我另外一篇博客https://blog.csdn.net/hundan_520520/article/details/81116149

3.2 安装ES

3.2.1 下载ES安装包elasticsearch-5.6.3.zip 在usr 目录下创建了es文件夹,将安装包上传到里面,解压 unzip elasticsearch-5.6.3.zip cd 进入 elasticsearch-5.6.3 文件里面

3.2.2 创建ES用户和组(创建elsearch用户组及elsearch用户),因为使用root用户执行ES程序,将会出现错误;所以这里需要创建单独的用户去执行ES 文件;命令如下:

命令一:groupadd elsearch
命令二:useradd elsearch -g elsearch
命令三:chown -R elsearch:elsearch elasticsearch-5.6.3  该命令是更改该文件夹下所属的用户组的权限

3.2.3 修改ES配置文件,使用cd命令进入到config 文件下,执行 vi elasticsearch.yml 命令,如图所示,本人没有配置集群,只是简单的配置了一下;详细说明可以参考官网(最简单的,保持原来的,放开network.host选项的注释,修改为自己的ip地址,不然只能在本地访问)

这里写图片描述

3.2.4 执行ES文件,进入到bin 目录下执行 ./elasticsearch 命令就可以了,执行 ./elasticesrarch -d 是后台运行如果没有什么问题话,就可以安全生成了;然后执行curl ‘http://自己配置的IP地址:9200/’ 命令,就出现下面的结果

这里写图片描述

第四步:问题

1.[1]: max file descriptors [4096] for elasticsearch process is too low, 
increase to at least [65536]意思是说你的进程不够用了

解决方案:切到root 用户:进入到security目录下的limits.conf;执行命令 vim /etc/security/limits.conf 在文件的末尾添加下面的参数值:

* soft nofile 65536
* hard nofile 131072
* soft nproc 2048
* hard nproc 4096

前面的*符号必须带上,然后重新启动就可以了。执行完成后可以使用命令 ulimit -n 查看进程数

2.[2]: max virtual memory areas vm.max_map_count [65530] is too low, 
increase to at least [262144]  需要修改系统变量的最大值了

解决方案:切换到root用户修改配置/etc/sysctl.conf 增加配置值:

vm.max_map_count=655360

执行命令 sysctl -p 这样就可以了,然后重新启动ES服务 就可以了

第五步:安装head 插件

5.1 下载head安装包,下载地址:https://github.com/mobz/elasticsearch-head/archive/master.zip 这是接从git 上下载下来 ,然后上传到虚拟机上的;由于head 插件不能放在elasticsearch-5.6.3 文件夹里,head 插件需要单独放,单独去执行;所以在elasticsearch-5.6.3 同级目录下解压了 head 插件;解压出来的文件名字,如图

这里写图片描述

5.2 执行head 插件,需要node.js 的支持,所以,下面先安装一node.js

执行命令一:curl -sL https://rpm.nodesource.com/setup_8.x | bash -
命令二:yum install -y nodejs

这里写图片描述

OK,执行完成后,可以使用命令 node -v 验证是否安装成功,同时npm 也安装成功了;执行命令 npm -v 也是可以验证的。

这里写图片描述

5.3 安装grunt ,由于head 插件的执行文件是有grunt 命令来执行的,所以这个命令必须安装

命令一:npm install grunt --save-dev
命令二:npm install 

5.3.1 修改配置文件,cd 进入elasticsearch-head-master 文件夹下,执行命令vim Gruntfile.js文件:增加hostname属性,设置为*;如图:

这里写图片描述

5.3.2 最后一个命令: grunt server (或 npm run start) 执行完成后就OK了

5.3.3 涉及到的问题,在网页上无法正常访问;查看防火墙是否关闭

最后执行的结果是这样的,我没有配置集群: 注意下面使用的端口号,不在是9200 了 而是head 插件中的 9100 了

这里写图片描述

看到上面的出现的健康值了吗,说明的连接还是有问题的,解决方案是修改 cd 命令进入到elasticsearch-5.6.3 /config 文件中 vi elasticsearch.yml

文件下添加:

http.cors.enabled: true
http.cors.allow-origin: "*"

这里写图片描述

然后重新执行ES ./elasticsearch 成功起来就可以了,执行结果就是这样的
这里写图片描述

猜你喜欢

转载自blog.csdn.net/hundan_520520/article/details/81666150
今日推荐