一.创建启动jar的脚本
1.上传jar包到指定项目文件夹,cd进入项目文件夹,创建shell脚本
touch start.sh
2.使用vim start.sh编写start.sh脚本内容,粘贴完后esc=> :wq
#!/bin/bash
#配置项目所在目录,取当前脚本目录
BASE_DIR=$(cd `dirname $0`; pwd)
#BASE_DIR=/home/duoduo-back
#进入项目所在目录
cd $BASE_DIR
#创建heapdump目录,用来放Heap Dump信息
if [ ! -d heapdump ]; then
mkdir heapdump
echo "创建heapdump目录..."
else
echo "heapdump目录 OK..."
fi
#HeapDump信息目录
HEAP_DUMP_DIR=$BASE_DIR/heapdump
#创建log目录,用来放日志信息
if [ ! -d log ]; then
mkdir log
echo "创建log目录..."
else
echo "log目录 OK..."
fi
#GC日志
GC_LOG_FILE=$BASE_DIR/log/gc.log
#错误日志
ERROR_LOG_DIR=$BASE_DIR/log
#遍历当前文件夹,取.jar结尾的文件名作为 APP_NAME
for filename in $(ls)
do
if [[ $filename == *.jar ]]; then
APP_NAME=$filename
break
fi
done
#如果APP_NAME是空的
if [[ -z $APP_NAME ]]; then
echo "未找到应用,指令结束..."
exit
fi
echo "找到应用:" $APP_NAME
#查找该应用的pid
PID=`ps -ef | grep $APP_NAME | grep -v grep | grep -v restart | awk '{print$2}'`
#如果找到PID,就杀掉它
if [[ -n $PID ]]; then
kill -9 $PID
sleep 5
echo $APP_NAME "的pid为" $PID ",已将其杀死..."
fi
#重新后台启动应用
nohup java -Xmx1g -Xms1g -XX:+UseParallelGC -XX:+UseParallelOldGC -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+UseGCLogFileRotation -XX:GCLogFileSize=128M -XX:NumberOfGCLogFiles=1 -Xloggc:$GC_LOG_FILE -XX:HeapDumpPath=$HEAP_DUMP_DIR -jar $APP_NAME --spring.profiles.active=release >$ERROR_LOG_DIR/$(date +'%Y%m%d').log 2>&1 &
echo $APP_NAME "成功运行!!!"
#命令解释
#"nohup":不挂断地运行命令,退出帐户之后继续运行相应的进程
#"-Xmx1g": 设置JVM最大可用内存为1g
#"-Xms1g" : 设置JVM初始内存为1g,此值可以设置与-Xmx相同,以避免每次垃圾回收完成后JVM重新分配内存
#"-XX:+UseParallelGC" : 选择垃圾收集器为并行收集器
#"-XX:+UseParallelOldGC" :配置老年代垃圾收集器为并行收集
#"-XX:+PrintGCDetails" : 可以详细了解GC中的变化
#"-XX:+PrintGCTimeStamps" : 配合上面的PrintGCDetails,可以了解这些垃圾收集发生的时间,自JVM启动以后以秒计量
#"-XX:+UseGCLogFileRotation" : 启用GC日志文件的自动转储
#"-XX:GCLogFileSize=128M" : 控制GC日志文件的大小
#"-XX:NumberOfGCLogFiles=1" : GC日志文件的循环数目
#"-Xloggc:$GC_LOG_FILE ": 把gc日志信息记录到文件$BASE_DIR/log/gc.log
#"-XX:HeapDumpPath=$HEAP_DUMP_DIR" : 将Heap Dump信息保存到$BASE_DIR/heapdump
#"-jar $APP_NAME":运行自己的springboot项目.jar
#"--spring.profiles.active=release":我的jar包里打入了application-dev.yml和application-release.yml配置文件
#所以运行jar包时,指定一下使用哪个配置 --spring.profiles.active=release
#">$ERROR_LOG_DIR/$(date +'%Y%m%d').log":将日志文件输出到指定目录,已日期.log命名
#"2>&1":2就是标准错误,1是标准输出,即把标准错误和标准输出同时输出到指定的“日志文件名.log”文件中。
#"&":让应用后台运行
3.使shell脚本可执行
chmod +x start.sh
4.运行shell脚本,成功启动应用
./start.sh
二.设置开机自启动服务
1.创建自动启动/opt/script/autostart.sh脚本,并设置可执行权限
touch autostart.sh
chmod +x autostart.sh
2.将jar项目启动脚本/home/duoduo-back/start.sh放进autostart.sh去,以后其他项目都可以加在这里实现开机启动
/opt/script/autostart.sh
#!/bin/sh
#duoduo项目启动脚本
/home/duoduo-back/start.sh
3.通过systemd设置自启动服务
①进入/etc/systemd/system,创建自启动服务
vim autostart.service
②编写一下内容 ,将我们创建的/opt/script/autostart.sh放进去
[Unit]
Description = This will run at startup
[Service]
#这里写要启动的脚本,要有执行权限
ExecStart = /opt/script/autostart.sh
[Install]
WantedBy = multi-user.target
③给autostart.service执行权限
chmod +x autostart.service
④设置开机启动
systemctl enable autostart.service
⑤此时可以重启看是否会自动运行了
shutdown -r now