Linux安装Elasticsearch7.12.0

1、检查是否安装jdk,es7内嵌了jdk,如果使用自己的jdk,至少1.8以上,并配置JAVA_HOME环境变量;

2、下载elasticsearch:

https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-7.12.0-linux-x86_64.tar.gz

3、解压到到/usr/local/目录下:

tar -zxvf elasticsearch-7.12.0-linux-x86_64.tar.gz -C /usr/local/

4、进入解压后的elasticsearch目录并创建数据存放目录:

cd /usr/local/elasticsearch-7.12.0
mkdir data

5、修改config/elasticsearch.yml:

vim config/elasticsearch.yml

取消以下注释项:

cluster.name: my-application #集群名称
node.name: node-1 #节点名称
#数据和日志的存储目录
path.data: /usr/local/elasticsearch-7.1.1/data
path.logs: /usr/local/elasticsearch-7.1.1/logs
#设置绑定的ip,设置为0.0.0.0以后就可以让任何计算机节点访问到了
network.host: 0.0.0.0
http.port: 9200 #端口
#设置在集群中的所有节点名称,这个节点名称就是之前所修改的,当然你也可以采用默认的也行,目前是单机,放入一个节点即可
cluster.initial_master_nodes: ["node-1"]

修改完毕后,:wq 保存退出vim

6、添加用户用来启动elasticsearch

adduser elasticsearch
passwd elasticsearch

不能使用root账户去启动elasticsearch,要不然会报下面的错误:

org.elasticsearch.bootstrap.StartupException: java.lang.RuntimeException: can not run elasticsearch as root
    at org.elasticsearch.bootstrap.Elasticsearch.init(Elasticsearch.java:163) ~[elasticsearch-7.12.0.jar:7.12.0]
    at org.elasticsearch.bootstrap.Elasticsearch.execute(Elasticsearch.java:150) ~[elasticsearch-7.12.0.jar:7.12.0]
    at org.elasticsearch.cli.EnvironmentAwareCommand.execute(EnvironmentAwareCommand.java:75) ~[elasticsearch-7.12.0.jar:7.12.0]
    at org.elasticsearch.cli.Command.mainWithoutErrorHandling(Command.java:116) ~[elasticsearch-cli-7.12.0.jar:7.12.0]
    at org.elasticsearch.cli.Command.main(Command.java:79) ~[elasticsearch-cli-7.12.0.jar:7.12.0]
    at org.elasticsearch.bootstrap.Elasticsearch.main(Elasticsearch.java:115) ~[elasticsearch-7.12.0.jar:7.12.0]
    at org.elasticsearch.bootstrap.Elasticsearch.main(Elasticsearch.java:81) ~[elasticsearch-7.12.0.jar:7.12.0]
Caused by: java.lang.RuntimeException: can not run elasticsearch as root
    at org.elasticsearch.bootstrap.Bootstrap.initializeNatives(Bootstrap.java:101) ~[elasticsearch-7.12.0.jar:7.12.0]
    at org.elasticsearch.bootstrap.Bootstrap.setup(Bootstrap.java:168) ~[elasticsearch-7.12.0.jar:7.12.0]
    at org.elasticsearch.bootstrap.Bootstrap.init(Bootstrap.java:397) ~[elasticsearch-7.12.0.jar:7.12.0]
    at org.elasticsearch.bootstrap.Elasticsearch.init(Elasticsearch.java:159) ~[elasticsearch-7.12.0.jar:7.12.0]

 7、给elasticsearch用户添加权限:

chown -R 用户名:用户名  文件(目录)名(root权限使用此命令)

chown -R elasticsearch:elasticsearch /usr/local/elasticsearch-7.12.0

8、启动报错

bootstrap check failure [1] of [2]: max file descriptors [4096] for elasticsearch process is too low, increase to at least [65535]
bootstrap check failure [2] of [2]: max virtual memory areas vm.max_map_count [65530] is too low, increase to at least [262144]

 原因是进程不够用了,现在可操作的文件大小只有4k 调整至64k

解决办法:

切换到root用户,修改文件

vi /etc/security/limits.conf
//在文件末尾添加下面的参数值
* soft nofile 65536
* hard nofile 131072

重新登录系统配置生效,检验方法:

ulimit -Hn
ulimit -Sn

 9、再次启动还是报错:

[1] bootstrap checks failed. You must address the points described in the following [1] lines before starting Elasticsearch.
bootstrap check failure [1] of [1]: max virtual memory areas vm.max_map_count [65530] is too low, increase to at least [262144]

 原因elasticsearch用户拥有的内存权限太小,至少需要262144

临时解决办法

sudo sysctl -w vm.max_map_count=262144

查看结果:

vm.max_map_count = 262144

 永久解决办法:编辑/etc/sysctl.conf文件,在最后添加一行

vim /etc/sysctl.conf
vm.max_map_count=262144

执行命令,使其立即生效

/sbin/sysctl -p

10、启动成功:

登录刚才新建的elasticsearch用户,并启动elasticsearch

su elasticsearch
cd /usr/local/elasticsearch-7.12.0
./bin/elasticsearch

后台启动:

./bin/elasticsearch -d

11、测试,You Know, for Search:

curl http://localhost:9200

 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值