Springboot如何打包部署项目
jar包方式打包1、pom文件引入插件boot使用这个插件可以将项目打包成一个可运行的jar,无需在目标服务器安装tomcat等spring-boot-maven-plugin项目存在于spring-boot-tools 目录中spring-boot-maven-plugin默认 有5 个goals;在打包的时候默认使用的是repackage。
一、jar包方式打包
1、pom文件引入插件
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
boot使用这个插件可以将项目打包成一个可运行的jar,无需在目标服务器安装tomcat等
spring-boot-maven-plugin项目存在于spring-boot-tools 目录中spring-boot-maven-plugin默认 有5 个goals; repackage、 run、start、stop、 build-info
在打包的时候默认使用的是repackage。spring-boot-maven-plugin的repackage能够将mvn package生成的软件包,再次打包为可执行的软件包,并将mvn package生成的软件包重命名为*original。
这就为什么当执行maven clean package时,spring-boot-maven-plugin会在target目录下生成两个jar文件
其中我们可以将 springxxx-0.0.1-SNAPSHOTjar.original文件的后缀original去掉,生成的新jar包便是包含业务代码的包(普通的jar包)。
另外的spring-xxx-0.0.1-SNAPSHOTjar包则是在Spring Boot中通过jar -jar启动的包,它包含了应用的依赖,以及spring boot相关class。
2、idea中快速打包
当然打包之前记得选择自己生产环境配置文件
3、java –jar运行项目
我们打开刚才打包之后的所在的位置,确实有一个jar包
在当前文件路径直接使用cmd通过java –jar运行项目
4、访问项目
5、发布到服务器
发布之前服务器需要已经安装了jdk环境,数据库(项目数据库服务器如果是本服务器)
通过类似xshell等上传文件将上面的jar文件上传到服务器某个文件夹下,在当前路径下运行下面命令即可在后台启动项目,其中hellword-0.0.1-SNAPSHOT.jar是我的项目
nohup java -jar hellword-0.0.1-SNAPSHOT.jar > hellword-0.0.1-SNAPSHOT.log 2>&1 &
补充:其他相关命令
nohup java -jar xxx.jar &
这样执行后,nohup会把执行结果中的日志输出到当前文件夹下面的nohup.out文件中,通常情况下我们使用以上命令即可。 也可手动指定一个参数来规定日志文件的输出地点
nohup java -jar xxx.jar > catalina.out 2>&1 &
如果不需要输出日志,可以使用如下命令
nohup java -jar xxx.jar >/dev/null &
为了方便管理,我们还可以通过Shell来编写一些用于启动应用的脚本,比如关闭应用的脚本:stop.sh
#!/bin/bash
PID=$(ps -ef | grep yourapp.jar | grep -v grep | awk '{ print $2 }')
if [ -z "$PID" ]
then
echo Application is already stopped
else
echo kill $PID
kill $PID
fi
启动应用的脚本:start.sh
#!/bin/bash
nohup java -jar yourapp.jar --server.port=8888 &
整合了关闭和启动的脚本:run.sh,由于会先执行关闭应用,然后再启动应用,这样不会引起端口冲突等问题,适合在持续集成系统中进行反复调用。
#!/bin/bash
echo stop application
source stop.sh
echo start application
source start.sh
在Spring Boot的Maven插件中,还提供了构建完整可执行程序的功能,什么意思呢?就是说,我们可以不用java -jar,而是直接运行jar来执行程序。这样我们就可以方便的将其创建成系统服务在后台运行了。主要步骤如下:在pom.xml中添加Spring Boot的插件,并注意设置executable配置
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<executable>true</executable>
</configuration>
</plugin>
</plugins>
</build>
在完成上述配置后,使用mvn install进行打包,构建一个可执行的jar包,创建软连接到/etc/init.d/目录下
sudo ln -s /var/yourapp/yourapp.jar /etc/init.d/yourapp
在完成软连接创建之后,我们就可以通过如下命令对yourapp.jar应用来控制启动、停止、重启操作了
/etc/init.d/yourapp start|stop|restart
二、war方式打包
传统的部署方式:将项目打成war包,放入tomcat 的webapps目录下面,启动tomcat,即可访问
1、修改pom
<packaging>jar</packaging>
修改为
<packaging>war</packaging>
2、pom文件添加如下依赖
<!--添加servlet-api的依赖,用来打war包
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<scope>provided</scope>
</dependency>
3、排除springboot内置tomcat的干扰
4、启动类改造
原有的启动类都是基于jar的启动设置的,现在基于war的方式,需要我们改造下启动类
如果是war包发布,需要增加SpringBootServletinitializer子类,并重写其configure方法、或者将main函数所在的类继承SpringBootServletlnitializer,并重写configure方法
改造前
@SpringBootApplication
public class SpringboottestApplication {
public static void main(String[] args) {
SpringApplication.run(SpringboottestApplication.class, args);
}
}
改造后
@SpringBootApplication
public class SpringboottestApplication extends SpringBootServletInitializer {
public static void main(String[] args) {
SpringApplication.run(SpringboottestApplication.class, args);
}
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) {
return builder.sources(SpringboottestApplication.class);
}
}
当然spring-boot-maven-plugin仍然需要的
然后执行mvn clean 和mvn package即可打包war,将项目打成war包,放入tomcat 的webapps目录下面,启动tomcat,即可访问
开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!
更多推荐
所有评论(0)