一.使用root账号启动es后 会遇到以下问题
[
2017-
04-
04T17:
41:
28,
377][WARN ][o
.e.b.ElasticsearchUncaughtExceptionHandler] [h001] uncaught exception
in thread [main]
org.elasticsearch.bootstrap.StartupException: java
.lang.RuntimeException: can not run elasticsearch as root
at org
.elasticsearch.bootstrap.Elasticsearch.init(Elasticsearch
.java:
125) ~[elasticsearch-
5.2.0.jar:
5.2.0]
at org
.elasticsearch.bootstrap.Elasticsearch.execute(Elasticsearch
.java:
112) ~[elasticsearch-
5.2.0.jar:
5.2.0]
at org
.elasticsearch.cli.SettingCommand.execute(SettingCommand
.java:
54) ~[elasticsearch-
5.2.0.jar:
5.2.0]
at org
.elasticsearch.cli.Command.mainWithoutErrorHandling(Command
.java:
122) ~[elasticsearch-
5.2.0.jar:
5.2.0]
at org
.elasticsearch.cli.Command.main(Command
.java:
88) ~[elasticsearch-
5.2.0.jar:
5.2.0]
at org
.elasticsearch.bootstrap.Elasticsearch.main(Elasticsearch
.java:
89) ~[elasticsearch-
5.2.0.jar:
5.2.0]
at org
.elasticsearch.bootstrap.Elasticsearch.main(Elasticsearch
.java:
82) ~[elasticsearch-
5.2.0.jar:
5.2.0]
Caused by: java
.lang.RuntimeException: can not run elasticsearch as root
at org
.elasticsearch.bootstrap.Bootstrap.initializeNatives(Bootstrap
.java:
105) ~[elasticsearch-
5.2.0.jar:
5.2.0]
at org
.elasticsearch.bootstrap.Bootstrap.setup(Bootstrap
.java:
203) ~[elasticsearch-
5.2.0.jar:
5.2.0]
at org
.elasticsearch.bootstrap.Bootstrap.init(Bootstrap
.java:
333) ~[elasticsearch-
5.2.0.jar:
5.2.0]
at org
.elasticsearch.bootstrap.Elasticsearch.init(Elasticsearch
.java:
121) ~[elasticsearch-
5.2.0.jar:
5.2.0]
解决办法:因为安全问题elasticsearch 不让用root用户直接运行,所以要给所需要的用户授权。 chown-R hdfs:hdfs /usr/bigdata/elasticsearch -R为hdfs这个用户进行授权
二.使用elsearch启动ES后 又会遇到以下问题
ERROR: bootstrap checks failed
max file descriptors [
4096]
for elasticsearch
process is too low, increase
to at least [
65536]
max number of threads [
1024]
for user [hdfs] is too low, increase
to at least [
2048]
max virtual memory areas vm.max_map_count [
65530] is too low, increase
to at least [
262144]
system call filters failed
to install; check
the logs
and fix your configuration
or disable
system call filters
解决方法切换到root用户
第一个问题:
原因:无法创建本地文件问题,用户最大可创建文件数太小
[root
@h001 elasticsearch]# vim /etc/security/limits.conf
添加如下内容:
*
soft nofile
65536
* hard nofile
131072
*
soft nproc
2048
* hard nproc
4096
第二个问题:
原因:无法创建本地线程问题,用户最大可创建线程数太小
[root
@h001 elasticsearch]
修改如下内容:
* soft nproc
1024
* soft nproc
2048
第三个问题:
原因:最大虚拟内存太小
[root
@h001 elasticsearch]
添加下面配置:
vm.max_map_count=
655360
并执行命令:
sysctl -p
第四个问题:
原因:因为Centos6不支持SecComp,而ES5
.2.1默认bootstrap
.system_call_filter为true进行检测,所以导致检测失败,失败后直接导致ES不能启动
解决方法:在elasticsearch
.yml中配置bootstrap
.system_call_filter为false,注意要在Memory下面:
bootstrap.memory_lock: false
bootstrap.system_call_filter: false
最后启动ES即可 以上就是我在安装过程中,遇到的一些棘手问题,也欢迎大家把遇到的一些问题,贴到评论区,一起探讨,学习。后期,我会将集群的安装贴出来供大家学习。
转载请注明原文地址: https://ju.6miu.com/read-14951.html