SpringBoot 项目部署到服务器的两种方式

前言:目前,前后端分离的架构已成主流,而使用SpringBoot构建Web应用是非常快速的,项目发布到服务器上的时候,只需要打成一个jar包,然后通过命令 : java -jar jar包名称即可启动服务了。

一、jar包(官方推荐)

SpringBoot项目默认打包成jar包

jar包方式启动,也就是使用SpringBoot内置的tomcat运行。服务器上面只要你配置了jdk1.8及以上就ok,不需要外置tomcat。

1、SpringBoot将项目打包成jar包

a.首先在pom.xml文件中导入Springboot的maven依赖

<!--将应用打包成一个可以执行的jar包-->

    <build>

        <plugins>

            <plugin>

                <groupId>org.springframework.boot</groupId>

                <artifactId>spring-boot-maven-plugin</artifactId>

            </plugin>

        </plugins>

    </build>

b.package一下

c.package完成以后,target中会生成一个.jar包;

d.将jar包放到Linux服务器任意目录,执行下面的命令即可启动项目服务

$ nohup java -jar test.jar >temp.txt &

//这种方法会把日志文件输入到你指定的文件中,没有则会自动创建。进程会在后台运行。

2、Linux运行jar包与停止命令
a、执行jar包的命令和在windows操作系统上是一样的,都是java -jar xxxx.jar。
b、后台运行,nohup 意思是不挂断运行命令,当账户退出或终端关闭时,程序仍然运行

当用 nohup 命令执行作业时,缺省情况下该作业的所有输出被重定向到nohup.out的文件中,除非另外指定了输出文件。

nohup java -jar shareniu.jar

c、如果想杀掉运行中的jar程序,查看进程命令为:

ps aux|grep getCimiss-surf.jar

将会看到此jar的进程信息

data 5796 0.0 0.0 112656 996 pts/1 S+ 09:11 0:00 grep --color=auto getCimiss-surf.jar data 30768 6.3 0.4 35468508 576800 ? Sl 09:09 0:08 java -jar getCimiss-surf.jar

其中30768则为此jar的pid,杀掉命令为

kill -9 30768

ps:

Linux jar包运行命令详细说明,请查看这篇博客:Linux后台运行Jar方法

为了方便也可以写shell脚本,请查看这篇博客:后台启动和关闭jar的shell脚本

二、war包

传统的部署方式:将项目打成war包,放入tomcat 的webapps目录下面,启动tomcat,即可访问。

SpringBoot项目改造打包成war的流程

1、pom.xml配置修改

<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>

这个依赖主要是用于在和jsp进行整合的使用,可酌情添加

3、排除springboot内置的tomcat干扰

 <!--最终打成war包,排除内置的tomcat-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-tomcat</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

4、改造启动类

如果是war包发布,需要增加SpringBootServletInitializer子类,并重写其configure方法,或者将main函数所在的类继承SpringBootServletInitializer子类,并重写configure方法

当时打包为war时上传到tomcat服务器中访问项目始终报404错就是忽略了这个步骤!!!

改造之前:

@SpringBootApplication
public class MainApp {

    public static void main(String[] args) {
        SpringApplication.run(MainApp.class,args);
    }
}

改造之后:

@SpringBootApplication
public class MainApp extends SpringBootServletInitializer {

    public static void main(String[] args) {
        SpringApplication.run(MainApp.class,args);
    }
  
    @Override
    protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) {

        // 注意这里要指向原先用main方法执行的Application启动类
        return builder.sources(MainApp.class);
    }
}

这种改造方式也是官方比较推荐的方法

5、pom文件中不要忘了maven编译插件

 <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

6、在IDEA中使用mvn clean命令清除旧的包,并使用mvn package生成新的war包

执行完毕后,可以看到war包已经生成了,默认是在target目录下,位置可以在pom文件中进行配置:

7、使用外部Tomcat运行该 war 文件,有两种方式。第一种把 war 文件直接丢到 tomcat的webapps目录,启动tomcat;第二种使用tomcat - conf - server.xml配置,使用target目录中war包解压的文件夹为项目地址进行部署

<Service name="testWar">  
  <Connector port="8088"    maxHttpHeaderSize="8192"  maxThreads="150" minSpareThreads="25" maxSpareThreads="75" enableLookups="true" redirectPort="8443" acceptCount="100" connectionTimeout="20000" disableUploadTimeout="true"  URIEncoding="utf-8"/>   
  <Engine name="hnswzy" defaultHost="localhost">
     <Realm className="org.apache.catalina.realm.UserDatabaseRealm" resourceName="UserDatabase"/>
     <Host name="localhost" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false">
         <Context path="" reloadable="true" docBase="D:\project\springboot\war\target\war-0.0.1">
         </Context>
     </Host>
  </Engine>
</Service>

注意事项:

将项目打成war包,部署到外部的tomcat中,这个时候,不能直接访问spring boot 项目中配置文件配置的端口。application.yml中配置的server.port配置的是spring boot内置的tomcat的端口号, 打成war包部署在独立的tomcat上之后, 你配置的server.port是不起作用的。一定要注意这一点!!

其实我们从tomcat的启动界面,已经可以看出,是启动的哪个端口:

很明显,日志告诉我们,我们应该访问8080端口。

三、jar包和war包方式对比

1.SpringBoot项目打包时能打成 jar 与 war包,对比两种打包方式,jar更加简单方便,使用 java -jar xx.jar 就可以启动。所以打成 jar 包的最多。

而 war包可以部署到tomcat的 webapps 中,随Tomcat的启动而启动。具体使用哪种方式,应视应用场景而定。

2、打jar包时不会把src/main/webapp 下的内容打到jar包里 (你认为的打到jar包里面,路径是不行的会报404)

     打war包时会把src/main/webapp 下的内容打到war包里

3.打成什么文件包进行部署与项目业务有关,就像提供 restful API 服务的项目需要打包成 jar文件,用命令运行很方便。。。而有大量css、js、html,且需要经常改动的项目,打成 war 包去运行比较方便,因为改动静态资源可以直接覆盖,很快看到改动后的效果,这是 jar 包不能比的(举个‘栗’子:项目打成 jar 包运行,一段时间后,前端要对其中某几个页面样式进行改动,使其更美观,那么改动几个css、html后,需要重新打成一个新的 jar 包,上传服务器并运行,这种改动频繁时很不友好,文件大时上传服务器很耗时,那么 war包就能免去这种烦恼,只要覆盖几个css与html即可)


参考链接:

SpringBoot的jar包运行及日志输出

SpringBoot War包形式部署到外部Tomcat

Spring Boot打war包部署遇到的坑

  • 41
    点赞
  • 244
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
部署 WebSocket 服务器通常有两种方法: 1. 将 WebSocket 服务器直接部署在应用服务器中,如 Tomcat、Jetty 等,这种方式需要在应用服务器中添加 WebSocket 支持的插件或者模块。 2. 使用独立的 WebSocket 服务器,如 Netty、Undertow 等,这种方式需要将 WebSocket 服务器独立部署,并将 WebSocket 服务器和应用服务器进行集成。 以下是基于 Spring Boot 的 WebSocket 服务器部署步骤: 1. 添加 Spring Boot WebSocket 依赖: ``` <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-websocket</artifactId> </dependency> ``` 2. 创建 WebSocket 配置类,并添加 @EnableWebSocket 注解: ``` @Configuration @EnableWebSocket public class WebSocketConfig implements WebSocketConfigurer { @Override public void registerWebSocketHandlers(WebSocketHandlerRegistry registry) { registry.addHandler(new MyWebSocketHandler(), "/websocket").setAllowedOrigins("*"); } } ``` 3. 创建 WebSocket 处理器: ``` public class MyWebSocketHandler extends TextWebSocketHandler { @Override public void handleTextMessage(WebSocketSession session, TextMessage message) throws Exception { String payload = message.getPayload(); session.sendMessage(new TextMessage("Received: " + payload)); } } ``` 4. 在应用程序中注入 WebSocket 处理器: ``` @Controller public class WebSocketController { @Autowired private MyWebSocketHandler webSocketHandler; @GetMapping("/websocket") public String websocket() { return "websocket"; } } ``` 5. 编写前端页面,使用 WebSocket 进行连接: ``` var socket = new WebSocket('ws://localhost:8080/websocket'); socket.onmessage = function(event) { console.log('Received: ' + event.data); } socket.send('Hello, Server!'); ``` 6. 运行应用程序,并访问 http://localhost:8080/websocket 页面,打开浏览器控制台查看 WebSocket 连接状态。 以上是基于 Spring Boot 的 WebSocket 服务器部署步骤,具体实现可以根据自己的需求进行调整。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Java架构何哥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值