特别说明,启动时候,没有特别指定日志,而是默认日志,如果生产的日志过大,将会影响脚本执行速度
案例参考,超详细备注 (Notpad++ 有颜色标注 更易读)
Windows请参考:https://www.zanglikun.com/5620.html
#!/bin/sh
# author name:zanglikun
# author QQ:740969606
# $0 是文件名
# $1 是第一个参数
# echo $0 start 是启动服务
# echo $0 stop 是停止服务
# echo $0 restart 是重启服务
# echo $0 status 是查看服务状态
# 指定JAR包文件夹,将来运行的时候,此文件需要与jar包同级
AppName=你的jar名字.jar
# JVM参数 可去https://docs.oracle.com/javase/8/docs/technotes/tools/unix/java.html 了解不知道的参数
JVM_OPTS="-Dname=$AppName -Duser.timezone=Asia/Shanghai -Xms512M -Xmx512M -XX:PermSize=256M -XX:MaxPermSize=512M -XX:+HeapDumpOnOutOfMemoryError -XX:+PrintGCDateStamps -XX:+PrintGCDetails -XX:NewRatio=1 -XX:SurvivorRatio=30 -XX:+UseParallelGC -XX:+UseParallelOldGC -Dspring.profiles.active=pro -Dserver.port=18083"
# -Dspring.profiles.active=pro 指的是激活application-pro.properties配置文件
# -Dserver.port=18083 可指定运行端口
# 此变量会获取到当前路径 等价于 Linux的pwd命令
APP_HOME=`pwd`
# 日志路径 一定要有此路经的文件夹,没有此路径的文件夹,将不会有日志文件:$AppName.log,记得创建logs文件夹。
LOG_PATH=$APP_HOME/logs/$AppName.log
# 获取第一个参数 如果为空,将会提示这个
if [ "$1" = "" ];
then
echo -e "\033[0;31m 未输入操作名 \033[0m \033[0;34m {start|stop|restart|status} \033[0m"
exit 1
fi
# 如果没有指定JAR包,将会提示这个
if [ "$AppName" = "" ];
then
echo -e "\033[0;31m 未输入应用名 \033[0m"
exit 1
fi
# start方法
function start()
{
# 获取PID,最后打印出结果$2 就是PID 注意,此处$2不是我们运行此脚本的第二个参数($0 不算做第一个参数)!
PID=`ps -ef |grep java|grep $AppName|grep -v grep|awk '{print $2}'`
if [ x"$PID" != x"" ]; then
echo "$AppName is running..."
else
# 不用手动创建日志
mkdir logs
nohup java -jar $JVM_OPTS $AppName > $LOG_PATH 2>&1 &
# 下面可以查看一下命令对不对
#echo "nohup java -jar $JVM_OPTS $AppName > $LOG_PATH 2>&1 &"
echo "Start $AppName success..."
fi
}
# stop方法
function stop()
{
echo "Stop $AppName"
PID=""
# 定制查询服务PID的方法
query(){
PID=`ps -ef |grep java|grep $AppName|grep -v grep|awk '{print $2}'`
}
# 第一次查询状态,更变PID
query
if [ x"$PID" != x"" ]; then
kill -TERM $PID
echo "$AppName (pid:$PID) exiting..."
while [ x"$PID" != x"" ]
do
# 间隔1秒执行后续代码
sleep 1
# 这是一个死循环,检查每一次PID,都会更变PID的最新结果,如果PID等于空了,就结束循环,输出结束
query
done
echo "$AppName exited."
else
echo "$AppName already stopped."
fi
}
# restart方法 注意方法内部的内容:调用了2个别的方法,所以从脚本加载从上倒下的顺序上,这2个被调用的方法,都要在此方法之前!
function restart()
{
# 先停止服务,然后等待2秒后,再次重启服务,不过2秒时间太短,建议久一点
stop
sleep 2
start
}
# status方法
function status()
{
# 获取PID
PID=`ps -ef |grep java|grep $AppName|grep -v grep|wc -l`
# 如果PID为0,代表服务器停止,不为0,就代表服务器正在运行
if [ $PID != 0 ];then
echo "$AppName is running..."
else
echo "$AppName is not running..."
fi
}
# 获取第一个参数,执行不同的方法!
case $1 in
start)
# 执行start方法
start
;;
stop)
# 执行stop方法
stop
;;
restart)
# 执行resrart方法
restart
;;
status)
# 执行status方法
status
;;
*)
# case的结束标志
esac
启动方式
步骤1:将你的jar包与你的.sh脚本放到同级目录
步骤2:修改上面的脚本的将 AppName 替换为Jar包名字
步骤3:在此目录下创建一个logs文件夹,如果不创建此文件夹,将不会有日志文件!
步骤4:用命令运行脚本
检查一下 文件编码格式:不能为Windows,因为换行符与Linux不一致导致的!切记!
# 启动你的服务
./你的文件名.sh start
# 停止你的服务
./你的文件名.sh stop
# 查看你的服务状态
./你的文件名.sh status
# 重启你的服务
./你的文件名.sh restart
演示
重启多个服务脚本,同时展示脚本总运行时间
# 说明 我有4个sh文件,同时运行,并追加参数restart!
starttime=$(date -d now +%s)
echo -e "\033[0;31m当前时间是:$(date "+%Y-%m-%d %H:%M:%S") 开始全部重启\033[0m"
echo
echo
./1login.sh restart;
echo
echo
./2room.sh restart;
echo
echo
./3friendcricle.sh restart;
echo
echo
./4pay.sh restart;
echo
echo
endtime=$(date -d now +%s)
echo
echo -e "\033[0;31m当前时间是:$(date "+%Y-%m-%d %H:%M:%S") 已经完全重启了!重启一共耗费了$(($endtime - $starttime))秒 \033[0m";
查看多个程序的状态
echo -e "\033[0;31m当前时间是:$(date "+%Y-%m-%d %H:%M:%S") 开始检测状态\033[0m"
./1login.sh status;
echo
./2room.sh status;
echo
./3friendcricle.sh status;
echo
./4pay.sh status;
echo -e "\033[0;31m当前时间是:$(date "+%Y-%m-%d %H:%M:%S") 已经检测状态完毕了! 请核实!\033[0m";
特殊说明:
上述文章均是作者实际操作后产出。烦请各位,请勿直接盗用!转载记得标注原文链接:www.zanglikun.com
第三方平台不会及时更新本文最新内容。如果发现本文资料不全,可访问本人的Java博客搜索:标题关键字。以获取最新全部资料 ❤
第三方平台不会及时更新本文最新内容。如果发现本文资料不全,可访问本人的Java博客搜索:标题关键字。以获取最新全部资料 ❤
评论(0)