基于ES7.4.1编写,其实一开始用的最新的8.1,但是问题太多了!!!!不稳定,降到7.4
下载好的安装包上传到服务器或虚拟机,创建ES目录,命令mkdir -p /路径xxxx
data:image/s3,"s3://crabby-images/effde/effdecce1715daa3d5765588ff4d618a9c40b408" alt=""
复制安装包到指定路径并解压:
tar zxvf elasticsearch-8.1.0-linux-x86_64.tar.gz -C /usr/local/es/
data:image/s3,"s3://crabby-images/01c24/01c2491eafe83ef5672136b1ddc4e2ae4b577371" alt=""
data:image/s3,"s3://crabby-images/1cc88/1cc88793b4da40dd63034c116bc22e9dbb9fbd76" alt=""
进入bin目录安装,命令./elasticsearch即可
data:image/s3,"s3://crabby-images/60468/60468b78f2fc96e010b6360fc061de7de9197d51" alt=""
为防止出现安全隐患,不允许root用户直接操作,提示信息如下:
data:image/s3,"s3://crabby-images/28a15/28a155734228f2f97769ed9547955b2b036def98" alt=""
创建用户组,设置es操作用户:groupadd es,向ES用户组添加用户es:useradd es -g es
data:image/s3,"s3://crabby-images/f388a/f388aaa6491b9807315c421ac9ec8a459cb8d53a" alt=""
root权限变更为es权限 : chown -Rf es:es /home/local/es/
data:image/s3,"s3://crabby-images/af460/af460030f044d446be8e62688ce4194a62426f04" alt=""
切换用户为es:su es,执行启动命令:./elasticsearch
出现错误
看这个错误意思是需要连接一个叫GeoLite2-ASN.mmdb的数据库,连接超时了。因为我本地并没有这个数据库,那么什么是GeoLite2-ASN.mmdb?
GeoLite2/GeoIP全球ASN-IP离线定位库,官网地址:https://dev.maxmind.com/geoip/geolocate-an-ip?lang=en
我们现在并不需要这个库,但是elasticsearch启动却需要连接这个库,所以我们需要将这个连接的配置关闭,让启动的时候不去连接这个库。
data:image/s3,"s3://crabby-images/cb3c2/cb3c28d0f37cb6a0beeb677879e1dd90f1b38502" alt=""
修改配置文件,
java
vim config/elasticsearch.yml
添加配置
java
ingest.geoip.downloader.enabled: false
再次启动,出现下面提示为完成:
data:image/s3,"s3://crabby-images/d2c31/d2c31e7b510e19e5df55fff210a5a556f49cb7b5" alt=""
通过curl命令查看:curl http://127.0.0.1:9200
data:image/s3,"s3://crabby-images/4e029/4e02922484c90d84c564d0b59a187cb7a7629e31" alt=""
现在只能本机访问,远程访问需要调整以下内容为0.0.0.0
data:image/s3,"s3://crabby-images/17e7f/17e7f861dbc9e937ff97bfddc2a043590e57a0ad" alt=""
再次启动报错:
data:image/s3,"s3://crabby-images/58c93/58c937fb90e8a3bd195be52980b3c1e44555d606" alt=""
问题1原因是虚拟内存数不足,修改这个文件
data:image/s3,"s3://crabby-images/6c5a6/6c5a6c3e0875fa1e4029cf8022145a49cb54ee9e" alt=""
在最下面添加:
#增加es虚拟内存
vm.max_map_count = 262144
data:image/s3,"s3://crabby-images/b73bb/b73bba4fa4f8cbca8a4bb4f10cbe9ba9c4358ceb" alt=""
设置完成后刷新内存,不然不生效:sysctl -p
data:image/s3,"s3://crabby-images/d40c9/d40c9c614afd4275839d89ed7eb0ad216cd82914" alt=""
问题2,发现配置,回到config,修改elasticsearch.yml
java
discovery.seed_hosts: ["你的ip"]
cluster.initial_master_nodes: ["你的ip"]
注意:流程应该用root用户修改内容,然后chown命令重新给予es用户权限,我这里用es用户修改的配置文件,如果出现问题,直接用root用户再次赋予权限即可
返回重新启动,启动成功
data:image/s3,"s3://crabby-images/1f494/1f494af2bcbfc2c32ddd72bc3bf39de384761356" alt=""
还是再开一个窗口,有那个curl命令查看服务运行情况
data:image/s3,"s3://crabby-images/70153/7015369a7d4c2e6bd0f158c122a610f8d5aee415" alt=""
这个时候就可以浏览器其他IP访问了,地址栏输入地址+ip
data:image/s3,"s3://crabby-images/bd17f/bd17fdc571e9747681deca65d9dc723a432e3054" alt=""
注意7.4或者说大版本7有一个警告
data:image/s3,"s3://crabby-images/6119a/6119a0ac811cf37f950ebe10802b42247e142830" alt=""
默认启动内存一个G,如果配置不够,可以调整内存,调整后弊端就是启动慢一点,其他没啥影响,这个警告也可以忽略,修改方式:
关闭es,去config里面找到jvm.options,修改图中位置调整即可,我这够,就不修改了
data:image/s3,"s3://crabby-images/fa2cc/fa2cc065b8efecd142b9c0a75e871bbcf04d519e" alt=""
上一个警告,出现GC过时可以按照下图改为G1GC,也可以不改
data:image/s3,"s3://crabby-images/7960f/7960fb984883abaac4eb5975be7fbaaddd0615cf" alt=""