Elasticsearch学习笔记(二)Windows安装

1. JDK

网上很多版本是需要手动安装JDK的,而且JDK版本至少得1.8以上的,但是最新的Elasticsearch7.x已经将jdk集成进去,因此不需要再手动安装。

2. 下载及安装

截止到目前ELasticsearch最新的版本(7.6.1)下载地址为下载
下载完成后解压文件到指定目录,如D:\workspace\software\elasticsearch-7.6.1\
Elasticsearch的目录结构如下:
在这里插入图片描述
文件结构的详细介绍请参考Elasticsearch目录结构及核心配置文件介绍

2.1 启动ELasticsearch

打开cmd命令行窗口,进入Elasticsearch安装目录,及上述目录的D:\workspace\software\elasticsearch-7.6.1目录下,执行以下命令:

bin\\elasticsearch

命令行窗口出现以下信息表上启动成功,此时Elasticsearch为单节点启动:

在这里插入图片描述
如果需要启动多个节点组成的集群,需要打开多个命令行窗口,执行下面命令

bin\\elasticsearch -Ecluster.name=集群名称 -Enode.name=节点名称

其中不同的节点集群名称相同,节点名称不同;
启动时如报以下错误:

uncaught exception in thread [main]
java.lang.IllegalStateException: failed to obtain node locks, tried [[D:\workspace\software\elasticsearch-7.6.1\data]] with lock id [0]; maybe these locations are not writable or multiple nodes were started without increasing [node.max_local_storage_nodes] (was [1])?
        at org.elasticsearch.env.NodeEnvironment.<init>(NodeEnvironment.java:301)
        at org.elasticsearch.node.Node.<init>(Node.java:277)
        at org.elasticsearch.node.Node.<init>(Node.java:257)
        at org.elasticsearch.bootstrap.Bootstrap$5.<init>(Bootstrap.java:221)
        at org.elasticsearch.bootstrap.Bootstrap.setup(Bootstrap.java:221)
        at org.elasticsearch.bootstrap.Bootstrap.init(Bootstrap.java:349)
        at org.elasticsearch.bootstrap.Elasticsearch.init(Elasticsearch.java:170)
        at org.elasticsearch.bootstrap.Elasticsearch.execute(Elasticsearch.java:161)
        at org.elasticsearch.cli.EnvironmentAwareCommand.execute(EnvironmentAwareCommand.java:86)
        at org.elasticsearch.cli.Command.mainWithoutErrorHandling(Command.java:125)
        at org.elasticsearch.cli.Command.main(Command.java:90)
        at org.elasticsearch.bootstrap.Elasticsearch.main(Elasticsearch.java:126)
        at org.elasticsearch.bootstrap.Elasticsearch.main(Elasticsearch.java:92)
For complete error details, refer to the log at D:\workspace\software\elasticsearch-7.6.1\logs\my_cluster_name.log

此错误的意思是在同一台机器上只能运行一个节点,一般部署Elasticsearch集群时也只会在一台机器上部署一个节点,可以在Elasticsearch安装目录下config目录下的elasticsearch.yml中添加如下配置:

node.max_local_storage_nodes: 10

表示同一台机器上最多可以运行10个节点。
启动时会看到这么这样的日志:

future versions of Elasticsearch will require Java 11; your Java version from [D:\Program Files\java\jdk1.8.0_111\jre] does not meet this requirement
Warning: with JDK 8 on Windows, Elasticsearch may be unable to derive correct
  ergonomic settings due to a JDK issue (JDK-8074459). Please use a newer
  version of Java.
Warning: MaxDirectMemorySize may have been miscalculated due to JDK-8074459.
  Please use a newer version of Java or set MaxDirectMemorySize explicitly.

这是因为环境变量中已配置jdk,Elasticsearch启动时默认使用环境变量中的配置,从上面的目录结构中我们已经看到Elasticsearch自带java环境,此时需要更Elasticsearch启动文件,让Elasticsearch使用自带的jdk环境,配置方式如下:
在Elasticsearch安装目录下的bin目录下,找到elasticsearch-env.bat,使用记事本打开,在

if defined JAVA_HOME (

前面加插入以下命令:

set JAVA_HOME="%ES_HOME%\jdk"

重新启动Elasticsearch节点,此时使用的已经是Elasticsearch自带的jdk了,但是还是会有一行warning

OpenJDK 64-Bit Server VM warning: Option UseConcMarkSweepGC was deprecated in version 9.0 and will likely be removed in a future release.

这是因为从jdk9开始cms垃圾收集器已经被标注为弃用了,可以在elasticsearch安装目录下的config下找到jvm.options文件,用记事本打开,将

-XX:+UseConcMarkSweepGC

修改为:

-XX:+UseG1GC

重新启动,服务正常,无warning
启动多个节点测试:
打开两个命令行窗口,并进入elasticsearch安装目录,分别执行以下命令:

elasticsearch -Ecluster.name=my_cluster -Enode.name=my_node1
elasticsearch -Ecluster.name=my_cluster -Enode.name=my_node2

若无报错信息,表示集群启动成功,在浏览器中输入:
http://localhost:9200测试,
在这里插入图片描述
查看集群健康状态:
在浏览器中输入:http://localhost:9200/_cluster/health
在这里插入图片描述
其中status表示集群的健康状态,
green:表示健康,所有主分片和副本分片都运行正常
yellow:表示亚健康,所有主分片都运行正常,但是存在副本分别运行不正常的情况
red:不健康,存在主分片运行不正常

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值