Spring Boot 2 基础篇学习笔记
- 内容介绍与课程目标
- 51-工程打包与运行
- 程序为什么要打包
- SpringBoot项目快速启动(Windows版)
- 步骤
- 打包优化:跳过 test 生命周期
- 小结:
- 52-打包插件
- 可执行jar包目录结构
- jar包描述文件(MANIFEST.MF)
- 命令行启动常见问题及解决方案
- 小结:
- 53-Boot工程快速启动(Linux版)
- 启动成功无法访问
- 添加 80 端口
- 后台启动命令
- 停止服务
- 小结:
- 总结:
- 54-临时属性
- 属性加载优先顺序
- 55-临时属性(开发环境)
- 56-配置文件4级分类
- 配置文件分类
- 57-自定义配置文件
- 58-多环境开发(yaml版)
- 59-多环境开发多文件版(yaml版)
- 多环境开发(YAML版)多配置文件格式
- 多环境开发配置文件书写技巧(一)
- 60-多环境开发多文件版(properties版)
- 61-多环境分组管理
- 多环境开发独立配置文件书写技巧(二)
- 62-多环境开发控制
- 63-日志基础操作
- 64-教你一招:快速创建日志对象
- 65-日志输出格式控制
- 66-文件记录日志(运维实用篇完结)
内容介绍
- 打包与运行
- 配置高级
- 多环境开发
- 日志
课程目标:
- 能够掌握SpringBoot程序多环境开发
- 能够基于Linux系统发布SpringBoot工程
- 能够解决线上灵活配置SpringBoot工程的需求
将程序部署在独立的服务器上
①:对SpringBoot项目打包(执行Maven构建指令package)
执行 package 打包命令之前 先执行 mvn clean 删除 target 目录及内容
mvn package
打包完成 生成对应的 jar 文件
可能出现的问题: IDEA下 执行 Maven 命令控制台中文乱码
Ctr+Alt+S 打开设置,在Build,Execution ,Deployment找到Build Tools下Maven项下的Runner ,在VM Options 添加
-Dfile.encoding=GB2312 ,点击OK。
②:运行项目(执行启动指令) java -jar <打包文件名>
java –jar springboot.jar
注意事项:
jar支持命令行启动需要依赖maven插件支持,请确认打包时是否具有SpringBoot对应的maven插件
org.springframework.boot spring-boot-maven-plugin
地址栏输入 cmd 回车
执行 java -jar springboot_08_ssmp-0.0.1-SNAPSHOT.jar
③:浏览器访问: http://localhost/pages/books.html
- SpringBoot工程可以基于java环境下独立运行jar文件启动服务
- SpringBoot工程执行mvn命令package进行打包
- 执行jar命令:java –jar 工程名.jar
如果没有配制spring boot 打包插件可能遇到下面的问题:
- 使用SpringBoot提供的maven插件可以将工程打包成可执行jar包
可执行jar包目录结构 jar包描述文件(MANIFEST.MF)org.springframework.boot spring-boot-maven-plugin
- 普通工程
Manifest-Version: 1.0 Implementation-Title: springboot_08_ssmp Implementation-Version: 0.0.1-SNAPSHOT Build-Jdk-Spec: 1.8 Created-By: Maven Jar Plugin 3.2.0
- 基于spring-boot-maven-plugin打包的工程
Manifest-Version: 1.0 Spring-Boot-Classpath-Index: BOOT-INF/classpath.idx Implementation-Title: springboot_08_ssmp Implementation-Version: 0.0.1-SNAPSHOT Spring-Boot-Layers-Index: BOOT-INF/layers.idx Start-Class: com.example.SSMPApplication 启动类 Spring-Boot-Classes: BOOT-INF/classes/ Spring-Boot-Lib: BOOT-INF/lib/ Build-Jdk-Spec: 1.8 Spring-Boot-Version: 2.5.6 Created-By: Maven Jar Plugin 3.2.0 Main-Class: org.springframework.boot.loader.JarLauncher jar启动器命令行启动常见问题及解决方案
- Windonws端口被占用
# 查询端口 netstat -ano # 查询指定端口 netstat -ano |findstr "端口号" # 根据进程PID查询进程名称 tasklist |findstr "进程PID号" # 根据PID杀死任务 taskkill /F /PID "进程PID号" # 根据进程名称杀死任务 taskkill -f -t -im "进程名称"
D:codeJavaIdeaProjectsspringboot-studyspringboot_08_ssmptarget>netstat -ano 活动连接 协议 本地地址 外部地址 状态 PID TCP 0.0.0.0:80 0.0.0.0:0 LISTENING 30988 TCP 0.0.0.0:135 0.0.0.0:0 LISTENING 1792 TCP 0.0.0.0:443 0.0.0.0:0 LISTENING 9400 TCP 0.0.0.0:445 0.0.0.0:0 LISTENING 4 TCP 0.0.0.0:902 0.0.0.0:0 LISTENING 6188 TCP 0.0.0.0:912 0.0.0.0:0 LISTENING 6188 D:codeJavaIdeaProjectsspringboot-studyspringboot_08_ssmptarget>netstat -ano |findstr "80" TCP 0.0.0.0:80 0.0.0.0:0 LISTENING 30988 TCP 0.0.0.0:7680 0.0.0.0:0 LISTENING 4864 TCP 0.0.0.0:8680 0.0.0.0:0 LISTENING 7976 TCP 192.168.1.102:9808 119.96.138.240:443 ESTABLISHED 20604 TCP [::]:80 [::]:0 LISTENING 30988 TCP [::]:7680 [::]:0 LISTENING 4864 UDP 127.0.0.1:65312 *:* 5680 UDP [fe80::2952:170d:f2f2:1464%16]:1900 *:* 2872 UDP [fe80::2952:170d:f2f2:1464%16]:60720 *:* 2872 UDP [fe80::4c2b:9d2f:a625:8b1c%6]:1900 *:* 2872 UDP [fe80::4c2b:9d2f:a625:8b1c%6]:60719 *:* 2872 UDP [fe80::e1e0:a2c9:200:2f34%19]:1900 *:* 2872 UDP [fe80::e1e0:a2c9:200:2f34%19]:60721 *:* 2872 D:codeJavaIdeaProjectsspringboot-studyspringboot_08_ssmptarget>tasklist |findstr "30988" java.exe 30988 Console 3 273,388 K D:codeJavaIdeaProjectsspringboot-studyspringboot_08_ssmptarget>tasklist 映像名称 PID 会话名 会话# 内存使用 ========================= ======== ================ =========== ============ System Idle Process 0 Services 0 8 K System 4 Services 0 1,500 K Registry 172 Services 0 94,584 K smss.exe 648 Services 0 1,084 K csrss.exe 1080 Services 0 5,888 K wininit.exe 1320 Services 0 6,868 K services.exe 1436 Services 0 9,264 K lsass.exe 1488 Services 0 11,932 K svchost.exe 1612 Services 0 17,804 K fontdrvhost.exe 1648 Services 0 488 K WUDFHost.exe 1688 Services 0 2,660 K svchost.exe 1792 Services 0 13,428 K WUDFHost.exe 1840 Services 0 2,628 K svchost.exe 1868 Services 0 3,460 K D:codeJavaIdeaProjectsspringboot-studyspringboot_08_ssmptarget>taskkill /F /PID "30988" 成功: 已终止 PID 为 30988 的进程。小结:
- spring-boot-maven-plugin插件作用
- Windonws端口被占用
- 基于Linux(CenterOS7)
- 安装JDK,且版本不低于打包时使用的JDK版本
- 可以使用 yum 安装
- 安装 MySQL
- 可以参考: https://blog.csdn.net/qq_42324086/article/details/120579197
- 安装包保存在/usr/local/自定义目录中或$HOME下
- 其他操作参照Windows版进行
- 添加 端口
firewall-cmd --zone=public --permanent --add-port=80/tcp
- 重启
systemctl restart firewalld后台启动命令
nohup java -jar springboot_08_ssmp-0.0.1-SNAPSHOT.jar > server.log 2>&1 &停止服务
- ps -ef | grep “java -jar”
- kill -9 PID
- cat server.log (查看日志)
[root@cjbCentos01 app]# ps -ef | grep "java -jar" UID PID PPID C STIME TTY TIME CMD root 6848 6021 7 14:45 pts/2 00:00:19 java -jar springboot_08_ssmp-0.0.1-SNAPSHOT.jar root 6919 6021 0 14:49 pts/2 00:00:00 grep --color=auto java -jar [root@cjbCentos01 app]# kill -9 6848 [root@cjbCentos01 app]# ps -ef | grep "java -jar" root 7016 6021 0 14:52 pts/2 00:00:00 grep --color=auto java -jar [1]+ 已杀死 nohup java -jar springboot_08_ssmp-0.0.1-SNAPSHOT.jar > server.log 2>&1 [root@cjbCentos01 app]#小结:
- 上传安装包
- 执行jar命令:java –jar 工程名.jar
- Boot程序打包依赖SpringBoot对应的Maven插件即可打包出可执行的jar包
- 运行jar包使用jar命令进行
- Windows与Linux下执行Boot打包程序流程相同,仅需确保运行环境有效即可
- 带属性数启动SpringBoot
java -jar springboot_08_ssmp-0.0.1-SNAPSHOT.jar --server.port=8080
- 携带多个属性启动SpringBoot,属性间使用空格分隔
- 参看 https://docs.spring.io/spring-boot/docs/current/reference/html/spring-boot-features.html#boot-features-external-config
小结:
- 使用jar命令启动SpringBoot工程时可以使用临时属性替换配置文件中的属性
- 临时属性添加方式:java –jar 工程名.jar --属性名=值
- 多个临时属性之间使用空格分隔
- 临时属性必须是当前boot工程支持的属性,否则设置无效
- 带属性启动SpringBoot程序,为程序添加运行属性
在启动类中 main 可以通过 System.out.println(Arrays.toString(args)); 查看配制的属性
- 通过编程形式带参数启动SpringBoot程序,为程序添加运行参数
public static void main(String[] args) {
String[] arg = new String[1];
arg[0] = "--server.port=8080";
SpringApplication.run(SSMPApplication.class, arg);
}
- 不携带参数启动SpringBoot程序
public static void main(String[] args) {
//可以在启动boot程序时断开读取外部临时配置对应的入口,也就是去掉读取外部参数的形参
SpringApplication.run(SSMPApplication.class);
}
小结:
- 启动SpringBoot程序时,可以选择是否使用命令行属性为SpringBoot程序传递启动属性
- SpringBoot中4级配置文件
- 1级:file :config/application.yml 【最高】
- 2级:file :application.yml
- 3级:classpath:config/application.yml
- 4级:classpath:application.yml 【最低】
- 作用:
- 1级与2级留做系统打包后设置通用属性,1级常用于运维经理进行线上整体项目部署方案调控
- 3级与4级用于系统开发阶段设置通用属性,3级常用于项目经理进行整体项目属性调控
思 考:
如果yml与properties在不同层级中共存会是什么效果?
例:类路径application.properties属性是否覆盖文件系统config目录中application.yml属性
properties文件的优先级大于yml文件 (properties文件会覆盖yml文件的配制)
小结:
- 配置文件分为4种
项目类路径配置文件:服务于开发人员本机开发与测试
项目类路径config目录中配置文件:服务于项目经理整体调控
工程路径配置文件:服务于运维人员配置涉密线上环境
工程路径config目录中配置文件:服务于运维经理整体调控 - 多层级配置文件间的属性采用叠加并覆盖的形式作用于程序
- 通过启动参数加载配置文件(无需书写配置文件扩展名) --spring.config.name=ebank
properties与yml文件格式均支持
- 通过启动参数加载指定文件路径下的配置文件 --spring.config.location=classpath:/ebank.yml
properties与yml文件格式均支持
- 通过启动参数加载指定文件路径下的配置文件时可以加载多个配置,后面的会覆盖前面的
--spring.config.location=classpath:/ebank.yml,classpath:/ebank-server.yml
注意事项:
多配置文件常用于将配置进行分类,进行独立管理,或将可选配置单独制作便于上线更新维护
自定义配置文件——重要说明
- 单服务器项目:使用自定义配置文件需求较低
- 多服务器项目:使用自定义配置文件需求较高,将所有配置放置在一个目录中,统一管理
- 基于SpringCloud技术,所有的服务器将不再设置配置文件,而是通过配置中心进行设定,动态加载配置信息
小结:
- 配置文件可以修改名称,通过启动参数设定
- 配置文件可以修改路径,通过启动参数设定
- 微服务开发中配置文件通过配置中心进行设置
总结:
- SpringBoot在开发和运行环境均支持使用临时参数修改工程配置
- SpringBoot支持4级配置文件,应用于开发与线上环境进行配置的灵活设置
- SpringBoot支持使用自定义配置文件的形式修改配置文件存储位置
- 基于微服务开发时配置文件将使用配置中心进行管理
多环境
多环境开发(YAML版)
#应用环境
#公共配制
spring:
profiles:
active: dev
#设置环境
#开发环境
---
spring:
config:
activate:
on-profile: dev
server:
port: 81
#生产环境
---
spring:
profiles: pro
server:
port: 80
#测试环境
---
spring:
profiles: test
server:
port: 82
小结:
- 多环境开发需要设置若干种常用环境,例如开发、生产、测试环境
- yaml格式中设置多环境使用—区分环境设置边界
- 每种环境的区别在于加载的配置属性不同
- 启用某种环境时需要指定启动时使用该环境
- 主启动配置文件application.yml
#应用环境
#公共配制
spring:
profiles:
active: test
- 环境分类配置文件application-pro.yml
server: port: 81
- 环境分类配置文件application-dev.yml
server: port: 82
- 环境分类配置文件application-test.yml
server: port: 83多环境开发配置文件书写技巧(一)
- 主配置文件中设置公共配置(全局)
- 环境分类配置文件中常用于设置冲突属性(局部)
小结:
- 可以使用独立配置文件定义环境属性
- 独立配置文件便于线上系统维护更新并保障系统安全性
- 主启动配置文件application.properties
spring.profiles.active=dev
- 环境分类配置文件application-pro.properties
server.port=9081
- 环境分类配置文件application-dev.properties
server.port=9082
- 环境分类配置文件application-test.properties
server.port=9083
小结:
- properties文件多环境配置仅支持多文件格式
- 根据功能对配置文件中的信息进行拆分,并制作成独立的配置文件,命名规则如下
- application-devDB.yml
- application-devRedis.yml
- application-devMVC.yml
- 使用include属性在激活指定环境的情况下,同时对多个环境进行加载使其生效,多个环境间使用逗号分隔
spring:
profiles:
active: dev
include: devDB,devMVC
注意事项:
当主环境dev与其他环境有相同属性时,主环境属性生效;其他环境中有相同属性时,最后加载的环境属性生效
The following profiles are active: devDB,devMVC,dev
- 从Spring2.4版开始使用group属性替代include属性,降低了配置书写量
- 使用group属性定义多种主环境与子环境的包含关系
spring:
profiles:
active: dev
group:
"dev": devDB,devMVC
"pro": proDB,proMVC
"test": testDB,testRedis,testMVC
注意事项:
使用group属性,会覆盖 主环境dev (active) 的内容,最后加载的环境属性生效
The following profiles are active: dev,devDB,devMVC
小结:
- 多环境开发使用group属性设置配置文件分组,便于线上维护管理
Maven与SpringBoot多环境兼容
①:Maven中设置多环境属性
dev_env
dev
true
pro_env
pro
test_env
test
②:SpringBoot中引用Maven属性
spring:
profiles:
active: @profile.active@
group:
"dev": devDB,devMVC
"pro": proDB,proMVC
③:执行Maven打包指令,并在生成的boot打包文件.jar文件中查看对应信息
问题:修改pom.xml 文件后,启动没有生效 手动 compile 即可
或者 设置 IDEA进行自动编译
小结:
- 当Maven与SpringBoot同时对多环境进行控制时,以Mavn为主,SpringBoot使用@…@占位符读取Maven对应的配置属性值
- 基于SpringBoot读取Maven配置属性的前提下,如果在Idea下测试工程时pom.xml每次更新需要手动compile方可生效
总结:
- 多环境开发(YAML版)
- 多环境开发(Properties版)
- Maven与SpringBoot多环境冲突现象解决方案
日志(log)作用
- 编程期调试代码
- 运营期记录信息
- 记录日常运营重要信息(峰值流量、平均响应时长……)
- 记录应用报错信息(错误堆栈)
- 记录运维过程数据(扩容、宕机、报警……)
代码中使用日志工具记录日志
- 先引入 Lombok 工具类
org.projectlombok
lombok
①:添加日志记录操作
@RestController
@RequestMapping("/books")
public class BookController {
private static final Logger log = LoggerFactory.getLogger(BookController.class);
@GetMapping
public String getById() {
System.out.println("springboot is running...");
log.debug("debug ...");
log.info("info ...");
log.warn("warn ...");
log.error("error ...");
return "springboot is running...";
}
}
- 日志级别
TRACE:运行堆栈信息,使用率低
DEBUG:程序员调试代码使用
INFO:记录运维过程数据
WARN:记录运维过程报警数据
ERROR:记录错误堆栈信息
FATAL:灾难信息,合并计入ERROR
②:设置日志输出级别
# 开启 debug 模式,输出调试信息,常用于检查系统运行状况
debug: true
# 设置日志级别, root 表示根节点,即整体应用日志级别
logging:
level:
root: debug
③:设置日志组,控制指定包对应的日志输出级别,也可以直接控制指定包对应的日志输出级别
logging:
# 设置分组
group:
# 自定义组名,设置当前组中所包含的包
ebank: com.example.controller,com.example.service,com.example.dao
iservice: com.alibaba
level:
root: info
# 设置某个包的日志级别
# com.example.controller: debug
# 为对应组设置日志级别
ebank: warn
小结:
- 日志用于记录开发调试与运维过程消息
- 日志的级别共6种,通常使用4种即可,分别是DEBUG,INFO,WARN,ERROR
- 可以通过日志组或代码包的形式进行日志显示级别的控制
- 使用lombok提供的注解@Slf4j简化开发,减少日志对象的声明操作
@Slf4j
//Rest模式
@RestController
@RequestMapping("/books")
public class BookController {
@GetMapping
public String getById(){
System.out.println("springboot is running...2");
log.debug("debug...");
log.info("info...");
log.warn("warn...");
log.error("error...");
return "springboot is running...2";
}
}
小结:
- 基于lombok提供的@Slf4j注解为类快速添加日志对象
- PID:进程ID,用于表明当前操作所处的进程,当多服务同时记录日志时,该值可用于协助程序员调试程序
- 所属类/接口名:当前显示信息为SpringBoot重写后的信息,名称过长时,简化包名书写为首字母,甚至直接删除
- 设置日志输出格式
logging:
pattern:
console: "%d - %m%n"
%d:日期
%m:消息
%n:换行
logging:
pattern:
# console: "%d - %m%n"
console: "%d %clr(%5p) --- [%16t] %clr(%-40.40c){cyan} : %m %n"
小结:
- 日志输出格式设置规则
- 设置日志文件
logging:
file:
name: server.log
- 日志文件详细配置
logging:
file:
name: server.log
logback:
rollingpolicy:
max-file-size: 4KB
file-name-pattern: server.%d{yyyy-MM-dd}.%i.log
小结:
- 日志记录到文件
- 日志文件格式设置
总结:
- 日志基础使用规则
- 编辑日志输出格式
- 日志文件设置



