以下脚本生产上可直接使用
#!/bin/bash
source /etc/profile
# 应用存放地址
APP_HOME=/data/app/$1
PORT=$2
# 应用名称jarname:
APP_NAME=$1
# Shell Info
# 使用说明,用来提示输入参数
usage() {
echo "Usage: sh boot [APP_NAME].jar [PORT] [start|stop|restart|status]"
exit 1
}
# 检查程序是否在运行
is_exist(){
# 获取PID
PID=$(ps -ef |grep ${APP_NAME} |grep ${PORT} | grep -v $0 |grep -v grep |awk '{print $2}')
if [ -z "${PID}" ]; then
# 如果进程不存在返回1
return 1
else
# 进程存在返回0
return 0
fi
}
# 定义启动程序函数
start(){
is_exist
if [ $? -eq "0" ]; then
echo "${APP_NAME} is already running, PID=${PID}"
else
nohup java -javaagent:/data/skywalking-agent/skywalking-agent.jar=agent.service_name=yecai_uat::${APP_NAME}_uat -server -Xms512m -Xmx512m -Xmn128m -XX:MetaspaceSize=64m -XX:MaxMetaspaceSize=512m -XX:SurvivorRatio=6 -XX:+UseConcMarkSweepGC -XX:+CMSParallelRemarkEnabled -XX:+UseCMSInitiatingOccupancyOnly -XX:CMSInitiatingOccupancyFraction=80 -XX:+ScavengeBeforeFullGC -XX:+CMSScavengeBeforeRemark -XX:+PrintGCDateStamps -verbose:gc -XX:+PrintGCDetails -Xloggc:gc.log -XX:+UseGCLogFileRotation -XX:NumberOfGCLogFiles=10 -XX:GCLogFileSize=100M -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=dump.hprof -jar ${APP_HOME}/${APP_NAME}.jar --server.port=${PORT} --spring.profiles.active=uat > /dev/null 2>&1 &
PID=$(echo $!)
echo "${APP_NAME} start success, PID=$!"
fi
}
# 停止进程函数
stop(){
# 使用kill -15优雅判断进程是否停止
num=0
while true
do
if [ $num -gt 30 ];then
sudo kill -9 ${PID}
echo "${APP_NAME} process stop, PID=${PID}"
break
fi
let num+=1
is_exist
if [ $? -eq "0" ]; then
sudo kill -15 ${PID}
echo "${APP_NAME} process is stoping, PID=${PID}"
sleep 1
else
echo "There is not the process of ${APP_NAME}"
break
fi
done
}
# 重启进程函数
restart(){
stop
start
}
# 查看进程状态
status(){
is_exist
if [ $? -eq "0" ]; then
echo "${APP_NAME} is running, PID=${PID}"
else
echo "There is not the process of ${APP_NAME}"
fi
}
case $3 in
"start")
start
;;
"stop")
stop
;;
"restart")
restart
;;
"status")
status
;;
*)
usage
;;
esac
exit 0