本文基于Linux环境部署和启动ElasticSearch7.5全文检索服务,相关步骤中做了一些在Linux上的注意事项和配置。
一、部署环境
1、Linux系统版本:CentOS 7.3.1611
2、ElasticSearch7.5.1安装包:elasticsearch-7.5.1-linux-x86_64.tar.gz
3、使用ES内置的JDK
二、安装和启动
1、准备好ElasticSearch7.5.1的Linux版本的安装包,这里上传到/opt/media目录下:
elasticsearch-7.5.1-linux-x86_64.tar.gz
2、在Linux上安装ElasticSearch需要用一个普通账户,用root账户存在问题,需要创建指定的用户去启动和部署ElasticSearch,用户名称不一定必须叫elasticsearch,如下:
useradd elasticsearch
passwd elasticsearch
3、使用root高权限用户,设置该用户的ulimit设置,输入如下命令编辑文件:
vi /etc/security/limits.conf
在文件后面,设置elasticsearch用户的系统资源限制
elasticsearch soft nofile 65536
elasticsearch hard nofile 65536
elasticsearch soft nproc 4096
elasticsearch hard nproc 4096
4、修改linux内核文件,设置vm.max_map_count参数,相关命令如下所示:
vi /etc/sysctl.conf
在文件的最后增加
vm.max_map_count=655360
保存退出后,执行如下命令使内核修改生效
sysctl -p
如果不设置用户的ulimit设置和系统内核参数,会出现类似如下错误提示:
[1]: max number of threads [1024] for user [elasticsearch] is too low, increase to at least [4096]
[2]: max virtual memory areas vm.max_map_count [65530] is too low, increase to at least [262144]
或:
[1]: max file descriptors [4096] for elasticsearch process is too low, increase to at least [65535]
[2]: max virtual memory areas vm.max_map_count [65530] is too low, increase to at least [262144]
5、创建存储解压后的目录,并赋予所属权限,然后切换到elasticsearch用户后,解压安装介质包
mkdir es7.5
chown elasticsearch:elasticsearch es7.5
chown elasticsearch:elasticsearch elasticsearch-7.5.1-linux-x86_64.tar.gz
mv elasticsearch-7.5.1-linux-x86_64.tar.gz es7.5/
su - elasticsearch
cd /opt/media/es7.5
tar -zxvf elasticsearch-7.5.1-linux-x86_64.tar.gz
6、更改ElasticSearch配置文件默认JDK引用的位置为内置的路径,操作命令如下:
vi /opt/media/es7.5/elasticsearch-7.5.1/bin/elasticsearch-env
修改大概39行附近的读取java的相关代码,修改下方的第2行和第三行,更改为如下类似:
if [ ! -z "$JAVA_HOME" ]; then
JAVA="$JAVA_HOME/bin/java"
JAVA_TYPE="JAVA_HOME"
else
if [ "$(uname -s)" = "Darwin" ]; then
# macOS has a different structure
JAVA="$ES_HOME/jdk.app/Contents/Home/bin/java"
else
JAVA="$ES_HOME/jdk/bin/java"
fi
JAVA_TYPE="bundled jdk"
fi
7、更改config文件夹下的elasticsearch.yml文件,可以根据需要修改默认端口9200为其他,由于目前为单节点,主要需要设置如下参数,
network.host: 0.0.0.0
bootstrap.memory_lock: false
bootstrap.system_call_filter: false
cluster.initial_master_nodes: ["node-1"]
否则会出现如下提示:
network.host: 0.0.0.0
bootstrap.memory_lock: false
bootstrap.system_call_filter: false
cluster.initial_master_nodes: ["node-1"]
8、最后输入如下命令启动,当启动命令中不指定-d参数时为前台启动,窗口关闭则退出服务,如下:
bin/elasticsearch
或后台方式启动
bin/elasticsearch -d
9、启动成功后,在浏览器中访问http://ip:9200/,如果出现类型结果,则证明安装成功!
{
"name" : "mydc-es-1",
"cluster_name" : "elasticsearch",
"cluster_uuid" : "_na_",
"version" : {
"number" : "7.5.1",
"build_flavor" : "default",
"build_type" : "tar",
"build_hash" : "3ae9ac9a93c95bd0cdc054951cf95d88e1e18d96",
"build_date" : "2019-12-16T22:57:37.835892Z",
"build_snapshot" : false,
"lucene_version" : "8.3.0",
"minimum_wire_compatibility_version" : "6.8.0",
"minimum_index_compatibility_version" : "6.0.0-beta1"
},
"tagline" : "You Know, for Search"
}
这样就简单的在Linux上启动部署一个单节点的全文检索服务,希望可以帮助到需要的小伙伴们!