框架 | SpringBoot项目发布部署外部tomcat服务器步骤

如何发布Sping Boot项目?

新建好SpringBoot项目之后,SIT测试如果没问题,则下一步肯定要进行UAT测试。

那么如何将SpringBoot项目进行发布部署,这和我们之前的普通web项目不太一样,之前的项目直接部署到tomcat的webapps中,然后启动tomcat即可访问。

但是SpringBoot项目内嵌tomcat,这如何发布部署访问呢?

目前比较常用的方式有三种:发布JAR包、发布WAR包、部署到自动化容器中,以下具体讲解发布部署过程。

1

技术选型

JDK1.7、MYSQL57、Spring Boot、Logback、Mybatis、mybatis映射xml、jsp、关闭默认模板引擎、DB连接池

2

开发工具

Myeclipse、Maven、Linux、Tomcat7

方式一:JAR包

点击这里《框架 | SpringBoot项目创建和发布部署步骤》

方式二:WAR包

为了更好的演示项目效果,将原有的SpringBoot示例项目进行了改造,增加了登录页面、支持jsp、支持mybatis映射、和修改了项目结构。

结构如下:

代码如下:

application.properties

##项目访问信息
server.port=8010
server.contextPath=/springboot
##数据库连接信息
spring.datasource.url=jdbc:mysql://localhost:3306/springboot
spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.max-idle=10
spring.datasource.max-wait=10000
spring.datasource.min-idle=5
spring.datasource.initial-size=5
# 页面默认前缀目录
spring.mvc.view.prefix=/WEB-INF/jsp/
## 响应页面默认后缀
spring.mvc.view.suffix=.jsp
#关闭默认模板引擎
spring.thymeleaf.cache=false
spring.thymeleaf.enabled=false
#mybatis
mybatis.mapper-locations=classpath:mybatis/mapper/*.xml
 UserDao.java
@Mapper
public interface  UserDao {
    UserInfo findByName(@Param("username") String username);
    int insert(@Param("username") String name, @Param("password") String password);
}
MainServer.java
@SpringBootApplication
@ComponentScan(basePackages={"com.xdl"})//添加的注解
@MapperScan({"com.xdl.dao"}) 
public class MainServer extends SpringBootServletInitializer {
 public static void main(String[] args) {
 SpringApplication.run(MainServer.class, args);
 }
 //为了打包springboot-war项目
 @Override
    protected SpringApplicationBuilder configure( SpringApplicationBuilder builder) {
        return builder.sources(this.getClass());
    }
}
 LoginController.java
@Controller
public class LoginController {
 /**
  * 登录页面
  * @return
  */
 @RequestMapping(value = "/login",method = RequestMethod.GET)
 public String login(){
 return "login";
 }
}
UserController.java
@Controller
public class UserController {
 private final Logger log = LoggerFactory.getLogger(UserController.class);
 @Autowired
 private UserDao userDao;
 @RequestMapping(value = "/add",method = RequestMethod.GET)
 public  @ResponseBody String addUser() {
 userDao.insert("likang","123123");
        return "插入成功";
    }
 @RequestMapping(value = "/find",method = RequestMethod.GET)
 public @ResponseBody UserInfo queryUserByName(String username){
 UserInfo userinfo = userDao.findByName(username);
 return userinfo;
 }
}
UserInfo.java
public class UserInfo {
 private int id;
 private String username;
 private String password;
增加getter和setter方法
}
IUserService.java
public interface IUserService {
 public UserInfo findByname(String username);
 public int insertUser(String username,String password);
}
UserServiceImpl.java
@Service
public class UserServiceImpl implements IUserService{
 @Autowired
 UserDao userDao;
 @Override
 public int insertUser(String username, String password) {
 return userDao.insert(username, password);
 }
 @Override
 public UserInfo findByname(String username) {
 UserInfo userinfo = userDao.findByName(username);
 return userinfo;
 }
}
UserMapper.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.xdl.dao.UserDao" >
    <resultMap id="BaseResultMap" type="com.xdl.system.entity.UserInfo" >
        <id column="id" property="id" jdbcType="INTEGER" />
        <result column="username" property="username" jdbcType="VARCHAR" />
        <result column="password" property="password" jdbcType="VARCHAR" />
    </resultMap>
    <sql id="Base_Column_List" >
        id, username, password
    </sql>
    <select id="findByName" resultMap="BaseResultMap" parameterType="java.lang.String" >
        select
        <include refid="Base_Column_List" />
        from userinfo
        where username = #{username,jdbcType=VARCHAR}
    </select>
    <insert id="insert" parameterType="com.xdl.system.entity.UserInfo" >
        insert into userinfo (id, username, password)
        values (#{username,jdbcType=VARCHAR}, #{password,jdbcType=VARCHAR})
    </insert>
</mapper>
login.jsp 
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<%
 pageContext.setAttribute("PATH", request.getContextPath());
%>
<html>
<head>
<meta charset="utf-8">
<link href=".//manager/static/h-ui/css/H-ui.min.css" rel="stylesheet" type="text/css" />
<link href="./manager/static/h-ui.admin/css/H-ui.login.css" rel="stylesheet" type="text/css" />
<link href="./manager/static/h-ui.admin/css/style.css" rel="stylesheet" type="text/css" />
<link href="./manager/lib/Hui-iconfont/1.0.8/iconfont.css" rel="stylesheet" type="text/css" />
<title>后台登录</title>
</head>
<body>
<input type="hidden" id="TenantId" name="TenantId" value="" />
<div class="loginWraper">
  <div id="loginform" class="loginBox">
 <h2 align="center">SpringBoot项目后台管理系统</h2>
    <form class="form form-horizontal" action="/login.do" method="post">
      <div class="row cl">
        <label class="form-label col-xs-3"><i class="Hui-iconfont">&#xe60d;</i></label>
        <div class="formControls col-xs-8">
          <input id="phone" name="phone" type="text" placeholder="账户手机号" class="input-text size-L">
        </div>
      </div>
      <div class="row cl">
        <label class="form-label col-xs-3"><i class="Hui-iconfont">&#xe60e;</i></label>
        <div class="formControls col-xs-8">
          <input id="passwordm" name="passwordm" type="password" placeholder="密码" class="input-text size-L">
        </div>
      </div>
      <div class="row cl">
        <div class="formControls col-xs-8 col-xs-offset-3">
         <button type="button" value="" class="btn btn-success radius size-L" id="login" onclick="loginAjax()">登录</button>
   &nbsp;&nbsp;&nbsp;&nbsp;  &nbsp;&nbsp;&nbsp;&nbsp;
          <input name="" type="reset" class="btn btn-default radius size-L" value="&nbsp;取&nbsp;&nbsp;&nbsp;&nbsp;消&nbsp;">
        </div>
      </div>
    </form>
  </div>
</div>
<script type="text/javascript" src="./manager/lib/jquery/1.9.1/jquery.min.js"></script> 
<script type="text/javascript" src="./manager/static/h-ui/js/H-ui.min.js"></script>
<script type="text/javascript" src="./manager/static/h-ui.admin/js/login-admin.js"></script>
</body>
</html>

发布部署WAR包步骤:

①:修改<packaging>war</packaging>为war包格式

②:修改pom.xml,取消tomcat依赖包关系

③:增加javax.servlet-api包依赖

④:项目右键,执行maven install命令

⑤:在target文件下,查找生成的war包

⑥:将war包复制到tomcat的webapps目录下

⑦:启动tomcat

⑧:测试访问

核心配置和操作过程如下:

pom.xml
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
 <modelVersion>4.0.0</modelVersion>
 <groupId>com.xdl</groupId>
 <artifactId>SpringBoot</artifactId>
 <version>0.0.1-SNAPSHOT</version>
 <packaging>war</packaging>
<parent>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-parent</artifactId>
 <version>1.5.9.RELEASE</version>
 <relativePath />
</parent>
<dependencies>
 <dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-web</artifactId>
 </dependency>
 <dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-test</artifactId>
 <scope>test</scope>
 </dependency>
 <dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-logging</artifactId>
 </dependency>
 <dependency>
 <groupId>org.mybatis.spring.boot</groupId>
 <artifactId>mybatis-spring-boot-starter</artifactId>
 <version>1.3.1</version>
 </dependency>
 <dependency>
 <groupId>mysql</groupId>
 <artifactId>mysql-connector-java</artifactId>
 <version>5.1.30</version>
 </dependency>
 <dependency>
 <groupId>org.apache.tomcat.embed</groupId>
 <artifactId>tomcat-embed-jasper</artifactId>
 <scope>provided</scope>
 </dependency>
 <dependency>
 <groupId>javax.servlet</groupId>
 <artifactId>jstl</artifactId>
 <scope>provided</scope>
 </dependency>
 <dependency>
 <groupId>javax.servlet</groupId>
 <artifactId>javax.servlet-api</artifactId>
 <scope>provided</scope>
 </dependency>
 <dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-web</artifactId>
 <!-- 移除嵌入式tomcat插件 -->
 <exclusions>
 <exclusion>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-tomcat</artifactId>
 </exclusion>
 </exclusions>
 </dependency>
</dependencies>
<build>
 <plugins>
 <plugin>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-maven-plugin</artifactId>
 <configuration>
 <mainClass>com.xdl.server.MainServer</mainClass>
 </configuration>
 </plugin>
 </plugins>
 <finalName>springboot</finalName>
</build>
</project>

接下来操作如下:

项目-->右键-->maven install-->然后在target下查找war包,如图:

然后复制war包到tomcat的webapps下,启动tomcat:

测试访问:

方式三:自动化容器

原文发布于微信公众号 - 码神联盟(lkchatspace)

原文发表时间:2018-05-11

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏IT进修之路

原 荐 Spring Boot 多库分布式事

27970
来自专栏Java3y

Druid数据库连接池就是这么简单

前言 本章节主要讲解Druid数据库连接池,为什么要学Druid数据库连接池呢?? 我的知识储备数据库连接池有两种->C3P0,DBCP,可是现在看起来并不够用...

535110
来自专栏架构师之旅

Spring框架知识总结-Spring事务配置的五种方式

前段时间对Spring的事务配置做了比较深入的研究,在此之间对Spring的事务配置虽说也配置过,但是一直没有一个清楚的认识。通过这次的学习发觉Spring的事...

18090
来自专栏闻道于事

Spring boot集成MybatisPlus

Mybatis-Plus(简称MP)是一个 Mybatis 的增强工具,在 Mybatis 的基础上只做增强不做改变,为简化开发、提高效率而生。(摘自myba...

15820
来自专栏Hadoop实操

如何使用Sentry管理Hive外部表权限

使用如下命令在HDFS的根目录下创建Hive外部表的数据目录/extwarehouse

1.9K80
来自专栏乐沙弥的世界

Linux下基于源码方式安装MySQL 5.6

    MySQL为开源数据库,因此可以基于源码实现安装。基于源码安装有更多的灵活性。也就是说我们可以针对自己的硬件平台选用合适的编译器来优化编译后的二进制代码...

10810
来自专栏Ryan Miao

gradle中使用嵌入式(embedded) tomcat, debug 启动

在gradle项目中使用embedded tomcat。 最开始部署项目需要手动将web项目打成war包,然后手动上传到tomcat的webapp下,然后启动t...

51090
来自专栏Java技术分享

SSM三大框架整合详细总结(Spring+SpringMVC+MyBatis)

使用 SSM ( Spring 、 SpringMVC 和 Mybatis )已经很久了,项目在技术上已经没有什么难点了,基于现有的技术就可以实现想要的功能,当...

2.2K130
来自专栏码神联盟

框架 | SpringBoot项目创建和发布部署步骤

3.2K40
来自专栏pangguoming

简单的Hibernate入门简介

其实Hibernate本身是个独立的框架,它不需要任何web server或application server的支持。然而,大多数的Hibernate入门介绍...

37190

扫码关注云+社区

领取腾讯云代金券