@zhangyy
2021-10-22T13:36:54.000000Z
字数 12942
阅读 135
ElasticSearch系列
系统:rhel8.3x64-1
cat /etc/hosts
----
192.168.100.41 rhel01.flyfish.cn 协调节点
192.168.100.42 rhel02.flyfish.cn 协调节点
192.168.100.43 rhel03.flyfish.cn 协调节点
192.168.100.44 rhel04.flyfish.cn 主节点
192.168.100.45 rhel05.flyfish.cn 主机点
192.168.100.46 rhel06.flyfish.cn 主节点
192.168.100.47 rhel07.flyfish.cn 数据节点
192.168.100.48 rhel08.flyfish.cn 数据节点
192.168.100.49 rhel09.flyfish.cn 数据节点
192.168.100.50 rhel10.flyfish.cn 扩容数据节点
192.168.100.51 rhel11.flyfish.cn 扩容数据节点
----
先部署前面九台机器,后面 两台作为 扩容节点
全部系统配置:
系统语言:
echo "export LANG=en_US.UTF8" >> ~/.bash_profile
cat ~/.bash_profile
---
分区:
pvcreate /dev/sdb
vgcreate esdatavg /dev/sdb
lvcreate -n esdatalv -L 100000M esdatavg
mkfs.xfs /dev/esdatavg/esdatalv
---
vi /etc/fstab
---
/dev/esdatavg/esdatalv /esdb xfs defaults 0 0
---
mkdir /esdb
mount /esdb
mkdir -p /esdb/soft
groupadd -g 60001 esadmin
useradd -u 61001 -g esadmin esadmin
chown -R esadmin:esadmin /esdb
chmod -R 775 /esdb
echo "esadmin" | passwd --stdin esadmin
systemctl set-default multi-user.target
chown esadmin:esadmin -R /esdb
cat >> /etc/security/limits.conf << EOF
root soft nofile 1048576
root hard nofile 1048576
esadmin soft nproc 1048576
esadmin hard nproc 1048576
esadmin soft nofile 1048576
esadmin hard nofile 1048576
esadmin soft stack 10240
esadmin hard stack 32768
esadmin hard memlock unlimited
esadmin soft memlock unlimited
EOF
---
---
cat >> /etc/sysctl.conf << EOF
fs.aio-max-nr = 1048576
fs.file-max = 6815744
net.ipv4.ip_local_port_range = 1024 65535
net.ipv4.tcp_mem = 786432 2097152 3145728
net.ipv4.tcp_rmem = 4096 4096 16777216
net.ipv4.tcp_wmem = 4096 4096 16777216
net.ipv4.tcp_tw_reuse = 1
net.ipv4.tcp_tw_recycle = 1
vm.swappiness=1
vm.min_free_kbytes=204800
vm.max_map_count=2048000
kernel.pid_max=819200
vm.zone_reclaim_mode=0
#vm.nr_hugepages = 0
EOF
sysctl -p
ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
hwclock
echo "SELINUX=disabled" > /etc/selinux/config
echo "#SELINUXTYPE=targeted " >> /etc/selinux/config
cat /etc/selinux/config
setenforce 0
systemctl stop firewalld.service
systemctl disable firewalld.service
cat >> /home/esadmin/.vimrc << EOF
map <F10>:set paste<CR>
map <F11>:set nopaste<CR>
EOF
shutdown -r now
做9台机器的esadmin 无密码登录
做esadmin 的无密码登录
/root/fgssh -user esadmin -hosts "rhel01.flyfish.cn rhel02.flyfish.cn rhel03.flyfish.cn rhel04.flyfish.cn rhel05.flyfish.cn rhel06.flyfish.cn rhel07.flyfish.cn rhel08.flyfish.cn rhel09.flyfish.cn" -advanced -exverify -confirm
chmod 600 /home/esadmin/.ssh/config
su - esadmin
cd /esdb/
tar zxvf /esdb/soft/jdk-14.0.2_linux-x64_bin.tar.gz
scp -r /esdb/jdk-14.0.2 esadmin@rhel02.flyfish.cn:/esdb/
scp -r /esdb/jdk-14.0.2 esadmin@rhel03.flyfish.cn:/esdb/
scp -r /esdb/jdk-14.0.2 esadmin@rhel04.flyfish.cn:/esdb/
scp -r /esdb/jdk-14.0.2 esadmin@rhel05.flyfish.cn:/esdb/
scp -r /esdb/jdk-14.0.2 esadmin@rhel06.flyfish.cn:/esdb/
scp -r /esdb/jdk-14.0.2 esadmin@rhel07.flyfish.cn:/esdb/
scp -r /esdb/jdk-14.0.2 esadmin@rhel08.flyfish.cn:/esdb/
scp -r /esdb/jdk-14.0.2 esadmin@rhel09.flyfish.cn:/esdb/
全部主机:
su - esadmin
cat >> ~/.bash_profile << EOF
export JAVA_HOME=/esdb/jdk-14.0.2
export PATH=/esdb/jdk-14.0.2/bin:$PATH
export LANG=en_US.UTF8
EOF
source ~/.bash_profile
java -version
全部主机:
mkdir -p /esdb/soft/
mkdir -p /esdb/esapp/esapp9200
mkdir -p /esdb/esdata/esdata9200
mkdir -p /esdb/eslog/eslog9200
chown esadmin:esadmin -R /esdb/
rhel01.flyfish.cn: 操作
cd /esdb/soft
tar zxvf /esdb/soft/elasticsearch-7.9.0-linux-x86_64.tar.gz
cp -r /esdb/elasticsearch-7.9.0/* /esdb/esapp/esapp9200
vi /esdb/esapp/esapp9200/bin/elasticsearch-env
----
export JAVA_HOME=/esdb/jdk-14.0.2
export PATH=$JAVA_HOME/bin:$PATH
----
vi /esdb/esapp/esapp9200/config/elasticsearch.yml
----
cluster.name: flyfishescluster1
node.name: 192.168.100.41
network.host: 192.168.100.41
http.port: 9200
transport.tcp.port: 9300
path.data: /esdb/esdata/esdata9200
path.logs: /esdb/eslog/eslog9200
node.master: false
node.data: false
cluster.remote.connect: false
http.cors.enabled: true
http.cors.allow-origin: "*"
bootstrap.memory_lock: true
bootstrap.system_call_filter: false
cluster.initial_master_nodes:
["192.168.100.44:9300","192.168.100.45:9300","192.168.100.46:9300"]
discovery.seed_hosts: ["192.168.100.44:9300", "192.168.100.45:9300", "192.168.100.46:9300"]
discovery.zen.fd.ping_timeout: 60s
discovery.zen.fd.ping_retries: 5
----
vim /esdb/esapp/esapp9200/config/jvm.options
----
-Xms1g
-Xmx1g
-XX:+DisableExplicitGC
-XX:HeapDumpPath=/esdb/eslog/eslog9200
-XX:ErrorFile=/esdb/eslog/eslog9200/hs_err_pid%p.log
9-:-Xlog:gc*,gc+age=trace,safepoint:file=/esdb/eslog/eslog9200/gc.log:utctime,pid,ta
gs:filecount=32,filesize=64m
----
同步所有主机:(所有节点都执行)
scp -r rhel01.flyfish.cn:/esdb/esapp/esapp9200 /esdb/esapp/
rhel0(1-3).flyfish.cn 前三台做协调节点:
rhel01.flyfish.cn:
vi /esdb/esapp/esapp9200/config/elasticsearch.yml
----
cluster.name: flyfishescluster1
node.name: 192.168.100.41
network.host: 192.168.100.41
http.port: 9200
transport.tcp.port: 9300
path.data: /esdb/esdata/esdata9200
path.logs: /esdb/eslog/eslog9200
node.master: false
node.data: false
cluster.remote.connect: false
http.cors.enabled: true
http.cors.allow-origin: "*"
bootstrap.memory_lock: true
bootstrap.system_call_filter: false
cluster.initial_master_nodes:
["192.168.100.44:9300","192.168.100.45:9300","192.168.100.46:9300"]
discovery.seed_hosts: ["192.168.100.44:9300", "192.168.100.45:9300", "192.168.100.46:9300"]
discovery.zen.fd.ping_timeout: 60s
discovery.zen.fd.ping_retries: 5
-----
rhel02.flyfish.cn:
vi /esdb/esapp/esapp9200/config/elasticsearch.yml
----
cluster.name: flyfishescluster1
node.name: 192.168.100.42
network.host: 192.168.100.42
http.port: 9200
transport.tcp.port: 9300
path.data: /esdb/esdata/esdata9200
path.logs: /esdb/eslog/eslog9200
node.master: false
node.data: false
cluster.remote.connect: false
http.cors.enabled: true
http.cors.allow-origin: "*"
bootstrap.memory_lock: true
bootstrap.system_call_filter: false
cluster.initial_master_nodes:
["192.168.100.44:9300","192.168.100.45:9300","192.168.100.46:9300"]
discovery.seed_hosts: ["192.168.100.44:9300", "192.168.100.45:9300", "192.168.100.46:9300"]
discovery.zen.fd.ping_timeout: 60s
discovery.zen.fd.ping_retries: 5
----
rhel03.flyfish.cn:
vi /esdb/esapp/esapp9200/config/elasticsearch.yml
---
cluster.name: flyfishescluster1
node.name: 192.168.100.43
network.host: 192.168.100.43
http.port: 9200
transport.tcp.port: 9300
path.data: /esdb/esdata/esdata9200
path.logs: /esdb/eslog/eslog9200
node.master: false
node.data: false
cluster.remote.connect: false
http.cors.enabled: true
http.cors.allow-origin: "*"
bootstrap.memory_lock: true
bootstrap.system_call_filter: false
cluster.initial_master_nodes:
["192.168.100.44:9300","192.168.100.45:9300","192.168.100.46:9300"]
discovery.seed_hosts: ["192.168.100.44:9300", "192.168.100.45:9300", "192.168.100.46:9300"]
discovery.zen.fd.ping_timeout: 60s
discovery.zen.fd.ping_retries: 5
---
rhel0(4-6).flyfish.cn做 主节点:
rhel04.flyfish.cn:
vi /esdb/esapp/esapp9200/config/elasticsearch.yml
----
cluster.name: flyfishescluster1
node.name: 192.168.100.44
network.host: 192.168.100.44
http.port: 9200
transport.tcp.port: 9300
path.data: /esdb/esdata/esdata9200
path.logs: /esdb/eslog/eslog9200
node.master: true
node.data: false
cluster.remote.connect: false
http.cors.enabled: true
http.cors.allow-origin: "*"
bootstrap.memory_lock: true
bootstrap.system_call_filter: false
cluster.initial_master_nodes:
["192.168.100.44:9300","192.168.100.45:9300","192.168.100.46:9300"]
discovery.seed_hosts: ["192.168.100.44:9300", "192.168.100.45:9300", "192.168.100.46:9300"]
discovery.zen.fd.ping_timeout: 60s
discovery.zen.fd.ping_retries: 5
-----
rhel05.flyfish.cn:
vi /esdb/esapp/esapp9200/config/elasticsearch.yml
----
cluster.name: flyfishescluster1
node.name: 192.168.100.45
network.host: 192.168.100.45
http.port: 9200
transport.tcp.port: 9300
path.data: /esdb/esdata/esdata9200
path.logs: /esdb/eslog/eslog9200
node.master: true
node.data: false
cluster.remote.connect: false
http.cors.enabled: true
http.cors.allow-origin: "*"
bootstrap.memory_lock: true
bootstrap.system_call_filter: false
cluster.initial_master_nodes:
["192.168.100.44:9300","192.168.100.45:9300","192.168.100.46:9300"]
discovery.seed_hosts: ["192.168.100.44:9300", "192.168.100.45:9300", "192.168.100.46:9300"]
discovery.zen.fd.ping_timeout: 60s
discovery.zen.fd.ping_retries: 5
----
rhel06.flyfish.cn:
vi /esdb/esapp/esapp9200/config/elasticsearch.yml
---
cluster.name: flyfishescluster1
node.name: 192.168.100.46
network.host: 192.168.100.46
http.port: 9200
transport.tcp.port: 9300
path.data: /esdb/esdata/esdata9200
path.logs: /esdb/eslog/eslog9200
node.master: true
node.data: false
cluster.remote.connect: false
http.cors.enabled: true
http.cors.allow-origin: "*"
bootstrap.memory_lock: true
bootstrap.system_call_filter: false
cluster.initial_master_nodes:
["192.168.100.44:9300","192.168.100.45:9300","192.168.100.46:9300"]
discovery.seed_hosts: ["192.168.100.44:9300", "192.168.100.45:9300", "192.168.100.46:9300"]
discovery.zen.fd.ping_timeout: 60s
discovery.zen.fd.ping_retries: 5
----
rhel0(7-9).flyfish.cn 做数据节点:
rhel07.flyfish.cn
vi /esdb/esapp/esapp9200/config/elasticsearch.yml
---
cluster.name: flyfishescluster1
node.name: 192.168.100.47
network.host: 192.168.100.47
http.port: 9200
transport.tcp.port: 9300
path.data: /esdb/esdata/esdata9200
path.logs: /esdb/eslog/eslog9200
node.master: false
node.data: true
cluster.remote.connect: false
http.cors.enabled: true
http.cors.allow-origin: "*"
bootstrap.memory_lock: true
bootstrap.system_call_filter: false
cluster.initial_master_nodes:
["192.168.100.44:9300","192.168.100.45:9300","192.168.100.46:9300"]
discovery.seed_hosts: ["192.168.100.44:9300", "192.168.100.45:9300", "192.168.100.46:9300"]
discovery.zen.fd.ping_timeout: 60s
discovery.zen.fd.ping_retries: 5
---
rhel08.flyfish.cn:
vi /esdb/esapp/esapp9200/config/elasticsearch.yml
----
cluster.name: flyfishescluster1
node.name: 192.168.100.48
network.host: 192.168.100.48
http.port: 9200
transport.tcp.port: 9300
path.data: /esdb/esdata/esdata9200
path.logs: /esdb/eslog/eslog9200
node.master: false
node.data: true
cluster.remote.connect: false
http.cors.enabled: true
http.cors.allow-origin: "*"
bootstrap.memory_lock: true
bootstrap.system_call_filter: false
cluster.initial_master_nodes: ["192.168.100.44:9300","192.168.100.45:9300","192.168.100.46:9300"]
discovery.seed_hosts: ["192.168.100.44:9300", "192.168.100.45:9300", "192.168.100.46:9300"]
discovery.zen.fd.ping_timeout: 60s
discovery.zen.fd.ping_retries: 5
----
rhel09.flyfish.cn:
vi /esdb/esapp/esapp9200/config/elasticsearch.yml
----
cluster.name: flyfishescluster1
node.name: 192.168.100.49
network.host: 192.168.100.49
http.port: 9200
transport.tcp.port: 9300
path.data: /esdb/esdata/esdata9200
path.logs: /esdb/eslog/eslog9200
node.master: false
node.data: true
cluster.remote.connect: false
http.cors.enabled: true
http.cors.allow-origin: "*"
bootstrap.memory_lock: true
bootstrap.system_call_filter: false
cluster.initial_master_nodes: ["192.168.100.44:9300","192.168.100.45:9300","192.168.100.46:9300"]
discovery.seed_hosts: ["192.168.100.44:9300", "192.168.100.45:9300", "192.168.100.46:9300"]
discovery.zen.fd.ping_timeout: 60s
discovery.zen.fd.ping_retries: 5
----
mkdir -p /esdb/scripts
vim /esdb/script/es_start.sh
----
#!/bin/bash
echo "es cluster all node start..."
for hostm in rhel04.flyfish.cn rhel05.flyfish.cn rhel06.flyfish.cn
#for host in `cat /esdb/scripts/es_host.sh | awk '{print $1}'`
do
echo "--------------------------------"
echo $hostm "node es start..."
ssh -n -T $hostm "/esdb/esapp/esapp9200/bin/elasticsearch -d >/dev/null 2>&1 &"
echo $hostm "node es start cancel..."
done
sleep 120
for hostd in rhel07.flyfish.cn rhel08.flyfish.cn rhel09.flyfish.cn
#for host in `cat /esdb/scripts/es_host.sh | awk '{print $1}'`
do
echo "--------------------------------"
echo $hostd "node es start..."
ssh -n -T $hostd "/esdb/esapp/esapp9200/bin/elasticsearch -d >/dev/null 2>&1 &"
echo $hostd "node es start cancel..."
done
sleep 120
for host in rhel01.flyfish.cn rhel02.flyfish.cn rhel03.flyfish.cn
#for host in `cat /esdb/scripts/es_host.sh | awk '{print $1}'`
do
echo "--------------------------------"
echo $host "node es start..."
ssh -n -T $h0st "/esdb/esapp/esapp9200/bin/elasticsearch -d >/dev/null 2>&1 &"
echo $host "node es start cancel..."
done
echo "es cluster all node start OK!"
----
vi /esdb/scripts/es_kill.sh
---
#!/bin/bash
ps -ef|grep java|grep esapp|awk '{print $2}'|xargs kill -9
vi /esdb/scripts/es_stop.sh
#!/bin/bash
echo "es cluster all node stop..."
for host in rhel01.flyfish.cn rhel02.flyfish.cn rhel03.flyfish.cn rhel04.flyfish.cn rhel05.flyfish.cn rhel06.flyfish.cn rhel07.flyfish.cn rhel08.flyfish.cn rhel09.flyfish.cn
#for host in `cat /esdb/scripts/host.sh | awk '{print $1}'`
do
echo "--------------------------------"
echo $host "node es stop..."
ssh -n -T $host "/esdb/scripts/es_kill.sh"
echo $host "node es stop cancel..."
done
echo "es cluster all node stop OK!"
---
chmod 755 /esdb/scripts/es_*.sh
/esdb/scripts/es_stop.sh
/esdb/scripts/es_start.sh
curl '192.168.100.44:9200/_cat/nodes?v'
curl -XPUT 192.168.100.41:9200/_template/all_index_shards -H 'Content-Type:application/json' -d '{
"template": "*",
"settings": {
"number_of_shards": 6,
"number_of_replicas": "1"
}
}'
设置路由分片防止堆积在一台上面:
curl -XPUT '192.168.100.41:9200/_cluster/settings' -H 'Content-Type: application/json' -d '{
"transient": {
"cluster.routing.allocation.same_shard.host": true
}
}'
插入数据:
curl -XPOST http://192.168.100.41:9200/itpuxdb/_doc/?pretty -H 'Content-Type:application/json' -d '
{
"id" : "1",
"name" : "itpux001",
"city" : "上海",
"course" : "bigdata",
"teacher" : "flyfish",
"pxdate": "20200829"
}'
查看数据:
curl -XPOST 'http://192.168.100.41:9200/itpuxdb/_search?pretty' -H 'Content-Type:application/json'
curl http://192.168.100.41:9200/_cat/shards?v