SpringBoot运维篇
SpringBoot程序的打包和运行
程序打包
SpringBoot程序是基于Maven创建的,在Maven中提供有打包的指令,叫做package。本操作可以在Idea环境下执行
mvn package
打包后会产生一个与工程名类似的jar文件,其名称由模块名+版本号+.jar组成
程序运行
程序打包好了以后,就可以直接执行了。在程序包所在的路径下,执行指令
java -jar 工程名.jar
执行程序打包指令后,程序正常运行,与在idea下执行程序没有区别
特别关注:如果你的计算机中没有安装java的jdk环境,是无法正确执行上述操作,因为程序执行使用的是Java指令
特别关注:在使用向导创建SpringBoot工程时,pom.xml文件中会由如下配置,这一段配置不能删除,否则打包后无法正常执行程序
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
总结
- SpringBoot工程可以基于java环境独立运行jar文件启动服务
- SpringBoot工程执行mvn命令package进行打包
- 执行jar命令:Java -jar 工程名.jar
配置高级
临时属性设置
携带属性启动SpringBoot
java -jar springboot.jar --server.port=80
携带多个属性启动SpringBoot,属性间使用空格分隔
java -jar springboot.jar --server.port=80 --logging.level.root=debug
带属性启动SpringBoot程序,为程序添加运行属性
通过编程形式带参数启动SpringBoot程序,为程序添加运行参数
@SpringBootApplication
public class DemoApplication {
public static void main(String[] args) {
String[] arg = new String[1];
arg[0] = "--server.port=8080";
SpringApplication.run(DemoApplication.class, arg);
}
}
不携带参数启动SpringBoot程序
@SpringBootApplication
public class DemoApplication {
public static void main(String[] args) {
SpringApplication.run(DemoApplication.class);
}
}
配置文件分类
1、SpringBoot中4级配置文件
1级:file:config/application.yml
2级:file:application.yml
3级:classpath:config/application.yml
4级:classpath:application.yml
2、作用:
- 1级与2级留做系统打包后设置通用属性,1级常用于运维经理进行线上整体项目部署方案调控
- 3级与4级用于系统开发阶段通用属性,3级常用于项目经理进行整体项目属性调控
总结:
配置文件分为4种:
- 项目类路径配置文件:服务于开发人员本机开发与测试
- 项目类路径config目录中配置文件:服务于项目经理整体调控
- 工程路径配置文件:服务于运维人员配置涉及线上环境
- 工程路径config目录中配置文件:服务于运维经理整体调控
多层级配置文件间的属性采用叠加并覆盖的形式作用于程序
自定义配置文件
- 通过启动参数加载配置文件(无需书写配置文件扩展名)
注意:properties与yml文件格式均支持
- 通过启动参数加载指定文件路径下的配置文件
- 通过启动参数加载指定文件路径下的配置文件时可以加载多个配置
注意:多配置文件常用于将配置进行分类,进行独立管理,或将可选配置单独制作便于上线更新维护
总结
- 单服务器项目:使用自定义配置文件需求较低
- 多服务器项目:使用自定义配置文件需求较高,将所有配置放置在一个目录中,统一管理
- 基于SpringCloud技术,所有的服务器将不再设置配置文件,而是通过配置中心进行设定,动态加载配置信息
多环境开发
Yaml
- 多环境开发需要设置若干种常用环境,例如开发、生产、测试环境
- yaml格式中设置多环境使用—区分环境设置边界
- 每种环境的区别在于加载的配置属性不同
- 启用某种环境时需要指定启动时使用环境
多配置文件格式
-
主启动配置文件application.yml
spring: profiles: active: dev
-
环境分类配置文件applcation-pro.yml
server: port: 80
-
环境分类配置文件application-dev.yml
server: port: 81
-
环境分类配置文件application-test.yml
server: port: 82
多种开发配置文件书写技巧
第一种
-
主配置文件中设置公共配置(全局)
-
环境配置文件中常用于设置冲突属性(局部)
第二种
- 根据功能对配置文件中的信息进行拆分,并制作成独立的配置文件,命名规则如下
- application-devDB.yml
- application-devRedis.yml
- application-devMVC.yml
- 使用include属性在激活指定环境的情况下,同时对多个环境进行加载使其生效,多个环境间使用逗号隔开
spring:
profiles:
active: dev
include: devDB,devRedis,devMVC
注意:当主环境dev与其他环境有相同属性时,主环境属性生效;其他环境中有相同属性时,最后加载的环境属性生效
第三种
- 从Spring2.4版开始使用group属性替代include属性,降低了配置书写量
- 使用group属性自定义多种主环境与子环境的包含关系
spring:
profiles:
active: dev
group:
"dev": devDB,devRedis,devMVC
"pro": proDB,proRedis,proMVC
"test": testDB,testRedis,testMVC
作用:
独立配置文件便于线上系统维护更新并保障系统安全
properties版
-
主启动配置文件application.properties
spring.profiles.active: dev
-
环境分类配置文件applcation-pro.properties
server.port: 80
-
环境分类配置文件application-dev.properties
server.port: 81
-
环境分类配置文件application-test.propertiesml
server.port: 82
maven中设置多环境属性
1、Maven中设置多环境属性
<profiles>
<profile>
<id>dev_env</id>
<properties>
<profile.active>dev</profile.active>
</properties>
<activation>
<activeByDefault>true</activeByDefault>
</activation>
</profile>
<profile>
<id>pro_env</id>
<properties>
<profile.active>pro</profile.active>
</properties>
</profile>
<profile>
<id>test_env</id>
<properties>
<profile.active>test</profile.active>
</properties>
</profile>
</profiles>
2、SpringBoot中引用Maven属性
spring:
profiles:
active: @profile.active@
3、执行Maven打包指令,并在生成的boot打包文件.jar文件中查看对应信息
总结:
- 当maven与SpringBoot同时对多环境进行控制时,以Maven为主,SpringBoot使用@…@占位符读取Maven对应的配置属性值
- 基于SpringBoot读取Maven配置属性的前提下,如果在idea下测试工程时,pom.xml每次更新需要手动compile方可生效
日志
日志基础操作
日志作用:
- 编程期调试代码
- 运营期记录信息
- 记录日常运营重要信息(峰值流量、平均响应时长…)
- 记录应用报错信息(错误堆栈)
- 记录运维过程数据(扩容、宕机、报警…)
代码中使用日志工具记录日志
1、添加日志记录操作
@RestController
@RequestMapping("/books")
public class BookController extends BaseController {
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
2、设置日志输出级别
# 开启debug模式,输出调试信息,常用于检查系统运行状况
debug: true
# 设置日志级别,root表示根节点,即整体应用日志级别
logging:
level:
root: debug
3、设置日志组,控制指定包对应的日志输出级别,也可以直接控制指定包对应的日志输出级别
logging:
# 设置日志组
group:
# 自定义组名,设置当前组中所包含的包
ebank: com.dc.controller
level:
root: info
# 为对应组设置日志级别
ebank: debug
# 为对应包设置日志级别
com.dc.controller: debug
总结
- 日志用于记录开发调试与运维过程消息
- 日志的级别共6中,通常使用4中即可,分别是DEBUG、INFO、WARN、ERROR
- 可以通过日志组或代码包的形式进行日志显示级别的控制
代码中使用日志工具记录日志
Maven中设置多环境属性
优化日志对象创建代码
使用lombok提供的注解@Slf4j简化开发,减少日志对象的声明操作
日志输出格式控制
- PID:进程ID,用于表明当前操作所处的进程,当多服务同时记录日志时,该值可用于协助程序员调试程序
- 所属类/接口名:当前显示信息为SpringBoot重写后的信息,名称过长时,简化包名书写为首字母,甚至直接删除
设置日志输出格式
logging:
pattern:
consoler: "%d - %m%n"
- %d:日期
- %m:消息
- %n:换行
logging:
pattern:
console: "%d %clr(%p) --- [%16t] %clr(%-40.40c){cyan} : %m %n"
-
设置日志文件
logging: file: name: server.log
-
日志文件详细配置
logging: file: name: server.log logback: rollingpolicy: max-file-size: 3KB file-name-pattern: server.%d{yyyy-MM-dd}.%i.log