栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Spring Boot 2 运维实用篇学习笔记

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Spring Boot 2 运维实用篇学习笔记

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工程的需求
51-工程打包与运行 程序为什么要打包

将程序部署在独立的服务器上

SpringBoot项目快速启动(Windows版) 步骤

①:对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

打包优化:跳过 test 生命周期


小结:
  1. SpringBoot工程可以基于java环境下独立运行jar文件启动服务
  2. SpringBoot工程执行mvn命令package进行打包
  3. 执行jar命令:java –jar 工程名.jar
52-打包插件

如果没有配制spring boot 打包插件可能遇到下面的问题:

  • 使用SpringBoot提供的maven插件可以将工程打包成可执行jar包
    
        
            
                org.springframework.boot
                spring-boot-maven-plugin
            
        
    
可执行jar包目录结构

jar包描述文件(MANIFEST.MF)
  • 普通工程
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 的进程。
小结:
  1. spring-boot-maven-plugin插件作用
  2. Windonws端口被占用
53-Boot工程快速启动(Linux版)

  • 基于Linux(CenterOS7)
  • 安装JDK,且版本不低于打包时使用的JDK版本
    • 可以使用 yum 安装
  • 安装 MySQL
    • 可以参考: https://blog.csdn.net/qq_42324086/article/details/120579197
  • 安装包保存在/usr/local/自定义目录中或$HOME下
  • 其他操作参照Windows版进行
启动成功无法访问 添加 80 端口
  • 添加 端口
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]# 

小结:
  1. 上传安装包
  2. 执行jar命令:java –jar 工程名.jar
总结:
  1. Boot程序打包依赖SpringBoot对应的Maven插件即可打包出可执行的jar包
  2. 运行jar包使用jar命令进行
  3. Windows与Linux下执行Boot打包程序流程相同,仅需确保运行环境有效即可
54-临时属性

  • 带属性数启动SpringBoot
java -jar springboot_08_ssmp-0.0.1-SNAPSHOT.jar --server.port=8080
  • 携带多个属性启动SpringBoot,属性间使用空格分隔
属性加载优先顺序
  1. 参看 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工程支持的属性,否则设置无效
55-临时属性(开发环境)

  • 带属性启动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);
}

小结:

  1. 启动SpringBoot程序时,可以选择是否使用命令行属性为SpringBoot程序传递启动属性
56-配置文件4级分类

配置文件分类
  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 【最低】
  2. 作用:
    1. 1级与2级留做系统打包后设置通用属性,1级常用于运维经理进行线上整体项目部署方案调控
    2. 3级与4级用于系统开发阶段设置通用属性,3级常用于项目经理进行整体项目属性调控

思 考:
如果yml与properties在不同层级中共存会是什么效果?
例:类路径application.properties属性是否覆盖文件系统config目录中application.yml属性
properties文件的优先级大于yml文件 (properties文件会覆盖yml文件的配制)

小结:

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

  • 通过启动参数加载配置文件(无需书写配置文件扩展名) --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技术,所有的服务器将不再设置配置文件,而是通过配置中心进行设定,动态加载配置信息

小结:

  1. 配置文件可以修改名称,通过启动参数设定
  2. 配置文件可以修改路径,通过启动参数设定
  3. 微服务开发中配置文件通过配置中心进行设置

总结:

  1. SpringBoot在开发和运行环境均支持使用临时参数修改工程配置
  2. SpringBoot支持4级配置文件,应用于开发与线上环境进行配置的灵活设置
  3. SpringBoot支持使用自定义配置文件的形式修改配置文件存储位置
  4. 基于微服务开发时配置文件将使用配置中心进行管理
58-多环境开发(yaml版)

多环境

多环境开发(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

小结:

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

多环境开发(YAML版)多配置文件格式
  1. 主启动配置文件application.yml
#应用环境
#公共配制
spring:
  profiles:
    active: test

  1. 环境分类配置文件application-pro.yml
server:
  port: 81
  1. 环境分类配置文件application-dev.yml
server:
  port: 82
  1. 环境分类配置文件application-test.yml
server:
  port: 83
多环境开发配置文件书写技巧(一)
  • 主配置文件中设置公共配置(全局)
  • 环境分类配置文件中常用于设置冲突属性(局部)

小结:

  1. 可以使用独立配置文件定义环境属性
  2. 独立配置文件便于线上系统维护更新并保障系统安全性
60-多环境开发多文件版(properties版)
  • 主启动配置文件application.properties
spring.profiles.active=dev
  • 环境分类配置文件application-pro.properties
server.port=9081
  • 环境分类配置文件application-dev.properties
server.port=9082
  • 环境分类配置文件application-test.properties
server.port=9083

小结:

  1. properties文件多环境配置仅支持多文件格式
61-多环境分组管理 多环境开发独立配置文件书写技巧(二)
  • 根据功能对配置文件中的信息进行拆分,并制作成独立的配置文件,命名规则如下
    • 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

小结:

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


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进行自动编译

小结:

  1. 当Maven与SpringBoot同时对多环境进行控制时,以Mavn为主,SpringBoot使用@…@占位符读取Maven对应的配置属性值
  2. 基于SpringBoot读取Maven配置属性的前提下,如果在Idea下测试工程时pom.xml每次更新需要手动compile方可生效

总结:

  1. 多环境开发(YAML版)
  2. 多环境开发(Properties版)
  3. Maven与SpringBoot多环境冲突现象解决方案
63-日志基础操作

日志(log)作用

  1. 编程期调试代码
  2. 运营期记录信息
  • 记录日常运营重要信息(峰值流量、平均响应时长……)
  • 记录应用报错信息(错误堆栈)
  • 记录运维过程数据(扩容、宕机、报警……)

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

  • 先引入 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

小结:

  1. 日志用于记录开发调试与运维过程消息
  2. 日志的级别共6种,通常使用4种即可,分别是DEBUG,INFO,WARN,ERROR
  3. 可以通过日志组或代码包的形式进行日志显示级别的控制
64-教你一招:快速创建日志对象

  • 使用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";
    }

}

小结:

  1. 基于lombok提供的@Slf4j注解为类快速添加日志对象
65-日志输出格式控制

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

小结:

  1. 日志输出格式设置规则
66-文件记录日志(运维实用篇完结)
  • 设置日志文件
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

小结:

  1. 日志记录到文件
  2. 日志文件格式设置

总结:

  1. 日志基础使用规则
  2. 编辑日志输出格式
  3. 日志文件设置
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/531711.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号