shell脚本部署zookeeper-3.4.10 [含注释]

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: shell脚本部署zookeeper-3.4.10 [含注释]

zk_install.sh

#!/bin/bash
base_path=$(cd `dirname $0`; pwd)
source ${base_path}/conf/config
function install_java () {
for (( i=0; i<${#zk_array[@]}; i++ ))
do
  # 判断需要安装zookeeper的节点是否已有java环境 [zookeeper的启动依赖java环境]
  # 返回非零状态则表示java环境不存在,并安装java环境
  # $USER 为环境变量,输出的值为当前用户的名称 [建议使用普通用户]
  ssh $USER@${zk_array[i]} 'java -version' &> /dev/null
  if [[ "$?" -ne '0' ]];then
    ssh $USER@${zk_array[i]} "mkdir -p ${java_path}"
    # 如果准备的java安装包名称不是 jdk.tar.gz ,可以重命名成 jdk.tar.gz ,或者修改 jdk.tar.gz 为当前安装包的名称
    scp ${base_path}/package/jdk.tar.gz $USER@${zk_array[i]}:${pack_path}/
    # 如果上一行有修改,此处的 jdk.tar.gz 也需要修改
    ssh $USER@${zk_array[i]} "cd ${pack_path} && tar xf jdk.tar.gz -C ${java_path} && rm -f jdk.tar.gz"
    ssh $USER@${zk_array[i]} "echo \"export JAVA_HOME=${java_path}\" >> $HOME/.bashrc"
    ssh $USER@${zk_array[i]} "echo 'export PATH=\$PATH:\$JAVA_HOME/bin' >> $HOME/.bashrc"
    ssh $USER@${zk_array[i]} "echo 'source /etc/profile' >> $HOME/.bashrc"
  fi
done
}
function install_zk () {
# 将 conf 目录下的 zoo_template.cfg 文件重定向成 zoo_sample.cfg 文件,保持配置文件的干净
# zoo_template.cfg 文件需要提前准备好
cat ${base_path}/conf/zoo_template.cfg > ${base_path}/conf/zoo_sample.cfg
# 定义一个变量conut,赋值为0,因为zookeeper是需要用到myid的,至于为什么不从1开始,程序员都懂的
count=0
for (( i=0; i<${#zk_array[@]}; i++ ))
do
  # 每次循环,count的值则会加1
  let count++
  echo "server.${count}=${zk_array[i]}:2888:3888" >> ${base_path}/conf/zoo_sample.cfg
done
# 根据 conf 目录下的 config 文件来修改 zoo_sample.cfg 文件,以此来生成zookeeper的配置文件
# 这里只修改了端口和数据目录,其他的可以自行使用增加sed命令即可
sed -i "/clientPort/s/=.*/=${zk_clinet_port}/" ${base_path}/conf/zoo_sample.cfg
sed -i "/dataDir/s#=.*#=${zk_data_dir}#" ${base_path}/conf/zoo_sample.cfg
# 开始安装zookeeper
for (( i=0; i<${#zk_array[@]}; i++ ))
do
  ssh $USER@${zk_array[i]} "mkdir ${zk_path}"
  scp ${base_path}/package/${pack_name}.tar.gz $USER@${zk_array[i]}:${pack_path}/
  ssh $USER@${zk_array[i]} "cd ${pack_path} && tar xf ${pack_name}.tar.gz -C ${zk_path} && rm -f ${pack_name}.tar.gz"
  ssh $USER@${zk_array[i]} "mkdir ${zk_data_dir}"
  scp ${base_path}/conf/zoo_sample.cfg $USER@${zk_array[i]}:${zk_path}/${pack_name}/conf/zoo.cfg
done
# 生成myid
id_num=0
for (( i=0; i<${#zk_array[@]}; i++ ))
do
  let id_num++
  ssh $USER@${zk_array[i]} "echo ${id_num} > ${zk_data_dir}/myid"
done
}
# 启动zookeeper
function start_zk () {
for (( i=0; i<${#zk_array[@]}; i++ ))
do
  ssh $USER@${zk_array[i]} "${zk_path}/${pack_name}/bin/zkServer.sh restart"
done
}
# 检查zookeeper的状态
function status_zk () {
# 检查每个节点的zookeeper状态
for (( i=0; i<${#zk_array[@]}; i++ ))
do
  # 利用zkServer.sh status来查看zookeeper的状态,grep -o 是只过滤Mode这个关键字,存在的情况下,只会返回Mode
  local check_status=$(ssh $USER@${zk_array[i]} "${zk_path}/${pack_name}/bin/zkServer.sh status | grep -o Mode")
  # 通过while死循环加上字符串比较来等待zookeeper服务的状态 [依赖java环境的服务,启动普遍偏慢]
  while [[ x"${check_status}" != x"Mode" ]]
  do
    sleep 10
    # 重新赋值来刷新变量值
    local check_status=$(ssh $USER@${zk_array[i]} "${zk_path}/${pack_name}/bin/zkServer.sh status | grep -o Mode") 
  done
done
if [[ $? -eq 0 ]];then
  echo "zookeeper cluster install success"
else
  echo "zookeeper cluster install fail"
  exit 2
fi
}
install_java
install_zk
start_zk
status_zk

conf/config

#!/bin/bash
base_path=$(cd `dirname $0`; pwd)
# 此处的ip为zookeeper节点ip
zk_hosts='
192.168.72.107
192.168.72.108
192.168.72.109
'
# 这个是格式转换,将上面的变量转换成数组的格式
zk_array=($(printf "%q\n" ${zk_hosts}))
# 一般zookeeper的安装包名称格式是zookeeper-版本,这里只需要和安装包的一样就可以了,去掉后缀
pack_name='zookeeper-3.4.10'
# java和zookeeper安装的目录 [注意查看磁盘空间大小,以实际情况来修改]
pack_path='/approot1'
java_path="${pack_path}/jdk"
zk_path="${pack_path}/zookeeper"
zk_data_dir="${zk_path}/${pack_name}/data"
# zookeeper的默认端口是2181,根据实际需求修改
zk_clinet_port=7181

conf/zoo_template.cfg

这是zookeeper安装包里面的配置文件模板

# The number of milliseconds of each tick
tickTime=2000
# The number of ticks that the initial 
# synchronization phase can take
initLimit=10
# The number of ticks that can pass between 
# sending a request and getting an acknowledgement
syncLimit=5
# the directory where the snapshot is stored.
# do not use /tmp for storage, /tmp here is just 
# example sakes.
dataDir=/tmp/zookeeper-3.4.10/data
# the port at which the clients will connect
clientPort=2181
# the maximum number of client connections.
# increase this if you need to handle more clients
#maxClientCnxns=60
#
# Be sure to read the maintenance section of the 
# administrator guide before turning on autopurge.
#
# http://zookeeper.apache.org/doc/current/zookeeperAdmin.html#sc_maintenance
#
# The number of snapshots to retain in dataDir
#autopurge.snapRetainCount=3
# Purge task interval in hours
# Set to "0" to disable auto purge feature
#autopurge.purgeInterval=1

package

安装包存放的路径

|___ jdk.tar.gz
|___ zookeeper-3.4.10.tar.gz


相关实践学习
基于MSE实现微服务的全链路灰度
通过本场景的实验操作,您将了解并实现在线业务的微服务全链路灰度能力。
目录
相关文章
|
8天前
|
监控 Shell Linux
Linux的Shell脚本详解
Linux的Shell脚本详解
|
12天前
|
Shell
shell脚本
shell脚本
15 2
|
20天前
|
Ubuntu Java Linux
Linux centos7 ubuntu 一键安装Java JDK 脚本 shell 脚本
Linux centos7 ubuntu 一键安装Java JDK 脚本 shell 脚本
32 2
|
20天前
|
Shell Linux
shell linux中shell脚本编写俄罗斯方块
shell linux中shell脚本编写俄罗斯方块
19 1
|
21天前
|
Shell Linux Perl
Linux shell脚本sed使用
Linux shell脚本sed使用
15 1
|
1天前
|
Shell
Shell脚本之条件语句if总结
Shell脚本之条件语句if总结
|
20天前
|
Ubuntu Shell Linux
linux shell 后台执行脚本的方法 脚本后台运行 后台运行程
linux shell 后台执行脚本的方法 脚本后台运行 后台运行程
14 0
|
20天前
|
监控 Shell Linux
shell linux中用shell写一个占用CPU的脚本
shell linux中用shell写一个占用CPU的脚本
19 0
|
21天前
|
Shell Linux
linux shell 脚本实现:根据文件内容中的每行分隔符放入数组,根据规则打印日志并重新创建目录 备份文件
linux shell 脚本实现:根据文件内容中的每行分隔符放入数组,根据规则打印日志并重新创建目录 备份文件
19 0
|
21天前
|
Shell Linux BI
linux shell脚本中 if 条件判断
linux shell脚本中 if 条件判断
13 0