SpringCould-Admin

在项目运行时,偶尔需要排查问题,需要看日志信息,但是平常只开了info级别的,对于调试找问题不是很方便,所以需要改日志重启,这里在不重启的情况下修改springboot的日志级别

名词介绍

  • spring-boot-starter-actuator 是监控springboot的健康情况的一个依赖工具包

    包含三类功能

    1. 应用配置:日志级别、环境变量等
    2. 度量指标:心跳、内存、中间件状态
    3. 操作控制:重启、更新配置等

简单实现动态修改日志级别

  1. 引入依赖

    1
    implementation 'org.springframework.boot:spring-boot-starter-actuator'
  2. 配置loggers接口,这里分别开了三个接口/actuator/loggers/actuator/info/actuator/health

    1
    management.endpoints.web.exposure.include=loggers,health,info
  3. 访问GET /actuator/loggers就可以得到所有包的日志级别了

    ce6aE8.png

  4. 查询特定包的日志级别GET /actuator/loggers/<package path>

    1
    2
    3
    4
    5
    6
    7
    # GET /actuator/loggers/com.exxk.adminClient
    ---------------------------------------------
    # RETURN
    {
    "configuredLevel": null,
    "effectiveLevel": "INFO"
    }
  5. 修改特定包的日志级别POST /actuator/loggers/<package path>然后添加 BODY JSON 内容{"configuredLevel": "DEBUG"},请求成功后对应包的日志级别就改变了,访问就会输出设置的日志级别的日志了

    1
    2
    3
    4
    5
    6
    7
    # POST /actuator/loggers/com.exxk.adminClient
    # BODY
    {
    "configuredLevel": "DEBUG"
    }
    -----------------------------------------------
    # RETURN 204 No Content

Spring Boot Admin可视化管理服务

官方文档

服务端配置

方案一(原生版本):

  1. 引入依赖,注意版本号要和spring boot的版本一致,不然启动会报错

    1
    2
    // https://mvnrepository.com/artifact/de.codecentric/spring-boot-admin-starter-server
    implementation group: 'de.codecentric', name: 'spring-boot-admin-starter-server', version: '2.2.2'
  2. 在启动类上面添加注解@EnableAdminServer

  3. 运行,然后访问http://127.0.0.1:8080

添加用登陆校验 (未配置完,暂时不需要)
  1. 添加依赖

    1
    2
    3
    // https://mvnrepository.com/artifact/de.codecentric/spring-boot-admin-server-ui-login
    implementation group: 'de.codecentric', name: 'spring-boot-admin-server-ui-login', version: '1.5.7'
    implementation 'org.springframework.boot:spring-boot-starter-security'
  2. 添加Spring Security配置

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    @Configuration(proxyBeanMethods = false)
    public class SecuritySecureConfig extends WebSecurityConfigurerAdapter {

    private final AdminServerProperties adminServer;

    public SecuritySecureConfig(AdminServerProperties adminServer) {
    this.adminServer = adminServer;
    }

    @Override
    protected void configure(HttpSecurity http) throws Exception {
    SavedRequestAwareAuthenticationSuccessHandler successHandler = new SavedRequestAwareAuthenticationSuccessHandler();
    successHandler.setTargetUrlParameter("redirectTo");
    successHandler.setDefaultTargetUrl(this.adminServer.path("/"));

    http.authorizeRequests(
    (authorizeRequests) -> authorizeRequests.antMatchers(this.adminServer.path("/assets/**")).permitAll()
    .antMatchers(this.adminServer.path("/login")).permitAll().anyRequest().authenticated()
    ).formLogin(
    (formLogin) -> formLogin.loginPage(this.adminServer.path("/login")).successHandler(successHandler).and()
    ).logout((logout) -> logout.logoutUrl(this.adminServer.path("/logout"))).httpBasic(Customizer.withDefaults())
    .csrf((csrf) -> csrf.csrfTokenRepository(CookieCsrfTokenRepository.withHttpOnlyFalse())
    .ignoringRequestMatchers(
    new AntPathRequestMatcher(this.adminServer.path("/instances"),
    HttpMethod.POST.toString()),
    new AntPathRequestMatcher(this.adminServer.path("/instances/*"),
    HttpMethod.DELETE.toString()),
    new AntPathRequestMatcher(this.adminServer.path("/actuator/**"))
    ))
    .rememberMe((rememberMe) -> rememberMe.key(UUID.randomUUID().toString()).tokenValiditySeconds(1209600));
    }

    // Required to provide UserDetailsService for "remember functionality"
    @Override
    protected void configure(AuthenticationManagerBuilder auth) throws Exception {
    auth.inMemoryAuthentication().withUser("user").password("{noop}password").roles("USER");
    }

    }
  3. 在配置文件设置密码

    1
    2
    spring.boot.admin.client.username=admin
    spring.boot.admin.client.password=admin

方案二(docker版本):

直接采用官方镜像codecentric/spring-boot-admin运行

1
2
3
4
5
6
docker run -d \
-p 8080:8080 \
-e "server.port=8080" \
-e "spring.boot.admin.client.instance.service-base-url=http://172.16.10.44:31736" \
--name spring-boot-admin \
codecentric/spring-boot-admin:2.7.9

然后访问http://本地ip或映射的外网ip:8080

客户端配置

方案一(原生版本):

  1. 添加依赖

    1
    implementation group: 'de.codecentric', name: 'spring-boot-admin-starter-client', version: '2.2.2'
  2. 添加配置

    1
    2
    3
    4
    5
    spring.boot.admin.client.url=http://localhost:8080
    #生产根据需要开放端口,*代表全部开放
    management.endpoints.web.exposure.include=*
    #健康信息显示所有
    management.endpoint.health.show-details=always
  3. 启动运行,就可以看到该springboot已经注册到了admin server里面去了,可以去日志配置界面动态修改日志级别了

    ceLZ7D.png

方案二(docker版本):

  1. 添加依赖

    1
    2
    3
    4
    5
    6
    <!-- 大版本号2.7.x要和服务端2.7.x一致 -->
    <dependency>
    <groupId>de.codecentric</groupId>
    <artifactId>spring-boot-admin-starter-client</artifactId>
    <version>2.7.15</version>
    </dependency>
  2. 添加springboot配置

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    spring:
    boot:
    admin:
    client:
    # 默认关闭,启用的时候可以通过设置环境变量开起
    enabled: false
    url: http://172.16.10.44:31736
    # 客户端信息配置,配置注册到服务端,客户端的名字,及自己的地址
    instance:
    name: ${DEVICE_NAME:AiBOX}
    #因为在容器里面,默认的地址是容器内的地址,服务端访问不到,需要手动指定容器的外网地址
    service-base-url: http://${HOST_ADDRESS:172.16.10.202}:8080
    management:
    endpoints:
    web:
    exposure:
    include: '*'
    metrics:
    enable:
    jvm.threads: true

常见问题

  1. /actuator/httptrace网络接口追踪404,解决建议用Sleuth