2019年最新版centos7.6 elasticsearch安装坑爹教程终于在这个重庆凉爽的夏季来到,那么老夫就直奔主题了,首先需要说明的是,Linux安装JDK8(或者更高版本的)后配好环境变量,然后再安装elasticsearch搜索引擎(或者叫他全文检索框架吧),相信百度这个教程了估计JDK安装那个就不需要赘述了,还有值得提出来的就是elasticsearch5.0后的版本,6,7呀这些版本,在Linux下需要非root用户才能操作(考虑到安全性),读者需要坚持2点,1最好先通读本博客,2大部分坑都是配置的坑,毕竟java程序员不是完全的运维人员,所以坚持一定能安装好的理念,大不了就是由于这个是大数据的框架对整个系统配置要求高一点而已,不要慌张.


注意如果使用非root用户启动后,虽然访问首页有时候可以,但是实际上是报错的启动,所以需要结束进程后重新启动(总之要以非root用户启动就对了)


如果觉得下载慢,这里提供Linux版本的相关tar包百度网盘(至于怎么让百度网盘加速我就不在这里说了哈,你懂得)


elasticsearch7.2 链接: https://pan.baidu.com/s/1-sdny0JPdHIa5LmAeeREJg 提取码: 1234


kibana7.2 链接: https://pan.baidu.com/s/162yZGF-ftfs9bND81FHTMA 提取码: 1234


elasticsearch-analysis-ik-7.2.0 中文分词 https://pan.baidu.com/s/19_y1c50wII1GV9Mm9H7phw 提取码: 1234


head插件 链接: https://pan.baidu.com/s/1Q3qcAeUbf8oWE3dR4c-LQA 提取码: 1234 


elasticsearch7.2安装

步骤1:先确认JDK是安装了的(因为是java写的框架)


步骤2:新建文件夹,并上传压缩包到新建的文件夹(如我的是/opt/software/elasticsearch)


步骤3:解压


[root@192 elasticsearch]# tar -zxvf elasticsearch.tar.gz

进入bin


[root@192 JDK]# cd /opt/software/elasticsearch/elasticsearch-7.2.0/bin

运行以下启动命令(此时报错支持,elasticsearch5.0开始要求不能是root用户运行启动等命令,我是centos7.6配elasticsearch-7.2.0,一般报以下错,

centos6和elasticsearch低一点的版本会报很多错,你自己百度看着办,知道思路就行)


[root@192 bin]# ./elasticsearch

不好意思,真的报错了(比如:org.elasticsearch.bootstrap.StartupException: java.lang.RuntimeException:root)


步骤4:创建一个非root用户来解决这个问题


#创建用户组


[root@192 bin]# groupadd esgroup


#创建用户并设置密码


[root@192 bin]# useradd esuser -g esgroup -p espassword


#给esuser用户授权(对文件夹循环授权,命令不作过多阐述)不授权后面启动会报jvm.options授权异常(报错Exception in thread "main" java.nio.file.AccessDeniedException: /opt/software/elasticsearch/elasticsearch-7.2.0/config/jvm.options)


[root@192 bin]# chown -R esuser:esgroup /opt/software/elasticsearch/elasticsearch-7.2.0


#切换用户


[root@192 bin]# su esuser

[esuser@192 bin]$ 


启动es


[esuser@192 bin]$ ./elasticsearch


看到以下标识这段话启动正常了

license [44e05c9c-2cb2-4e07-9cc4-627142e154b1] mode [basic] - valid


但是我们最好(新开窗口)访问一下


[root@192 ~]# curl 127.0.0.1:9200

如图

Linux安装elasticsearch7.2和kibana7.2最新教程_linux



这样基本是就ok了,但是实际情况是要让外网(如本机的Windows能访问才行)


步骤5:


这个时候需要配置文件elasticsearch.yml发挥作用了,进入/opt/software/elasticsearch/elasticsearch-7.2.0/config,使用记事本等打开,在elasticsearch.yml中(去注释后保证代码顶格,这样才规范)


17行放开注释     cluster.name: my-application

23行放开注释     node.name: node-1

55行放开IP注释  network.host: 192.168.69.110  (不该会报错Caused by: java.net.BindException: 无法指定被请求的地址)

59行放开端口注释  http.port: 9200

72行下面添加(当然修改这行也行)   cluster.initial_master_nodes: ["node-1"]

其他暂时默认,再在对应的bin路径下执行启动


[esuser@192 bin]$ ./elasticsearch


纳尼,还在报错?(Linux环境默认分配资源不足以满足elasticsearch导致的,毕竟是大数据相关框架),比如报错如下


ERROR: [4] bootstrap checks failed

[1]: max file descriptors [4096] for elasticsearch process is too low, increase to at least [65535]

[2]: max number of threads [3795] for user [esuser] is too low, increase to at least [4096]

[3]: max virtual memory areas vm.max_map_count [65530] is too low, increase to at least [262144]

[4]: the default discovery settings are unsuitable for production use; at least one of [discovery.seed_hosts, discovery.seed_providers, cluster.initia


步骤6:(切换为root用户才可以操作这些命令)


[esuser@192 bin]$ su root

进入以下路径/etc/security找到limits.conf进行编辑,在# End of file前(注意,不要以为是注释的就无所谓),*代表用户,esuser也行


* soft nofile 65536

* hard nofile 65536

* soft nproc 4096

* hard nproc 4096

使配置生效(执行以下命令后会有4个bash: elasticsearch: 未找到命令,忽略它)


[root@192 bin]# source /etc/security/limits.conf

编辑/etc/sysctl.conf,在文本最后添加


vm.max_map_count=655360

fs.file-max=655360

使配置生效


[root@192 bin]# sysctl -p

步骤7:切换为普通账户elasticsearch


[root@192 bin]# su esuser

步骤8:最后进入bin目录再次启动./elasticsearch(不推荐这种方式,推荐下面的2条命令启动方式)


 注意:如果需要后台启动(Linux控制台看不到启动日志,但是可以在同一个窗口访问)执行命令后加 -d,如下


[esuser@192 bin]$ ./elasticsearch -d

或者在对应目录下打印日志,并且返回对应的进程号,方便你kill关闭

[esuser@localhost bin]$ nohup ./elasticserach &



 可以在Windows浏览器测试(成功看见下面的json那么恭喜你),注意如果是root用户启动失败之后,切换为esuser再启动,貌似也可以访问,但是会影响kibana的链接,这里必须先关闭刚才root启动的进程,之后再用esuser重新启动.

Linux安装elasticsearch7.2和kibana7.2最新教程_root用户_02



或者Linux(新开一个窗口测试)

Linux安装elasticsearch7.2和kibana7.2最新教程_linux_03关闭elasticsearch的话使用以下两种方式均可


暴力方式(kill的是第一排的进程号)


[esuser@192 bin]$ ps -ef|grep elasticsearch

esuser    16370  16265  0 23:47 pts/0    00:00:00 grep --color=auto elasticsearch

[esuser@192 bin]$ kill -9 16265

已杀死

日常报错请参考

​https://blog.csdn.net/qq_21387171/article/details/53577115​


下载elasticsearch中文分词zip压缩包(在官网下载配套的7.2版本),通过把解压后的所有文件放在新建的文件夹里


/opt/software/elasticsearch/elasticsearch-7.2.0/plugins/ik


如图

Linux安装elasticsearch7.2和kibana7.2最新教程_linux_04






测试中文分词(Linux里面curl模拟浏览器请求)


[root@192 ~]# curl -XGET http://192.168.69.110:9200/_analyze?pretty -H 'Content-Type:application/json' -d'              

{

  "analyzer": "ik_smart",

  "text": "长草颜团子是最可爱的表情包哈,哈哈哈!"

}'

 测试结果(报错请重启,因为安装中文分词的时候es需要重新加载一下)

Linux安装elasticsearch7.2和kibana7.2最新教程_elasticsearch_05



kibana7.2安装

上传压缩文件到一个文件夹,并切换到对应目录


[root@192 software]# cd /opt/software

解压软件(解压完后建议重命名为kibana)


[root@192 software]# tar -zxvf kibana-7.2.0.tar.gz

进入bin


[root@192 software]# cd /opt/software/kibana/bin

授权(没有授权报错Error: EACCES: permission denied, open '/opt/software/kibana/optimize/.babelcache.json')


[root@192 bin]# chown -R esuser:esgroup /opt/software/kibana

修改配置文件 /opt/software/kibana/config/kibana.yml


在第2行放开注释

第7行放开注释,并改为server.host: "0.0.0.0"

第28行(改成你的虚拟机IP)elasticsearch.hosts: ["http://192.168.69.110:9200"]

切换用户


[root@192 bin]# su esuser


启动(很慢,有点卡)./kibana9(不推荐,推荐下面的方式),最好先重启一下elastic search

推荐启动方式(这样控制台可以继续敲命令(ctr+c回到命令行模式)并且把日志文件放在bin目录了,至于目录制定可以参考Linux详细命令,这里不是重点)


[esuser@192 bin]$ nohup ./kibana &

关闭使用(注意是node)


[esuser@localhost bin]$ ps -ef | grep node


返回的进程第一行的进程号可以用于关闭,比如


[esuser@192 bin]$ kill -9 8558


此时访问http://192.168.69.110:5601/   (没有启动成功会提示Kibana server is not ready yet (服务器未启动好,yml配置错误))如图

Linux安装elasticsearch7.2和kibana7.2最新教程_elasticsearch_06



最后可视化插件安装请参考:   https://blog.csdn.net/yu_kang/article/details/85014953


解决跨域请在es的配置文件加上


http.cors.enabled: true

http.cors.allow-origin: "*"

http.cors.allow-methods: OPTIONS, HEAD, GET, POST, PUT, DELETE

http.cors.allow-headers: "X-Requested-With, Content-Type, Content-Length, X-User"

 安装完成和配置好跨域后在插件安装目录执行CMD(npm run start运行)  集群不健康就是黄色,尴尬了哈哈(注意有的比如user,test_index那个是我测试时创建的索引,下图仅供参考)

Linux安装elasticsearch7.2和kibana7.2最新教程_linux_07