1 背景介绍
开发有个一个服务,正常启动服务的时候,日志级别是 INFO。
目前开发希望能够使用 systemctl 控制服务的时候,可以添加参数,实现启动的时候日志级别变成 DEBUG。
服务是一个 jar 包,进过分析需要使用两个 systemd 的服务配置文件,并分别指定不同的启动参数,或者指定不同的启动环境文件。
并且使用一个脚本实现,执行同一个脚本,通过传递不同的参数实现自动启动 参数指定的服务器启动方式,比如 info 级别的,或者是 debug 级别的。
还要考虑到传递参数不正确或者未传递参数的处理逻辑。
2 脚本内容
# 定义颜色
RED='\033[31m'
GREEN='\033[32m'
YELLOW='\033[33m'
BLUE='\033[34m'
RESET='\033[0m'
if [[ "$1" =~ start|stop|restart|status ]] && [ "$2" != "debug" ]
then
echo -e "${YELLOW}这将日志以 info 级别管理服务${RESET}"
echo -e "${RED}并停止 debug 日志级别的服务${RESET}"
echo
echo "如果希望日志级别为 debug 级别方式管理服务"
echo "使用:"
echo "sh $0 start|stop|restart|status debug"
echo
systemctl stop debug-project
serverName="spms-project"
elif [[ "$1" =~ start|stop|restart|status ]] && [ "$2" == "debug" ]
then
echo -e "${YELLOW}这将日志以 debug 级别管理服务${RESET}"
echo -e "${RED}并停止 info 日志级别的服务${RESET}"
echo
systemctl stop spms-project
serverName="debug-project"
fi
case $1 in
start)
echo 启动服务 $serverName
systemctl start $serverName
;;
restart)
echo 重启服务 $serverName
systemctl restart $serverName
;;
stop)
echo 停止服务 $serverName
systemctl stop $serverName
;;
status)
echo 当前服务状态
systemctl stop $serverName
;;
*)
echo "需要至少传一个参数:"
echo " start 启动服务; restart 重启服务"
echo " stop 停止服务; status 查看服务状态"
echo "示例1: 启动服务,并且日志级别为 info"
echo -e "${GREEN}sh $0 start${RESET}"
echo
echo "示例2: 启动服务,并且日志级别为 debug"
echo -e "${GREEN}sh $0 start debug${RESET}"
;;
esac