引言
Springboot
项目部署到服务器常见的方式有打成war
包部署Tomcat
容器或者打成jar
包直接使用内置容器运行,我之前也都打成war
包部署到tomcat
,这种方式虽然没问题 但是后期维护比较麻烦。从官方的说明中打成jar
部署是最好的方式。
本文包含以下内容:
- Linux服务器上安装JDK
- Springboot项目打成Jar包
- Nginx部署项目分发
一、Linux服务器上安装JDK
1、Java JDK是区分32位和64位的,所以在安装JDK
之前需要首先判断一下我们Linux
是哪一个版本的,在Xshell 6
中通过执行以下命令:
uname –a
显示结果中如果有x86_64
就是64
位的,没有就是32
位的,可以看出我这里的版本是64位的。
2、从Oracle
官网上下载Linux x64
版本的jdk-8u45-linux-x64.rpm
文件,如下图所示:
拉到最下面
3、使用 xftp
将JDK
上传到Linux
服务器
切换到/usr/local
目录下,在此目录下新建文件夹jdk_8u45
,用于存放jdk
的安装包,命令如下
cd /usr/local
mkdir jdk_8u45
使用远程连接工具 Xftp
连接服务器,然后使用如下命令,上传到/usr/local/jdk_8u45
目录下
上传完后的文件如下,文件只有读写
权限,没有执行
权限
使用如下命令授权,如果文件已经有了执行权限,此步骤可省略
chmod 775 jdk-8U45-linux-x64.rpm
再次ll
查看
4、安装JDK
执行如下命令安装jdk
# rpm -ivh jdk-8u45-linux-x64.rpm
JDK安装成功后,默认存放在/usr/java
文件目录中
5、配置环境变量
使用 vim
或 vi
编辑器打开文件/etc/profile
# vim /etc/profile
# vi /etc/profile
在文件尾部添加如下内容,保存退出
export JAVA_HOME=/usr/java/jdk1.7.0_71
export PATH=$JAVA_HOME/bin:$PATH
export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tool.jar
此时,我们刚刚配置的环境变量并没有起效,输入如下命令,使用环境变量立即生效
# source /etc/profile
输入如下命令验证环境变量是否生效
# echo $PATH
输入如下命令查看jdk版本
# java -version
二、Springboot项目打成Jar包
1、在pom.xml
文件中添加
<packaging>jar</packaging>
2、在pom.xml
中添加新的插件
<build>
<finalName>sell</finalName>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<version>2.22.1</version>
<configuration>
<!-- 不指定单元测试 -->
<skipTests>true</skipTests>
</configuration>
</plugin>
</plugins>
</build>
3、使用IDEA编辑器
的Maven
插件进行打包
出现build success
即为打包完成
4、在项目中的target
目录下出现一个可执行的jar
文件
5、使用FTP
工具将jar包上传至root
目录下
此时Jar
包已打包完成并上传至Linux服务器上。
Springboot默认是/
,这样直接通过http://ip:port/就可以访问到index
页面,但是我们要通过nginx
配置多项目的话就要给每一个项目单独指定context-path
。
记住:
Springboot
项目得在配置文件application.properties
中配置 (不然项目无法被正确访问)
server.context-path: /sell
三、Nginx部署项目分发
1、在Linux服务器上进入Nginx配置目录:
cd /usr/local/nginx/conf/
这里给出nginx.conf
的配置
server {
listen 80;
server_name localhost;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
root html;
index index.html index.htm index.php;
}
#将/wvv请求转发给http://127.0.0.1:1992/wvv处理
location /wvv {
proxy_set_header Host $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://127.0.0.1:1992/wvv;
}
}
同理可应用在HTTPS
上的分发策略
注意上面的端口号一定要跟程序中application.properties
保持一致。
如果是部署多个SpringBoot
项目,则可以多次添加如下配置,只要修改成不一样的路径即可
#将/wvv请求转发给http://127.0.0.1:1991/project处理
location /project{
proxy_set_header Host $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://127.0.0.1:1991/project;
}
配置完成后,重启nginx
。
nginx -s reload
接下来直接使用nohup
命令进行后台启动应用jar
包,但是要在jar包所在当前目录进行nohup启动。(注意)
nohup java -jar sell.jar &
其实到这里本文教程算是告一段落了,但是重新启动项目还是比较繁琐的。
四、编辑脚本以实现自动化
先来说一下,正常的重启方式吧。
两种方式进行进程号的查询
ps -ef|grep jar包名
或者
netstat -nap|grep jar包启动端口号,如8080
然后去kill
进程
kill -9 刚刚查询到的进程号
然后重新上传新的要覆盖的Jar包,进行nohup
命令后台启动。
整合了一个启动脚本,顿时项目部署变得无比简单。
下面是具体步骤:
1、项目重启的脚本,写个start.sh
的脚本,注意脚本和jar
包同级目录,主要是修改RESOURCE_NAME
这一项的Jar
包名称。
vi start.sh
#!/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!
2、chmod +x start.sh
(第一次运行的时候获取一下超级管理员权限)
然后以后每次运行直接
./start.sh
即可
五、多个Jar包应用同时部署
在服务器目录根据个人喜好新建一个文件夹,专门用来存放spring-boot
打包成的jar
和重启脚本,如下所示: