SpringBoot运维实用篇

SpringBoot运维实用篇

打包与运行

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

步骤

  1. 对SpingBoot项目打包(执行MAven构建指令package)
mvn package
  1. 运行项目(执行启动指令)
java -jar 工程名.jar

注意事项

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

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

打包插件

· spring-boot-maven-plugins插件作用

· jar包描述文件(MANIFEST.MF)

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-bHB2tli0-1646815543624)(C:\Users\maybe3032\AppData\Roaming\Typora\typora-user-images\image-20220308214629645.png)]

· windows端口被占用

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-o2NBYjuU-1646815543625)(C:\Users\maybe3032\AppData\Roaming\Typora\typora-user-images\image-20220308214717130.png)]

SpringBoot项目快速启动(Linux)

  1. 上传安装包
  2. 执行jar命令:java -jar 工程名.jar

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Sy1XvMJd-1646815543625)(C:\Users\maybe3032\AppData\Roaming\Typora\typora-user-images\image-20220308215809095.png)]

总结

  1. Boot程序打包依赖SpringBoot对应的Maven插件既可打包出可执行的jar包
  2. 运行jar包使用jar命令执行
  3. Windows与Linux下执行Boot打包程序流程相同,仅需确保运行环境有效即可

配置高级

临时配置设置

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

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-X1MJGObu-1646815543626)(C:\Users\maybe3032\AppData\Roaming\Typora\typora-user-images\image-20220308220938096.png)]

临时配置设置(开发环境中)
  1. 启动SpringBoot程序时,可以选择是否使用命令行属性为SpringBoot程序传递启动属性

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

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-pKieCJHf-1646815543626)(C:\Users\maybe3032\AppData\Roaming\Typora\typora-user-images\image-20220308221426360.png)]

· 通过编程形式带参数启动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. 项目类路径配置文件:服务于开发人员本机开发于测试
    1. 项目类路径config目录中配置文件:服务于项目经理整体调控
    2. 工程路径配置文件:服务于运维人员配置涉密线上环境
    3. 工程路径config目录中配置文件:服务于运维经理整体调控
  2. 多层级配置文件间的属性采用叠加并覆盖的形式作用于程序
4种配置文件

1级:file: config/appilcation.yml

2级:file: appilcation.yml

3级:classpath : config/appilcation.yml

4级:classpath : config/appilcation.yml

自定义配置文件

  1. 配置文件可以修改名称,通过启动参数设定(无需书写配置文件扩张名)

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-QZV72fe4-1646815543626)(C:\Users\maybe3032\AppData\Roaming\Typora\typora-user-images\image-20220309143621828.png)]

  1. 配置文件可以修改路径,通过启动参数设定(yml和properties都支持),也可以加载多个配置文件

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-67OkyqOt-1646815543627)(C:\Users\maybe3032\AppData\Roaming\Typora\typora-user-images\image-20220309143656577.png)]

  1. 微服务开发中配置文件通过配置中心进行设置

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-WRxsnFm4-1646815543627)(C:\Users\maybe3032\AppData\Roaming\Typora\typora-user-images\image-20220309143829844.png)]

多环境开发

多环境开发(YAML版)

  1. 多环境开发需要设置若干种常用环境,例如开发、生产、测试环境
  2. yaml格式中设置多环境使用(—)区分环境设置边界
  3. 每种环境的区别在于加载的配置属性不同
  4. 启用某种环境时需要指定启动时使用该环境
//启动指定环境
spring:
 profiles:
  active:pro
---
//设置生产环境
spring:
 config:
  activate:
  on-profile:pro
server:
 port:80  
---
//设置开发环境
spring:
 config:
  activate:
  on-profile:dev
server:
 port:81
---
//设置测试环境
spring:
 config:
  activate:
  on-profile:test
server:
 port:82
多配置文件格式
  1. 可以使用独立配置文件定义环境属性
  2. 独立配置文件便于线上系统维护更新并保证系统安全性

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GX7xLJcb-1646815543628)(C:\Users\maybe3032\AppData\Roaming\Typora\typora-user-images\image-20220309151401523.png)]

多环境开发(Properties版)

  1. properties文件多环境配置仅支持多文件格式

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-9zfrl7Qd-1646815543629)(C:\Users\maybe3032\AppData\Roaming\Typora\typora-user-images\image-20220309151628074.png)]

多环境开发控制

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

    # 使用group属性定义多种主环境与子环境的包含关系
    spring:
     profiles:
      active:dev
      group:
       "dev": devDB,devRedis,devMVC
       "pro": proDB,proRedis,proMVC
       "test": testDB,testRedis,testMVC
    
多环节冲突
  1. 当Maven与SpringBoot同时对多环境进行控制时,以Maven为主,SpringBoot使用@…@占位符读取Maven对应的配置属性值
  2. 基于SpringBoot读取Maven配置属性的前提下,如果在Idea下测试工程时pom.xml每次更新需要手动compile方可生效
<!--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>

日志

日志基础

  1. 日志用于记录开发调试与运维过程信息
  2. 日志的级别共6种,通常使用4种即可,分别是DEBUG、INFO、WARN、ERROR
  3. 可以通过日志组或代码包的形式进行日志显示级别的控制
//添加日志记录操作
@RestController
@RequestMappng("/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("");
        log.info("");
        log.warn("");
        log.error("");
        return "springboot is running...";
    }
}
日志级别

· TRACE:运行堆栈信息,使用率低

· DEBUG:程序员调试代码使用

· INFO: 记录运维过程数据

· WARN:记录运维过程报警数据

· ERROR:记录错误堆栈信息

· FATAL:灾难信息,合并计入ERROR

# 开启debug模式,输出调试信息,常用于检查系统运行状况
debug: true

# 设置日志级别,root表示根节点,即整体应用日志级别
logging:
 level:
  root: debug
  
# 设置日志组
logging:
 group:
  #自定义组名,设置当前组中所包含的包
  ebank: com.xxx.xxx
 level:
  root: warn
 
 # 为对应组设置日志级别
  ebank: debug
  
  # 为对包设置日志级别
  ebank: com.xxx.xxx:debug
快速创建日志对象

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

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

日志输出格式控制

· 设置日志输出格式

logging:
 pattern:
  console: "%d - %m%n"

· %d: 日期

· %m: 消息

· %n: 换行

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

日志文件

  1. 设置日志文件
logging:
 file:
  name: server.log
  1. 日志文件详细配置
logging:
 file:
  name: server.log
 logback:
  rollingpolicy:
   max-file-size: 3KB
   file-name-pattern: server.%d{yyyy-MM-dd}.%i.log
   #避免日志文件过大
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值