Hive Metastore和Hiveserver2启停脚本
一、Hive Metastore和Hiveserver2启停脚本
#!/bin/bashHIVE_LOG_DIR=$HIVE_HOME/logs
if [ ! -d $HIVE_LOG_DIR ]
thenmkdir -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_stopsleep 2hive_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. 日志目录设置
HIVE_LOG_DIR=$HIVE_HOME/logs
if [ ! -d $HIVE_LOG_DIR ]
thenmkdir -p $HIVE_LOG_DIR
fi
这部分代码确保Hive日志目录存在,如果不存在则创建该目录。
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
}
这个函数用于检查指定服务进程是否正在运行:
- 参数1:进程名
- 参数2:进程端口
- 通过ps命令查找进程ID,通过netstat查找监听端口的进程ID
- 比较两个ID判断服务是否正常运行
- 通过进程名($1)和端口($2)双重验证服务状态
- 若进程ID和端口对应的进程ID匹配,则返回0(成功),否则返回1(失败)
3. 启动函数
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. 停止函数
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. 主程序逻辑
case $1 in
"start")hive_start;;
"stop")hive_stop;;
"restart")hive_stopsleep 2hive_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
,然后可以通过以下命令操作:
# 启动服务
./hiveservices.sh start# 停止服务
./hiveservices.sh stop# 重启服务
./hiveservices.sh restart# 检查状态
./hiveservices.sh status
该脚本实现了Hive服务的规范化管理,避免了手动执行命令的繁琐,同时通过日志记录和状态检查提高了服务管理的可靠性,综合使用了函数定义、条件判断、进程管理。