SpringBoot快速入门(笔记四-实用运维篇)

本章节将讲一下我们在实际部署springBoot 项目中需要注意的问题

一:打包与运行

1.1 SpringBoot项目快速启动 【Windows版】

1.1.1:对SpringBoot项目打包(执行Maven构建指令package)

mvn package


1.1.2:运行项目(执行启动指令)

java –jar 打包的jar包名称.jar

 注意 jar支持命令行启动需要依赖maven插件支持,请确认打包时是否具有SpringBoot对应的maven插件




org.springframework.boot
spring-boot-maven-plugin


 不然会有如下错误SpringBoot快速入门(笔记四-实用运维篇)_第1张图片

 那么咱们打包后的jar包里到底有什么东西

分别是:

SpringBoot快速入门(笔记四-实用运维篇)_第2张图片

那么为什么基于spring-boot-maven-plugin打包的工程就可以启动?咱们打开打包后项目的描述文件 MANIFEST.MF,可以看到基于spring-boot-maven-plugin 打包的项目中有指定启动类,以及jar启动器。

SpringBoot快速入门(笔记四-实用运维篇)_第3张图片

 1.1.3:Windonws端口被占用时候指令

# 查询端口
netstat -ano
# 查询指定端口
netstat -ano |findstr "端口号"
# 根据进程PID查询进程名称
tasklist |findstr "进程PID号"
# 根据PID杀死任务
taskkill /F /PID "进程PID号"
# 根据进程名称杀死任务
taskkill -f -t -im "进程名称"

1.2:SpringBoot项目快速启动(Linux版)

基于Linux(CenterOS7)
安装JDK,且版本不低于打包时使用的JDK版本
安装包保存在/usr/local/自定义目录中或$HOME下
其他操作参照Windows版进行 1. 上传安装包 2. 执行jar命令:java –jar 工程名.jar


二:配置高级

1:临时属性设置

1.1:带属性数启动SpringBoot

java –jar springboot.jar –-server.port=80

携带多个属性启动SpringBoot,属性间使用空格分隔

这里涉及一个属性加载顺序:

参看https://docs.spring.io/spring-boot/docs/current/reference/html/spring-boot-features.html#boot-features-external-config

1. 使用jar命令启动SpringBoot工程时可以使用临时属性替换配置文件中的属性
2. 临时属性添加方式:java –jar 工程名.jar –-属性名=值
3. 多个临时属性之间使用空格分隔
4. 临时属性必须是当前boot工程支持的属性,否则设置无效

这里设置是在服务器上 我们开发想临时设置该如何制作?

IDEA属性启动SpringBoot程序,为程序添加运行属性

SpringBoot快速入门(笔记四-实用运维篇)_第4张图片

1.2 通过编程形式带参数启动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) {
SpringApplication.run(SSMPApplication.class);
}

1. 启动SpringBoot程序时,可以选择是否使用命令行属性为 SpringBoot程序传递启动属性 

2:配置文件分类

1.1: SpringBoot中4级配置文件

1级: file :config/application.yml 【最高】

2级: file :application.yml

3级:classpath:config/application.yml

4级:classpath:application.yml 【最低】

1.2: 作用:

1级与2级留做系统打包后设置通用属性,1级常用于运维经理进行线上整体项目部署方案调控   3级与4级用于系统开发阶段设置通用属性,3级常用于项目经理进行整体项目属性调控

如果yml与properties在不同层级中共存会是什么效果? 例:类路径application.properties属性是否覆盖文件系统config目录中application.yml属性?

1. 配置文件分为4种  

        项目类路径配置文件:服务于开发人员本机开发与测试  

        项目类路径config目录中配置文件:服务于项目经理整体调控  

        工程路径配置文件:服务于运维人员配置涉密线上环境  

        工程路径config目录中配置文件:服务于运维经理整体调控

2. 多层级配置文件间的属性采用叠加并覆盖的形式作用于程序

3:自定义配置文件

通过启动参数加载配置文件(无需书写配置文件扩展名)  比如 ebank.yml 文件 properties与yml文件格式均支持

SpringBoot快速入门(笔记四-实用运维篇)_第5张图片

 通过启动参数加载指定文件路径下的配置文件 properties与yml文件格式均支持

SpringBoot快速入门(笔记四-实用运维篇)_第6张图片

通过启动参数加载指定文件路径下的配置文件时可以加载多个配置

SpringBoot快速入门(笔记四-实用运维篇)_第7张图片

 多配置文件常用于将配置进行分类,进行独立管理,或将可选配置单独制作便于上线更新维护

说明: 

单服务器项目:使用自定义配置文件需求较低
多服务器项目:使用自定义配置文件需求较高,将所有配置放置在一个目录中,统一管理
基于SpringCloud技术,所有的服务器将不再设置配置文件,而是通过配置中心进行设定,动态加载配置信息

三:多环境开发(重点)

SpringBoot快速入门(笔记四-实用运维篇)_第8张图片

1:多环境开发(YAML版)

1. 多环境开发需要设置若干种常用环境,例如开发、生产、测试环境
2. yaml格式中设置多环境使用---区分环境设置边界
3. 每种环境的区别在于加载的配置属性不同
4. 启用某种环境时需要指定启动时使用该环境

SpringBoot快速入门(笔记四-实用运维篇)_第9张图片

SpringBoot快速入门(笔记四-实用运维篇)_第10张图片

 但是这里有个问题  它暴露配置,人一眼就看到所有配置 这是不允许的(银行项目等)

SpringBoot快速入门(笔记四-实用运维篇)_第11张图片

所以我们一般都会分为 pro,dev,test 三个配置文件然后配置一个主启动配置文件,将公共的配置放到主启动配置文件中去。

主配置文件中设置公共配置(全局)
环境分类配置文件中常用于设置冲突属性(局部)

SpringBoot快速入门(笔记四-实用运维篇)_第12张图片

2:多环境开发(Properties版)

SpringBoot快速入门(笔记四-实用运维篇)_第13张图片

 补充与技巧

1:根据功能对配置文件中的信息进行拆分,并制作成独立的配置文件,命名规则如下
application-devDB.yml
application-devRedis.yml
application-devMVC.yml
2:使用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

 1. 多环境开发使用group属性设置配置文件分组,便于线上维护管理

3:多环境开发控制

3.1:Maven与SpringBoot多环境兼容

SpringBoot快速入门(笔记四-实用运维篇)_第14张图片

 SpringBoot快速入门(笔记四-实用运维篇)_第15张图片

 ③:执行Maven打包指令,并在生成的boot打包文件.jar文件中查看对应信息

1. 当Maven与SpringBoot同时对多环境进行控制时,以Mavn为主, SpringBoot使用@..@占位符读取Maven对应的配置属性值

2. 基于SpringBoot读取Maven配置属性的前提下,如果在Idea下测试 工程时pom.xml每次更新需要手动compile方可生效

四:日志

1:日志基础

SpringBoot快速入门(笔记四-实用运维篇)_第16张图片

1.1:代码中使用日志工具记录日志

1. 日志用于记录开发调试与运维过程消息

2. 日志的级别共6种,通常使用4种即可,分别是DEBUG,INFO,WARN,ERROR 3. 可以通过日志组或代码包的形式进行日志显示级别的控制

①:添加日志记录操作

@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...";
}
}

 private static final Logger log = LoggerFactory.getLogger(BookController.class);

日志级别
    TRACE:运行堆栈信息,使用率低
    DEBUG:程序员调试代码使用
    INFO:记录运维过程数据
    WARN:记录运维过程报警数据
    ERROR:记录错误堆栈信息
    FATAL:灾难信息,合并计入ERROR

②:设置日志输出级别

# 开启debug模式,输出调试信息,常用于检查系统运行状况
debug: true
# 设置日志级别,root表示根节点,即整体应用日志级别
logging:
 level:
  root: debug

 ③:设置日志组,控制指定包对应的日志输出级别,也可以直接控制指定包对应的日志输出级别

logging:
# 设置日志组
group:
# 自定义组名,设置当前组中所包含的包
ebank: com.aming.controller
 level:
  root: warn
# 为对应组设置日志级别
ebank: debug
# 为对包设置日志级别
com.aming.controller: debug

每次日志控制我们都要反复写:

private static final Logger log = LoggerFactory.getLogger(BookController.class);

所以使用lombok提供的注解@Slf4j简化开发,减少日志对象的声明操作

@Slf4j
@RestController
@RequestMapping("/books")
public class BookController {
@GetMapping
public String getById(){
System.out.println("springboot is running...");
log.debug("debug info...");
log.info("info info...");
log.warn("warn info...");
log.error("error info...");
return "springboot is running...";
}
}

1. 基于lombok提供的@Slf4j注解为类快速添加日志对象

2:日志输出格式控制

SpringBoot快速入门(笔记四-实用运维篇)_第17张图片

 那我们如何设置日志输出格式?配置文件中:

logging:
 pattern:
  console: "%d %clr(%p) --- [%16t] %clr(%-40.40c){cyan} : %m %n"

%d:日期
%m:消息
%n:换行

%clr(%p)  给PID加颜色

 [%16t]   16个占位符

%clr(%-40.40c){cyan}  前后对齐 包名缩写 加颜色

3:日志文件

我们的日志 不可以光打在控制台 要写入一个日志文件中方便排查问题

logback:

   rollingpolicy:     日志生成策略为滚动

max-file-size: 3KB     文件大小3kb

file-name-pattern: server.%d{yyyy-MM-dd}.%i.log    文件名格式 server.年月日.log

SpringBoot快速入门(笔记四-实用运维篇)_第18张图片

你可能感兴趣的:(SpringBoot,spring,spring,boot,java)