spring boot运维基础笔记

运维篇


打包与运行

程序打包与运行 (windows版 )

  • Spring Boot工程可以基于Java环境下独立运行jar文件启动服务

  • 对Spring Boot项目打包 (执行Maven构建指令package进行打包)

    mvn package
    
  • 运行项目 (cmd中执行启动指令)

    java -jar 工程名.jar
    
  • 注意事项

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

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

程序运行(Linux版)

Windows与Linux下执行Boot打包程序流程相同,仅需确保运行环境有效即可
基于Linux(CenterOS7)
1.上传安装包
2.执行jar命令: java -jar 工程名.jar

安装JDK,且版本不低于打包时使用的JDK版本

安装包保存在/usr/local/自定义目录中或$HOME下

其他操作参照windows版进行

命令行启动常见问题及解决方案

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

配置高级

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

临时属性(参数)设置

  • 命令窗口环境启动spring boot程序
带属性数启动SpringBoot

    java -jar 工程名.jar --server.port=8080(server.port=8080:修改服务器端口为8080)
    
    java -jar 工程名.jar --属性名=值

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

临时属性必须是当前boot工程支持的属性,否则设置无效
  • idea带属性启动Spring Boot程序,为程序添加运行属性

在这里插入图片描述

配置文件分类

  • Spring Boot中4级配置文件

    等级权限
    1级file : config/application.yml工程路径config目录中配置文件: 服务于运维经理整体调控[最高]
    2级file : application.yml工程路径配置文件:服务于运维人员配置涉密线上环境
    3级classpath: config/application.ym]类路径config目录中配置文件: 服务于项目经理整体调控
    4级:classpath: application.yml项目类路径配置文件:服务于开发人员本机开发与测试项目[最低]
  • 作用:

    • 1级与2级留做系统打包后设置通用属性,1级常用于运维经理进行线上整体项目部署方案调控
    • 3级与4级用于系统开发阶段设置通用属性,3级常用于项目经理进行整体项目属性调控
  • 多层级配置文件间的属性采用叠加并覆盖的形式作用于程序

自定义配置文件

  • 通过启动参数加载配置文件(无需书写配置文件扩展名)

    在这里插入图片描述

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

    在这里插入图片描述

  • 注意事项

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

多环境开发

多环境开发 (YAML版)

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

    1.可以使用独立配置文件定义环境属性
    2.独立配置文件便于线上系统维护更新并保障系统安全性
    
    • 主启动配置文件application.yml

      spring:
       profiles:
         active: dev
      
    • 环境分类配置文件application-pro.yml

      server:
        port: 80
      
    • 环境分类配置文件application-dev.ym]

      server:
        port: 81
      
    • 环境分类配置文件application-test.ym]

      server: 
        port: 82
      
  • 多环境开发配置文件书写技巧 (一)

    • 主配置文件中设置公共配置(全局)
    • 环境分类配置文件中常用于设置冲突属性(局部)
  • 多环境开发独立配置文件书写技巧 (二)

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

      application-devDB.yml
      application-devRedis.yml
      application-devMVC.yml
      
    • 使用include属性在激活指定环境的情况下,同时对多个环境进行加载使其生效,多个环境间使用逗号分隔

      spring:
       profiles:
        active: dev
        include: devDB,devRedis,devMVC
      
      • 注意事项
        当主环境dev与其他环境有相同属性时,主环境属性生效,其他环境中有相同属性时,最后加载的环境属性生效
    • 从Spring Boot 2.4版开始使用group属性替代include属性,降低了配置书写量

    • 使用group属性定义多种主环境与子环境的包含关系

      spring:
       profiles:
        active: dev
        group :
         "dev": devDB,devRedis,devMVC
         "pro": proDB,proRedis,proMVC
         "test": testDB,testRedis,testMVC
      

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

多环境开发 (Properties版)

  • 多环境开发和yml版的开发环境基本相似,简略了

多环境开发控制

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

    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. Spring Boot中引用Maven属性

      spring:
       profiles:
        active: @profile.active@
      

      之后会根据定义默认的true去读取

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

日志

日志基础

  • 代码中使用日志工具记录日志的控制
1.日志用于记录开发调试与运维过程消息
2.日志的级别共6种,通常使用4种即可,分别是DEBUG,INFO,WARN,ERROR
3.可以通过日志组或代码包的形式进行日志显示级别
  1. 添加日志记录操作

    @RestController
    @RequestMapping("/books")
    public class BookController extends BaseController {
      private static final Logger log = LoggerFactory.getlogger(BookController.class);
        @GetMapping
        public String getById(){
            System.out.printIn("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.test.controller
     level:
      root: warn
      #为对应组设置日志级别
      ebank: debug
      #为对包设置日志级别
      com.test.controller: debug
    
优化日志对象创建代码

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

日志输出格式控制

设置日志输出格式
logging:
 pattern:
  console: "%d - %m%n"
  • %d:日期
  • %m:消息
  • %n: 换行
  • %p:日志级别

日志文件

设置日志文件
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
  • 20
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值