Hive Metastore和Hiveserver2启停脚本

一、Hive Metastore和Hiveserver2启停脚本

shell 复制代码
#!/bin/bash

HIVE_LOG_DIR=$HIVE_HOME/logs
if [ ! -d $HIVE_LOG_DIR ]
then
	mkdir -p $HIVE_LOG_DIR
fi

#检查进程是否运行正常,参数1为进程名,参数2为进程端口
function check_process()
{
    pid=$(ps -ef 2>/dev/null | grep -v grep | grep -i $1 | awk '{print $2}')
    ppid=$(netstat -nltp 2>/dev/null | grep $2 | awk '{print $7}' | cut -d '/' -f 1)
    echo $pid
    [[ "$pid" =~ "$ppid" ]] && [ "$ppid" ] && return 0 || return 1
}

function hive_start()
{
    metapid=$(check_process HiveMetastore 9083)
    cmd="nohup hive --service metastore >$HIVE_LOG_DIR/metastore.log 2>&1 &"
    [ -z "$metapid" ] && eval $cmd || echo "Metastroe服务已启动"
    server2pid=$(check_process HiveServer2 10000)
    cmd="nohup hive --service hiveserver2 >$HIVE_LOG_DIR/hiveServer2.log 2>&1 &"
    [ -z "$server2pid" ] && eval $cmd || echo "HiveServer2服务已启动"
}

function hive_stop()
{
metapid=$(check_process HiveMetastore 9083)
    [ "$metapid" ] && kill $metapid || echo "Metastore服务未启动"
    server2pid=$(check_process HiveServer2 10000)
    [ "$server2pid" ] && kill $server2pid || echo "HiveServer2服务未启动"
}

case $1 in
"start")
    hive_start
    ;;
"stop")
    hive_stop
    ;;
"restart")
    hive_stop
    sleep 2
    hive_start
    ;;
"status")
    check_process HiveMetastore 9083 >/dev/null && echo "Metastore服务运行正常" || echo "Metastore服务运行异常"
    check_process HiveServer2 10000 >/dev/null && echo "HiveServer2服务运行正常" || echo "HiveServer2服务运行异常"
    ;;
*)
    echo Invalid Args!
    echo 'Usage: '$(basename $0)' start|stop|restart|status'
    ;;
esac

二、脚本解读

这段shell代码是一个Hive服务管理脚本,用于启动和管理Hive Metastore和Hiveserver2服务。

包括:

  • 检查
  • 启动
  • 停止
  • 重启

脚本结构解析

1. 日志目录设置

bash 复制代码
HIVE_LOG_DIR=$HIVE_HOME/logs
if [ ! -d $HIVE_LOG_DIR ]
then
	mkdir -p $HIVE_LOG_DIR
fi

这部分代码确保Hive日志目录存在,如果不存在则创建该目录。

2. 进程检查函数

bash 复制代码
function check_process()
{
    pid=$(ps -ef 2>/dev/null | grep -v grep | grep -i $1 | awk '{print $2}')
    ppid=$(netstat -nltp 2>/dev/null | grep $2 | awk '{print $7}' | cut -d '/' -f 1)
    echo $pid
    [[ "$pid" =~ "$ppid" ]] && [ "$ppid" ] && return 0 || return 1
}

这个函数用于检查指定服务进程是否正在运行:

  • 参数1:进程名
  • 参数2:进程端口
  • 通过ps命令查找进程ID,通过netstat查找监听端口的进程ID
  • 比较两个ID判断服务是否正常运行
  • 通过进程名(1)和端口(2)双重验证服务状态
  • 若进程ID和端口对应的进程ID匹配,则返回0(成功),否则返回1(失败)

3. 启动函数

bash 复制代码
function hive_start()
{
    metapid=$(check_process HiveMetastore 9083)
    cmd="nohup hive --service metastore >$HIVE_LOG_DIR/metastore.log 2>&1 &"
    [ -z "$metapid" ] && eval $cmd || echo "Metastroe服务已启动"
    server2pid=$(check_process HiveServer2 10000)
    cmd="nohup hive --service hiveserver2 >$HIVE_LOG_DIR/hiveServer2.log 2>&1 &"
    [ -z "$server2pid" ] && eval $cmd || echo "HiveServer2服务已启动"
}

该函数用于启动Hive服务:

  • 首先检查Metastore服务(端口9083)是否已运行
  • 如果未运行,则执行启动命令,否则提示服务已启动
  • 同样处理HiveServer2服务(端口10000)
  • 通过短路逻辑确保只启动未运行的服务

4. 停止函数

bash 复制代码
function hive_stop()
{
metapid=$(check_process HiveMetastore 9083)
    [ "$metapid" ] && kill $metapid || echo "Metastore服务未启动"
    server2pid=$(check_process HiveServer2 10000)
    [ "$server2pid" ] && kill $server2pid || echo "HiveServer2服务未启动"
}

该函数用于停止Hive服务:

  • 检查服务进程是否存在
  • 存在则使用kill命令终止进程,否则提示服务未启动

5. 主程序逻辑

bash 复制代码
case $1 in
"start")
    hive_start
    ;;
"stop")
    hive_stop
    ;;
"restart")
    hive_stop
    sleep 2
    hive_start
    ;;
"status")
    check_process HiveMetastore 9083 >/dev/null && echo "Metastore服务运行正常" || echo "Metastore服务运行异常"
    check_process HiveServer2 10000 >/dev/null && echo "HiveServer2服务运行正常" || echo "HiveServer2服务运行异常"
    ;;
*)
    echo Invalid Args!
    echo 'Usage: '$(basename $0)' start|stop|restart|status'
    ;;
esac

使用case语句根据传入参数执行不同操作:

  • start:启动服务
  • stop:停止服务
  • restart:重启服务
  • status:检查服务状态
  • 其他参数显示使用帮助,提供友好的参数错误提示

使用方法

将脚本保存为hiveservices.sh,然后可以通过以下命令操作:

bash 复制代码
# 启动服务
./hiveservices.sh start

# 停止服务
./hiveservices.sh stop

# 重启服务
./hiveservices.sh restart

# 检查状态
./hiveservices.sh status

该脚本实现了Hive服务的规范化管理,避免了手动执行命令的繁琐,同时通过日志记录和状态检查提高了服务管理的可靠性,综合使用了函数定义、条件判断、进程管理。