文章目录
- 前言
- 一、开发环境
- 二、项目搭建
- 2.1 Maven创建项目
- 2.1.1 创建maven项目
- 2.1.2 引入依赖
- 2.1.3 maven常用命令
- 三、SpringBoot基础配置
- 四、项目打包
- 4.1 打包jar
- 4.2 打包war
- 4.2.1 修改项目打包为war包
- 4.2.2 排除内嵌的tomcat,引入外部tomcat
- 4.2.3 添加servlet-api依赖
- 4.2.4 修改app入口方法,继承SpringBootServletInitializer,记得重写configure方法
- 4.2.5 和打包jar包一样添加war包插件,其中warName就是项目启动后访问项目的contextPath,当然这时候可以去tomcat里配置无需contextPath。默认访问该项目
- 五、服务部署
- 5.1 winserver
- 5.2 centos
- 六、Nginx相关配置
- 6.1 端口转发
- 6.2 HTTPS
- 6.3 静态Web
- 6.4 静态资源访问
前言
从事Java开发许久,从最初学习的JDK环境变量开始,到如今开发部署发布,已经逐渐形成了自己的一套体系,当然,其中也不少学习了网上各种资料总结,接下来将在本文对Java项目开发到部署发布整个流程进行归纳梳理。
一、开发环境
关于开发环境,在之前写的一篇文章里有详细教学,因为是比较基础的部分,就不在这里过多赘述,如果各位看官需要翻阅可以点击下面链接跳转
Java开发环境搭建教程
二、项目搭建
环境配置好了,自然就是搭建项目框架,这里使用的是idea+maven方式,其他IDE大同小异
2.1 Maven创建项目
2.1.1 创建maven项目
首先file->new->project,注意图中红框的JDK版本
2.1.2 引入依赖
打开项目的pom.xml文件,在中配置每一个dependency,而springboot项目,需要添加父依赖
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>***</version>
</parent>
<dependencies>
<dependency>
<groupId>***</groupId>
<artifactId>***</artifactId>
<version>**</version>
</dependency>
</dependencies>
2.1.3 maven常用命令
一般来说,maven常用命令用clean和install(package),idea为maven项目提供了按钮操作,无需在terminal中使用mvn命令
三、SpringBoot基础配置
server:
port: 6013 # tomcat端口
servlet:
context-path: /v1 # api context path
spring:
application:
name: TEST # app name
datasource:
url: jdbc:mysql://localhost:3306/test?serverTimezone=Asia/Shanghai&characterEncoding=UTF8
username: root
password: admin
driver-class-name: com.mysql.cj.jdbc.Driver
jpa:
hibernate:
ddl-auto: update
show-sql: true
logging:
config: classpath:log/logging.xml # 日志配置路径
四、项目打包
因为是maven构建的springboot项目,故这里仅讲述maven打包的方式
4.1 打包jar
在pom.xml中配置build即可
<build>
<finalName>{自行指定打包名称,不配置则默认项目名称}</finalName>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<fork>true</fork>
<mainClass>{springboot项目入口,即main方法所在类class}</mainClass>
</configuration>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
4.2 打包war
相对于jar包,打包war就需要排除springboot中内嵌的tomcat
4.2.1 修改项目打包为war包
4.2.2 排除内嵌的tomcat,引入外部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>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>provided</scope>
</dependency>
4.2.3 添加servlet-api依赖
<dependency>
<groupId>org.apache.tomcat</groupId>
<artifactId>tomcat-servlet-api</artifactId>
<version>7.0.42</version>
<scope>provided</scope>
</dependency>
4.2.4 修改app入口方法,继承SpringBootServletInitializer,记得重写configure方法
@SpringBootApplication
@EnableCaching
public class TestApplication extends SpringBootServletInitializer {
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
return application.sources(TestApplication.class);
}
public static void main(String[] args) {
SpringApplication.run(TestApplication.class, args);
}
}
4.2.5 和打包jar包一样添加war包插件,其中warName就是项目启动后访问项目的contextPath,当然这时候可以去tomcat里配置无需contextPath。默认访问该项目
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-war-plugin</artifactId>
<configuration>
<warSourceExcludes>src/main/resources/**</warSourceExcludes>
<warName>test</warName>
</configuration>
</plugin>
五、服务部署
5.1 winserver
winserver的部署和我们在电脑开发类似,打包cmd,运行java -jar jar包完整路径即可
当然,可以编写bat脚本一键启动等等,这些骚操作就不在这里过多讲述,可自行发挥bat编写
5.2 centos
和winserver类似,打包传上去,java -jar jar包路径
不过由于ssh session的关系,如果直接运行上面命令,会在session前台运行,此时session要么关闭,要么看着jar包运行。如果需要后台运行,则需要用到nohup命令
nohup java -jar **.jar &
控制台输出默认在nohup.out中
同winserver的bat一样,jar包也通常不会再linux中直接运行,一般使用sh脚本或者写入service中,通过脚本或systemctl等命令运行
六、Nginx相关配置
6.1 端口转发
一般来说,我们开发的端口不会直接使用80,会使用域名转发到我们的端口服务上,在nginx中,可以进行一下配置达到此效果
server {
listen 80;
server_name www.***.com;
charset utf-8;
location / {
proxy_pass http://127.0.0.1:8080/**;
}
error_page 404 400 401 402 403 /404.html;
location = /404.html {
root html;
}
error_page 500 502 503 504 /500.html;
location = /500.html {
root html;
}
}
6.2 HTTPS
https首先需要为自己的域名购买或生成证书,具体方法可自行百度或在各大云服务商购买
有了证书后,将证书中后缀为crt和key的两个文件放入和ngxin的nginx.conf文件平级或者下级的目录中,然后在需要https访问的域名中配置如下
server {
# https 默认443端口
listen 443 ssl;
server_name www.***.com;
charset utf-8;
#证书文件名称
ssl_certificate 1_www.***.com_bundle.crt;
#私钥文件名称
ssl_certificate_key 2_www.***.com.key;
ssl_session_timeout 5m;
#请按照以下协议配置
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
#请按照以下套件配置,配置加密套件,写法遵循 openssl 标准。
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;
ssl_prefer_server_ciphers on;
location / {
proxy_pass http://127.0.0.1:8080/**;
}
error_page 404 400 401 402 403 /404.html;
location = /404.html {
root html;
}
error_page 500 502 503 504 /500.html;
location = /500.html {
root html;
}
}
6.3 静态Web
静态web的配置方式与端口转发类似,只是将proxy_pass换成了root路径
server {
listen 80;
server_name www.***.com;
charset utf-8;
location / {
root /usr/local/web/***;
index index.html;
}
error_page 404 400 401 402 403 /404.html;
location = /404.html {
root html;
}
error_page 500 502 503 504 /500.html;
location = /500.html {
root html;
}
}
6.4 静态资源访问
静态资源和静态web配置一致,只需要将web路径换成资源路径即可,访问同样按照web访问资源文件
server {
listen 80;
server_name file.***.com;
charset utf-8;
location / {
root /usr/local/file/***;
index index.html;
}
}