安装elasticsearch踩过的坑,教训写在这里,一起共同努力,希望大家先通读一下再按着步骤操作,看过就知道哪些坑可以掠过

本文主要是介绍安装elasticsearch踩过的坑,教训写在这里,一起共同努力,希望大家先通读一下再按着步骤操作,看过就知道哪些坑可以掠过,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

安装elasticsearch踩过的坑,教训写在这里,一起共同努力,希望大家先通读一下再按着步骤操作,看过就知道哪些坑可以掠过

配置外网访问出现启动不了的问题:

Java HotSpot(TM) 64-Bit Server VM warning: Option UseConcMarkSweepGC was deprecated in version 9.0 and will likely be removed in a future release.

[2019-09-06T09:27:10,924][WARN ][o.e.b.ElasticsearchUncaughtExceptionHandler] [hadoop111] 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:163) ~[elasticsearch-7.3.1.jar:7.3.1]

        at org.elasticsearch.bootstrap.Elasticsearch.execute(Elasticsearch.java:150) ~[elasticsearch-7.3.1.jar:7.3.1]

        at org.elasticsearch.cli.EnvironmentAwareCommand.execute(EnvironmentAwareCommand.java:86) ~[elasticsearch-7.3.1.jar:7.3.1]

        at org.elasticsearch.cli.Command.mainWithoutErrorHandling(Command.java:124) ~[elasticsearch-cli-7.3.1.jar:7.3.1]

        at org.elasticsearch.cli.Command.main(Command.java:90) ~[elasticsearch-cli-7.3.1.jar:7.3.1]

        at org.elasticsearch.bootstrap.Elasticsearch.main(Elasticsearch.java:115) ~[elasticsearch-7.3.1.jar:7.3.1]

        at org.elasticsearch.bootstrap.Elasticsearch.main(Elasticsearch.java:92) ~[elasticsearch-7.3.1.jar:7.3.1]

Caused by: java.lang.RuntimeException: can not run elasticsearch as root

        at org.elasticsearch.bootstrap.Bootstrap.initializeNatives(Bootstrap.java:105) ~[elasticsearch-7.3.1.jar:7.3.1]

        at org.elasticsearch.bootstrap.Bootstrap.setup(Bootstrap.java:172) ~[elasticsearch-7.3.1.jar:7.3.1]

        at org.elasticsearch.bootstrap.Bootstrap.init(Bootstrap.java:349) ~[elasticsearch-7.3.1.jar:7.3.1]

        at org.elasticsearch.bootstrap.Elasticsearch.init(Elasticsearch.java:159) ~[elasticsearch-7.3.1.jar:7.3.1]

这个说是elasticsearch不能用root用户启动

说以需要创建一个其他用户

adduser   test

passwd    test

输入明码

重新输入密码

这样就创建好其他用户了,但是如果你用其他的ssh软件去登录服务器可能会报如下错误

The server has disconnected with an error. Server message reads:

A protocol error occurred. Change of username or service not allowed: (root,ssh-connection) -> (user,ssh-connection) 

这个是因为你用了一个已经创建好的链接,这个链接写的用户是其他用户,我开始用的是root用户,而且只接受一次验证,所以

再次链接的时候可以重新的输入用户名和密码,所以就报出了这样错误,所以你需要重新创建一个链接,不需要把以前的链接删除掉

现在我就可以使用其他用户登录了

在这个之前我们在elasticsearch-evn中也配置了jdk的路径,因为我是最新下载的elasticsearch,所以需要jdk11的支持,而我的

Linux中是jdk1.8的所以不支持,怎么在elasticsearch-evn中配置jdk11自行百度一下

然后需要配置一个elasticsearch的环境变量,我们配置在用户的环境变量中,使用~/.bash_profile文件进行配置

配置好后我们再次启动发现还是不行,报错误

Exception in thread "main" java.nio.file.AccessDeniedException: /usr/developing/elasticsearch/elasticsearch-7.3.1/config/jvm.options

        at java.base/sun.nio.fs.UnixException.translateToIOException(UnixException.java:90)

        at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:111)

        at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:116)

        at java.base/sun.nio.fs.UnixFileSystemProvider.newByteChannel(UnixFileSystemProvider.java:219)

        at java.base/java.nio.file.Files.newByteChannel(Files.java:373)

        at java.base/java.nio.file.Files.newByteChannel(Files.java:424)

        at java.base/java.nio.file.spi.FileSystemProvider.newInputStream(FileSystemProvider.java:420)

        at java.base/java.nio.file.Files.newInputStream(Files.java:158)

        at org.elasticsearch.tools.launchers.JvmOptionsParser.main(JvmOptionsParser.java:61)

经网上查询说我没对这个文件没有操作权限,所以报了一个访问拒绝的异常,然后我用我的test用户

去修改它的权限发现我的test用户没有修改这个文件的权限

那没办法,只好使用我的root用户修改权限了,修改权限后继续启动,还是有部分文件权限不足,

那没办法继续改

还是同样的道理,那么这次我们直接config文件的权限都改了

但是还是一顿的报错,真实无语,最后查找网上相关教程,只要使用root用户把elasticsearch文件权限赋给test用户就可以了,本身是一小步

操作,整了这么多没有的权限修改,实际只需要执行下面的就可以了

在启动完成之后会在cd elasticsearch-7.3.1/文件夹下自动的生成一个data目录,

然后在Linux中使用curl访问一下这样就正常了,但是在浏览器中不能访问,看到需要配置一个

启动后,如果只有本地可以访问,尝试修改配置文件 elasticsearch.yml

中network.host(注意配置文件格式不是以#开头的要空一格, 后要空一格) 为network.host: 0.0.0.0

如果想在后台以守护进程模式运行,添加-d参数。

注意的是要开头空一格 :后要空一格

但是即使注意了这些,启动后怎么也启动不了报错

[2019-09-06T10:58:35,577][INFO ][o.e.p.PluginsService ] [hadoop111] no plugins loaded

[2019-09-06T10:58:49,613][INFO ][o.e.x.s.a.s.FileRolesStore] [hadoop111] parsed [0] roles from file [/usr/developing/elasticsearch/elasticsearch-7.3.1/config/roles.yml]

[2019-09-06T10:58:51,850][INFO ][o.e.x.m.p.l.CppLogMessageHandler] [hadoop111] [controller/108780] [Main.cc@110] controller (64 bit): Version 7.3.1 (Build 1d93901e09ef43) Copyright (c) 2019 Elasticsearch BV

[2019-09-06T10:58:52,921][DEBUG][o.e.a.ActionModule ] [hadoop111] Using REST wrapper from plugin org.elasticsearch.xpack.security.Security

[2019-09-06T10:58:53,650][INFO ][o.e.d.DiscoveryModule ] [hadoop111] using discovery type [zen] and seed hosts providers [settings]

[2019-09-06T10:58:56,251][INFO ][o.e.n.Node ] [hadoop111] initialized

[2019-09-06T10:58:56,251][INFO ][o.e.n.Node ] [hadoop111] starting ...

[2019-09-06T10:58:56,561][INFO ][o.e.t.TransportService ] [hadoop111] publish_address {192.168.1.129:9300}, bound_addresses {[::]:9300}

[2019-09-06T10:58:56,569][INFO ][o.e.b.BootstrapChecks ] [hadoop111] bound or publishing to a non-loopback address, enforcing bootstrap checks

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 [3764] for user [test] 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.initial_master_nodes] must be configured

[2019-09-06T10:58:56,987][INFO ][o.e.n.Node ] [hadoop111] stopping ...

[2019-09-06T10:58:57,014][INFO ][o.e.n.Node ] [hadoop111] stopped

[2019-09-06T10:58:57,015][INFO ][o.e.n.Node ] [hadoop111] closing ...

[2019-09-06T10:58:57,049][INFO ][o.e.n.Node ] [hadoop111] closed

[2019-09-06T10:58:57,057][INFO ][o.e.x.m.p.NativeController] [hadoop111] Native controller process has stopped - no new native processes can be started

终于好了,在网上转了好几圈,翻看了好多贴子,终于有整完了。

其实在好多贴子都写了,也能解决问题,但是有的关键的地方没有写到,所以你其实配正确了,但是最后启动还是启动不了

下面我就给大家分析一下怎么解决,总共是4个报错,先看一下这几个报错:

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

这个说应用打开一个文件的描述量(我觉的就是一个文件的大小),Linux中默认的访问量是4096,但是elasticsearch进程需要至少是65535

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

目前Linux对于test这个用户中最多线程(但是在配置文件中写的是process进程数量)数量是3764,需要增加打4096

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

虚拟的内存范围是65530太低,需要增加到至少262144

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

configured

默认的discovery设置不适合生产使用,在discovery.seec_hosts,discovery.seed_providers,cluter.inital_master_nodes中的至少一个需要设置一下

那么我就按着这几个问题解决一下,在许多贴子其实都有描述(配置文件的时候使用root用户):

vim /etc/security/limits.conf

修改这个配置文件:

这个就把第一和第二错误解决了,不要着急的再启动你的elasticsearch,接着解决第三个错误

[3]: max virtual memory areas vm.max_map_count [65530] is too low, increase to at least [262144]
修改/etc/sysctl.conf文件,增加配置vm.max_map_count=262144

这个配置文件配置完了,需要是这个配置文件生效一下,但是上边第一个错误和第二错误配置不需要生效

但是需要重新链接一下ssh(但也不需要着急的启动elasticsearch),不然的话第一个错误和第二错误还是会出错的。

还有一个elasticsearch的配置文件需要配置一下解决第4个错误:

在elasticsearch的目录中的config/elasticsearch.yml

cluster.initial_master_nodes: ["node-1"] 

这个配置完毕之后,重新用ssh链接一下服务器再启动就大功告成了,也可以用其他服务器访问该服务搜索引擎了

可以访问:http://192.168.1.129:9200/    也可以访问:http://192.168.1.129:9200/?pretty,如果出现下面的提示就说明成功了

这篇关于安装elasticsearch踩过的坑,教训写在这里,一起共同努力,希望大家先通读一下再按着步骤操作,看过就知道哪些坑可以掠过的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1042527

相关文章

ESP32 esp-idf esp-adf环境安装及.a库创建与编译

简介 ESP32 功能丰富的 Wi-Fi & 蓝牙 MCU, 适用于多样的物联网应用。使用freertos操作系统。 ESP-IDF 官方物联网开发框架。 ESP-ADF 官方音频开发框架。 文档参照 https://espressif-docs.readthedocs-hosted.com/projects/esp-adf/zh-cn/latest/get-started/index

Linux 安装、配置Tomcat 的HTTPS

Linux 安装 、配置Tomcat的HTTPS 安装Tomcat 这里选择的是 tomcat 10.X ,需要Java 11及更高版本 Binary Distributions ->Core->选择 tar.gz包 下载、上传到内网服务器 /opt 目录tar -xzf 解压将解压的根目录改名为 tomat-10 并移动到 /opt 下, 形成个人习惯的路径 /opt/tomcat-10

RedHat运维-Linux文本操作基础-AWK进阶

你不用整理,跟着敲一遍,有个印象,然后把它保存到本地,以后要用再去看,如果有了新东西,你自个再添加。这是我参考牛客上的shell编程专项题,只不过换成了问答的方式而已。不用背,就算是我自己亲自敲,我现在好多也记不住。 1. 输出nowcoder.txt文件第5行的内容 2. 输出nowcoder.txt文件第6行的内容 3. 输出nowcoder.txt文件第7行的内容 4. 输出nowcode

VMware9.0详细安装

双击VMware-workstation-full-9.0.0-812388.exe文件: 直接点Next; 这里,我选择了Typical(标准安装)。 因为服务器上只要C盘,所以我选择安装在C盘下的vmware文件夹下面,然后点击Next; 这里我把√取消了,每次启动不检查更新。然后Next; 点击Next; 创建快捷方式等,点击Next; 继续Cont

vcpkg安装opencv中的特殊问题记录(无法找到opencv_corexd.dll)

我是按照网上的vcpkg安装opencv方法进行的(比如这篇:从0开始在visual studio上安装opencv(超详细,针对小白)),但是中间出现了一些别人没有遇到的问题,虽然原因没有找到,但是本人给出一些暂时的解决办法: 问题1: 我在安装库命令行使用的是 .\vcpkg.exe install opencv 我的电脑是x64,vcpkg在这条命令后默认下载的也是opencv2:x6

【服务器运维】CentOS6 minimal 离线安装MySQL5.7

1.准备安装包(版本因人而异,所以下面的命令中版本省略,实际操作中用Tab自动补全就好了) cloog-ppl-0.15.7-1.2.el6.x86_64.rpmcpp-4.4.7-23.el6.x86_64.rpmgcc-4.4.7-23.el6.x86_64.rpmgcc-c++-4.4.7-23.el6.x86_64.rpmglibc-2.12-1.212.el6.x86_64.r

【服务器运维】CentOS7 minimal 离线安装 gcc perl vmware-tools

0. 本机在有网的情况下,下载CentOS镜像 https://www.centos.org/download/ 1. 取出rpm 有的情况可能不需要net-tools,但是如果出现跟ifconfig相关的错误,就把它安装上。另外如果不想升级内核版本的话,就找对应内核版本的rpm版本安装 perl-Time-Local-1.2300-2.el7.noarch.rpmperl-Tim

Windows/macOS/Linux 安装 Redis 和 Redis Desktop Manager 可视化工具

本文所有安装都在macOS High Sierra 10.13.4进行,Windows安装相对容易些,Linux安装与macOS类似,文中会做区分讲解 1. Redis安装 1.下载Redis https://redis.io/download 把下载的源码更名为redis-4.0.9-source,我喜欢跟maven、Tomcat放在一起,就放到/Users/zhan/Documents

Ubuntu20.04离线安装Docker

1.下载3个docker离线安装包,下载网址: https://download.docker.com/linux/ubuntu/dists/xenial/pool/stable/amd64/ 2.把3个离线安装包拷贝到ubuntu本地执行以下命令 sudo dpkg -i containerd.io_1.4.6-1_amd64.deb sudo dpkg -i docker-ce-c

SQL Server中,always on服务器的相关操作

在SQL Server中,建立了always on服务,可用于数据库的同步备份,当数据库出现问题后,always on服务会自动切换主从服务器。 例如192.168.1.10为主服务器,12为从服务器,当主服务器出现问题后,always on自动将主服务器切换为12,保证数据库正常访问。 对于always on服务器有如下操作: 1、切换主从服务器:假如需要手动切换主从服务器时(如果两个服务