赞
踩
- https://www.elastic.co/cn/downloads/elasticsearch
- 下载你需要的版本
- 192.168.28.129
- 192.168.28.130
- 192.168.29.131
Elasticsearch不能在 root
用户下启动,我们需要在三台机器上分别创建一个普通用户:
- # 创建elastic用户
- useradd elastic
- # 设置用户密码
- passwd elastic
- # 切换到elastic用户
- su elastic
-
- 这样创建的用户的目录默认在/home/elastic 下面
分别在三台机器上的 /home/elastic/
目录下创建elasticsearch文件夹,然后在elasticsearch文件夹下分别创建data、logs文件夹。 用的elastic登陆创建哟
在生产环境下我们要把Elasticsearch生成的索引文件数据存放到自定义的目录下
data:存储Elasticsearch索引文件数据
logs:存储日志文件
随便那一台机器将下载的elasticsearch-7.17.0-linux-x86_64.tar.gz 移动 /home/elastic/下
解压缩: tar zxvf
elasticsearch-7.17.0-linux-x86_64.tar.gz
vi config/elasticsearch.yml
- cluster.name: my-application
-
- node.name: node-1
-
-
- path.data: /home/elastic/elasticsearch/data
-
- path.logs: /home/elastic/elasticsearch/logs
-
- network.host: 192.168.28.129
-
- http.port: 9200
-
- discovery.seed_hosts: ["192.168.28.129", "192.168.28.130", "192.168.28.131"]
-
- cluster.initial_master_nodes: ["node-1", "node-2", "node-3"]
-
- node.master: true
- node.data: false
- node.ingest: false
- search.remote.connect: false
主要修改如下几处配置:
cluster.name
的值必须要相同。0.0.0.0
(任何地址都能访问到)。9200
即可,当然你也可以修改不过不配置默认是 如下
node.master: true
node.data: true
node.ingest: false
search.remote.connect: false
参考如下:
https://blog.csdn.net/zhuchunyan_aijia/article/details/128720341
可以配置3个master节点, 其余都是data 节点. 也不需要ingest 和 协调节点
我们已经配置好一台Elasticsearch节点了接下来我们只需要把这台配置好的Elasticsearch复制到另外两台机器中在做一些简单的修改就就可以了。
我们使用 scp
命令复制当前配置好的Elasticsearch到另外两台机器中:
- scp -r /home/elastic/elasticsearch/elasticsearch
- elastic@192.168.28.130:/home/elastic/elasticsearch/
-
- scp -r /home/elastic/elasticsearch/elasticsearch
- elastic@192.168.28.131:/home/elastic/elasticsearch/
分别在两台机器中修改几处配置:192.168.28.130
这台机器修改elasticsearch.yml配置文件如下
- node.name: node-2
- network.host: 192.168.28.130
从命令行运行Elasticsearch
Elasticsearch可以从命令行启动,如下所示:
./bin/elasticsearch
作为后台启动
要将Elasticsearch作为后台程序运行,请在命令中指定-d
,然后使用-p
将进程ID记录在文件中:
./bin/elasticsearch -d -p pid
分别在三台机器上启动Elasticsearch,启动过程中建议单个机器启动成功后在启动另一台。
- 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]
- ERROR: Elasticsearch did not exit normally - check the logs at /home/elastic/logs/xxxxx
以下配置需要在root帐号下处理
1. /etc/security/limits.conf
- * soft nofile 65535
- * hard nofile 65535
- elastic soft memlock unlimited
- elastic hard memlock unlimited
2. /etc/security/limits.d/20-nproc.conf
- * soft nproc 65535
- root soft nproc unlimited
3. /etc/sysctl.conf
- vm.max_map_count = 655360
- vm.swappiness=1
- kernel.pid_max = 65535
-
- 保存后执行:sysctl -p 生效
接下来我们来检查一下集群是否已经形成,给三台服务器中的任意一台发送http请求:
http://192.168.28.129:9200/_cat/health?v
cluster:显示的是当前集群的名称
status:显示的是 green
表示当前集群是健康的状态
node.total:显示 3
表示当前集群有三个节点
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。