最近开发完一个springboot项目,打包成jar包之后要部署到Linux服务器上面运行,我用的nohup java -jar 命令,但是代码更新之后重新部署的时候覆盖原来的项目,又要手动运行

ps -ef|grep jar包名 去查找进程,然后kill -9 去kill进程,有时候nohup进程老是kill不掉,只能多试几次,烦不胜烦。后来专门花时间研究了一下脚本和本地window上传文件到linux服务器的命令,整合了一个启动脚本,顿时项目部署变得无比简单,一分钟内在线上的代码就可以更新了。下面是具体步骤:

1、在idea上写一个maven 打包命令 : clean package -DskipTests=true                 (打包跳过测试,打包更快)

jar包提交到hadoop集群 jar部署到linux_jar包提交到hadoop集群

 

2、运行 package 打包,会在项目根路径target下面生成jar包

jar包提交到hadoop集群 jar部署到linux_上传_02

3、接下来我们要把本地项目jar包上传到Linux服务器上面,怎么快速上传呢?主要有两种方式:

一、直接用鼠标拉取jar包到Xftp文件夹下,如下图

jar包提交到hadoop集群 jar部署到linux_上传_03

 

二、直接在用命令上传,比较推荐这种,不用再去打开target文件夹了,也不用再拉取了

我们先安装一个文件上传和下载的工具软件包 :yum -y install lrzsz    

lrzsz包安装完成后包括上传rz、下载sz命令

然后我们可以 输入命令 rz -y     ,(rz 代表上传, -y 可以强制覆盖文件),会弹出一个文件选择框,我们可以鼠标选择jar包位置,确定即可,下次再上传的时候会直接弹出jar包窗口,当然下次用的时候也可以用tab键光标跳转选择,这就完全不用鼠标了,注意下面发送文件到ASCII不要打钩

jar包提交到hadoop集群 jar部署到linux_上传_04

 

4、最后就是重头戏了,项目重启的脚本,写个start.sh 的脚本,注意脚本和jar包同级目录 , 如下:

 

#!/bin/sh
RESOURCE_NAME=resource-0.0.1-SNAPSHOT.jar
 
tpid=`ps -ef|grep $RESOURCE_NAME|grep -v grep|grep -v kill|awk '{print $2}'`
if [ ${tpid} ]; then
echo 'Stop Process...'
kill -15 $tpid
fi
sleep 5
tpid=`ps -ef|grep $RESOURCE_NAME|grep -v grep|grep -v kill|awk '{print $2}'`
if [ ${tpid} ]; then
echo 'Kill Process!'
kill -9 $tpid
else
echo 'Stop Success!'
fi
 
tpid=`ps -ef|grep $RESOURCE_NAME|grep -v grep|grep -v kill|awk '{print $2}'`
if [ ${tpid} ]; then
    echo 'App is running.'
else
    echo 'App is NOT running.'
fi
 
rm -f tpid
nohup java -jar ./$RESOURCE_NAME --spring.profiles.active=test &
echo $! > tpid
echo Start Success!

  

5、脚本运行   

cd /home (我是把jar包和脚本放在home下面)

chmod +x start.sh (第一次运行的时候获取一下超级管理员权限)

然后以后每次运行直接

./start.sh 即可

 

拷贝脚本的时候运行的时候如果报错,应该是文件格式转换的问题

bash: ./a.sh: /bin/bash^M: bad interpreter: No such file or directory

 

可以  yum -y install dos2unix  

然后 dos2unix start.sh 

重新运行脚本