zookeeper-server-stop.sh 脚本

bash 复制代码
SIGNAL=${SIGNAL:-TERM}

OSNAME=$(uname -s)
if [[ "$OSNAME" == "OS/390" ]]; then
    if [ -z $JOBNAME ]; then
        JOBNAME="ZKEESTRT"
    fi
    PIDS=$(ps -A -o pid,jobname,comm | grep -i $JOBNAME | grep java | grep -v grep | awk '{print $1}')
elif [[ "$OSNAME" == "OS400" ]]; then
    PIDS=$(ps -Af | grep java | grep -i QuorumPeerMain | grep -v grep | awk '{print $2}')
else
    PIDS=$(ps ax | grep java | grep -i QuorumPeerMain | grep -v grep | awk '{print $1}')
fi

if [ -z "$PIDS" ]; then
  echo "No zookeeper server to stop"
  exit 1
else
  kill -s $SIGNAL $PIDS
fi

以下是 zookeeper-server-stop.sh 脚本的逐行解释:

bash 复制代码
SIGNAL=${SIGNAL:-TERM}
  • 作用 :设置信号变量 SIGNAL,默认值为 TERM(终止信号)。

  • 解释 :如果调用脚本时未通过环境变量指定 SIGNAL,则使用 TERM 作为默认信号。TERM 允许进程优雅退出。

bash 复制代码
OSNAME=$(uname -s)
  • 作用:获取当前操作系统的名称。

  • 解释 :通过 uname -s 命令获取系统类型(如 Linux、Darwin、OS/390 等),结果存入 OSNAME 变量。

bash 复制代码
if [[ "$OSNAME" == "OS/390" ]]; then
  • 作用 :检查当前操作系统是否为 IBM OS/390

  • 解释:OS/390 是 IBM 的大型机操作系统,需特殊处理。

bash 复制代码
    if [ -z $JOBNAME ]; then
        JOBNAME="ZKEESTRT"
    fi
  • 作用 :若 JOBNAME 变量未定义,则将其设为默认值 ZKEESTRT

  • 解释 :在 OS/390 中,进程可能以作业(Job)形式运行,ZKEESTRT 是 ZooKeeper 的默认作业名。

bash 复制代码
    PIDS=$(ps -A -o pid,jobname,comm | grep -i $JOBNAME | grep java | grep -v grep | awk '{print $1}')
  • 作用:获取 ZooKeeper 进程的 PID。

  • 解释

    1. ps -A -o pid,jobname,comm:列出所有进程的 PID、作业名和命令。

    2. grep -i $JOBNAME:过滤包含 JOBNAME(不区分大小写)的行。

    3. grep java:进一步筛选 Java 进程。

    4. grep -v grep:排除 grep 自身产生的行。

    5. awk '{print $1}':提取第一列(PID)。

bash 复制代码
elif [[ "$OSNAME" == "OS400" ]]; then
  • 作用 :检查操作系统是否为 IBM OS/400(AS/400)。

  • 解释:OS400 是 IBM 的中型机操作系统,需另一种处理方式。

bash 复制代码
    PIDS=$(ps -Af | grep java | grep -i QuorumPeerMain | grep -v grep | awk '{print $2}')
  • 作用:获取 ZooKeeper 进程的 PID。

  • 解释

    1. ps -Af:显示完整格式的所有进程。

    2. grep java:筛选 Java 进程。

    3. grep -i QuorumPeerMain:查找 ZooKeeper 的主类 QuorumPeerMain(集群模式入口类)。

    4. awk '{print $2}':提取第二列(PID),因为 ps -f 的 PID 列在第二位。

bash 复制代码
else
  • 作用:处理其他类 Unix 系统(如 Linux、macOS)。
bash 复制代码
    PIDS=$(ps ax | grep java | grep -i QuorumPeerMain | grep -v grep | awk '{print $1}')
  • 作用:获取 ZooKeeper 进程的 PID。

  • 解释

    1. ps ax:显示所有进程(包括其他用户的进程)。

    2. grep java:筛选 Java 进程。

    3. grep -i QuorumPeerMain:查找 ZooKeeper 主类。

    4. awk '{print $1}':提取第一列(PID)。

bash 复制代码
if [ -z "$PIDS" ]; then
  echo "No zookeeper server to stop"
  exit 1
  • 作用:检查是否找到 ZooKeeper 进程。

  • 解释 :若 PIDS 为空,输出提示信息并退出(状态码 1 表示错误)。

bash 复制代码
else
  kill -s $SIGNAL $PIDS
fi
  • 作用:向 ZooKeeper 进程发送信号。

  • 解释 :使用 kill 命令发送 SIGNAL(默认为 TERM)到所有找到的 PID,终止进程。

相关推荐
半新半旧3 小时前
Redis集群和 zookeeper 实现分布式锁的优势和劣势
redis·分布式·zookeeper
Code季风1 天前
深入理解微服务中的服务注册与发现(Consul)
java·运维·微服务·zookeeper·架构·go·consul
武子康2 天前
大数据-31 ZooKeeper 内部原理 Leader选举 ZAB协议
大数据·后端·zookeeper
阿波罗.20123 天前
Zookeeper 客户端 .net访问框架 ZookeeperNetEx项目开发编译
分布式·zookeeper
武子康3 天前
大数据-30 ZooKeeper Java-API 监听节点 创建、删除节点
大数据·后端·zookeeper
小葛呀13 天前
互联网大数据求职面试:从Zookeeper到Flink的技术探讨
大数据·redis·zookeeper·面试·flink·互联网·yarn
小白上线*^_^*14 天前
Kafka与Zookeeper在linux上的下载记录
zookeeper·kafka·linux上的下载与安装
longxibo14 天前
ZooKeeper 3.9.2 集群安装指南
大数据·分布式·zookeeper·debian
dessler15 天前
ZooKeeper-备份(Backup)
linux·运维·zookeeper
dessler15 天前
ZooKeeper-监控(Monitor)
linux·运维·zookeeper