如果需要日志分割,有个取巧的办法,编辑计划任务,每日凌晨重启,便会生成每日日志
#!/bin/bash
#description: 启动重启server服务
#端口号,根据此端口号确定PID
PORT=8080
Server_name=EnergyGateway.jar
#启动命令所在目录
HOME='/home/server/server-jar'
#查询出监听了test.jar端口TCP协议的程序
pid=$(ps -ef | grep $Server_name | grep -v grep | awk '{print $2}')
start(){
echo "start running cloud-core ............... "
if [ -n "$pid" ]; then
echo "server already start,pid:$pid"
echo "pid:$pid test port:$PORT 服务已经在运行了,请停止后再 执行 sh run.sh start "
return 0
fi
#进入命令所在目录
cd $HOME
# 启动服务控制台日志输出到nohup.out文件中
nohup java -jar $Server_name >`date +%Y-%m-%d`.nohup.log 2>&1 &
echo "running success test port:$PORT"
echo "test port:$PORT 服务启动成功 ..... "
tail -f $HOME/$starttimenohup.out
}
stop(){
echo "stopping running cloud-core ............... "
if [ -z "$pid" ]; then
echo "not find program on port:$PORT"
echo "test port:$PORT 服务已经被关闭了请执行 sh run.sh start "
return 0
fi
#结束程序,使用讯号2,如果不行可以尝试讯号9强制结束
kill -9 $pid
rm -rf $pid
echo "kill program use signal 2,pid:$pid"
}
status(){
if [ -z "$pid" ]; then
echo "not find program on port:$PORT"
else
echo "program is running,pid:$pid"
fi
}
case $1 in
start)
start
;;
stop)
stop
;;
restart)
$0 stop
sleep 2
$0 start
;;
status)
status
;;
*)
echo $"Usage: $0 {start|stop|status}"
exit 0
esac
启动方式:
sh run.sh start
sh run.sh stop
sh run.sh restart
sh run.sh status
检测脚本格式
直接输入":",然后在":“之后输入"set ff”
如果显示fileformat=doc我们需要把格式改为unix,方法是输入":set ff=unix",也可以输入":set fileformat=unix"