SpringBoot运维实用篇学习笔记

SpringBoot学习笔记

例如:第一章 Python 机器学习入门之pandas的使用


SpringBoot运维实用篇学习笔记

  • SpringBoot学习笔记
  • 前言
  • 一、工程打包与运行(Windows版)
  • 二、临时属性
    • 2.1 临时属性设置
    • 2.2 临时属性(开发环境)
  • 三、配置文件
    • 3.1 配置文件分类
    • 3.2 自定义配置文件
  • 四、多环境开发
    • 4.1 多环境开发(yaml版)
    • 4.2 多环境开发多文件版(yaml版)
    • 4.3 多环境开发多文件版(properties版)
    • 4.4 多环境分组管理
    • 4.5 多环境开发控制
  • 五、日志
    • 5.1 日志基础
    • 5.2 快速创建日志对象
    • 5.3 日志输出格式控制
    • 5.4 日志文件


前言


提示:以下是本篇文章正文内容,下面案例可供参考

一、工程打包与运行(Windows版)

(1)程序打包的原因:将程序部署在独立的服务器上
(2)步骤
①:对SpringBoot项目打包(执行Maven构建指令package)
执行 package 打包命令之前,先执行 mvn clean, 删除 target 目录及内容,然后跳过 test 生命周期
SpringBoot运维实用篇学习笔记_第1张图片

cLean成功
SpringBoot运维实用篇学习笔记_第2张图片
跳过 test 生命周期
SpringBoot运维实用篇学习笔记_第3张图片
打包完成生成对应的 jar 文件
SpringBoot运维实用篇学习笔记_第4张图片
SpringBoot运维实用篇学习笔记_第5张图片
②:运行
地址栏输入 cmd 回车
SpringBoot运维实用篇学习笔记_第6张图片
回车后弹出下列窗口
SpringBoot运维实用篇学习笔记_第7张图片
运行项目(执行启动指令) java -jar <打包文件名>

java –jar springboot.jar

SpringBoot运维实用篇学习笔记_第8张图片
在这里插入图片描述

③:浏览器访问: http://localhost//pages/books.html

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

<build>
        <plugins>
            <plugin>
                <groupId>org.springframework.bootgroupId>
                <artifactId>spring-boot-maven-pluginartifactId>
            plugin>
        plugins>
    build>

(3)打包插件

如果没有配制springboot 打包插件可能遇到下面的问题:
SpringBoot运维实用篇学习笔记_第9张图片
如果没有配制spring boot 打包插件可能遇到下面的问题:

<build>
        <plugins>
            <plugin>
                <groupId>org.springframework.bootgroupId>
                <artifactId>spring-boot-maven-pluginartifactId>
            plugin>
        plugins>
    build>

(4)命令行启动常见问题及解决方案
①:Windonws端口被占用

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

二、临时属性

2.1 临时属性设置

(1)带属性数启动SpringBoot

java -jar springboot_08_ssmp-0.0.1-SNAPSHOT.jar --server.port=8080

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

(2)属性加载优先顺序
参看https://docs.spring.io/spring-boot/docs/current/reference/html/spring-boot-features.html#boot-features-external-config

(3)小结

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

2.2 临时属性(开发环境)

(1)临时属性设置
①:带属性启动SpringBoot程序,为程序添加运行属性
SpringBoot运维实用篇学习笔记_第10张图片
SpringBoot运维实用篇学习笔记_第11张图片
SpringBoot运维实用篇学习笔记_第12张图片
(②:通过编程形式带参数启动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);
}

三、配置文件

3.1 配置文件分类

(1)SpringBoot中4级配置文件

  1. 1级:file :config/application.yml 【最高】
  2. 2级:file :application.yml
  3. 3级:classpath:config/application.yml
  4. 4级:classpath:application.yml 【最低】
  5. 作用:
    ①:1级与2级留做系统打包后设置通用属性,1级常用于运维经理进行线上整体项目部署方案调控
    ②:3级与4级用于系统开发阶段设置通用属性,3级常用于项目经理进行整体项目属性调控

(2)小结

  1. 配置文件分为4种
    ①:项目类路径配置文件:服务于开发人员本机开发与测试
    ②:项目类路径config目录中配置文件:服务于项目经理整体调控
    ③:工程路径配置文件:服务于运维人员配置涉密线上环境
    ④:工程路径config目录中配置文件:服务于运维经理整体调控
  2. 多层级配置文件间的属性采用叠加并覆盖的形式作用于程序

3.2 自定义配置文件

四、多环境开发

SpringBoot运维实用篇学习笔记_第13张图片

4.1 多环境开发(yaml版)

(1)
SpringBoot运维实用篇学习笔记_第14张图片
SpringBoot运维实用篇学习笔记_第15张图片
(2)application.yml

#应用环境
#公共配制
spring:
  profiles:
    active: pro
---
# 设置环境

#生产环境
spring:
  config:
    activate:
      on-profile: test
server:
  port: 80
---
#生产环境
spring:
  config:
    activate:
      on-profile: dev
server:
  port: 81
---
# 测试环境
spring:
  config:
    activate:
      on-profile: test
server:
  port: 82


(3)小结
SpringBoot运维实用篇学习笔记_第16张图片

4.2 多环境开发多文件版(yaml版)

SpringBoot运维实用篇学习笔记_第17张图片
(1)主启动配置文件application.yml

#应用环境
#公共配制
spring:
  profiles:
    active: test

(2)环境分类配置文件application-pro.yml

server:
  port: 8080

(3)环境分类配置文件application-dev.yml

server:
  port: 8081

(4)环境分类配置文件application-test.yml

server:
  port: 8082

(5)多环境开发配置文件书写技巧(一)
①:主配置文件中设置公共配置(全局)
②:环境分类配置文件中常用于设置冲突属性(局部)

(6)小结
①:可以使用独立配置文件定义环境属性
②:独立配置文件便于线上系统维护更新并保障系统安全性

4.3 多环境开发多文件版(properties版)

(1)主启动配置文件application.yml

spring.profiles.active=dev

(2)环境分类配置文件application-pro.properties

server.port=9081

(3)环境分类配置文件application-dev.properties

server.port=9082

(4)环境分类配置文件application-test.properties

server.port=9083

(5)小结
①:properties文件多环境配置仅支持多文件格式

4.4 多环境分组管理

(1)多环境开发独立配置文件书写技巧(二)

  • 根据功能对配置文件中的信息进行拆分,并制作成独立的配置文件,命名规则如下

    • application-devDB.yml
    • application-devRedis.yml
    • application-devMVC.yml

(2)使用include属性在激活指定环境的情况下,同时对多个环境进行加载使其生效,多个环境间使用逗号分隔

spring:
  profiles:
    active: dev
    include: devDB,devMVC

注意事项:
当主环境dev与其他环境有相同属性时,主环境属性生效;其他环境中有相同属性时,最后加载的环境属性生效

The following profiles are active: devDB,devMVC,dev

(3)

  • 从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

(4)小结

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

4.5 多环境开发控制

五、日志

5.1 日志基础

(1)日志(log)作用

  1. 编程期调试代码

  2. 运营期记录信息

    • 记录日常运营重要信息(峰值流量、平均响应时长……)
    • 记录应用报错信息(错误堆栈)
    • 记录运维过程数据(扩容、宕机、报警……)
      (2)代码中使用日志工具记录日志
      ①:先引入 Lombok 工具类
 <!--lombok-->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>

②:添加日志记录操作

  //创建记录日志的对象
    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.yan.controller,com.yan.service,com.yan.mapper
    iservice: com.alibaba
  level:
    root: info
    # 设置某个包的日志级别
    #    com.yan.controller: debug
    # 为对应组设置日志级别
    ebank: warn

5.2 快速创建日志对象

SpringBoot运维实用篇学习笔记_第18张图片
①:使用lombok提供的注解@Slf4j简化开发,减少日志对象的声明操作

@Slf4j
//Rest模式
@RestController
@RequestMapping("/books")
public class BookController {

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

}

②:小结

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

5.3 日志输出格式控制

SpringBoot运维实用篇学习笔记_第19张图片
(1)设置日志输出格式
①:

#设置日志模板格式
logging:
  pattern:
    console: "%d - %m%n"

%d:日期
%m:消息
%n:换行
SpringBoot运维实用篇学习笔记_第20张图片
②:

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

在这里插入图片描述

5.4 日志文件

(1)设置日志文件

logging:
  file:
    name: server.log

(2)日志文件详细配置

logging:
  file:
    name: server.log
  logback:
    rollingpolicy:
      max-file-size: 4KB
      file-name-pattern: server.%d{yyyy-MM-dd}.%i.log

在这里插入图片描述

(3)小结
①:日志记录到文件
②:日志文件格式设置

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