Home > Java > javaTutorial > What is the operation of SpringBoot to dynamically modify the log level?

What is the operation of SpringBoot to dynamically modify the log level?

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Release: 2023-05-14 08:25:13
forward
1753 people have browsed it

The traditional approach is generally:

1. Modify the log level in the configuration

2. Restart the application

3. Check the error log to troubleshoot the problem when the problem occurs

This process requires restarting the application, which is more troublesome and less efficient. Moreover, for large-scale online projects, it is impossible to stop and restart at will. So is there a way to dynamically change the log level without restarting the application?

Now, let Lao Wan teach you how to dynamically modify the log level through SpringBoot's actuator component.

1. Add dependencies

<dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
Copy after login

2. Configure the port exposed by actuator

#启用actuator端口
management.endpoints.enabled-by-default=fasle
#设置actuator的访问根路径,默认是/actuator
management.endpoints.web.base-path=/message
#启用的端点
management.endpoints.web.exposure.include=loggers
Copy after login

Here I modified the default access path of actuator/actuator to /message, for It is saved consistent with the basic access path of the project.

Two configuration methods to enable the port:

Method 1: (Recommended)

management.endpoints.web.exposure.include=loggers
Copy after login

Method 2: (Test in this way Not effective)

management.endpoint.loggers.enabled=true
Copy after login

Additional: How to disable the info port

management.endpoints.enabled-by-default=false
management.endpoint.info.enabled=true
Copy after login

About the actuator component, it is called one of the four major components of spring boot and has powerful functions. Everyone can find some information on the Internet to learn more.

actuator’s endpoint port description:

IDDescriptionEnabled by default
auditeventsDisplay the audit event information of the current applicationYes
beansDisplay a complete list of all Spring Beans in an applicationYes
conditionsDisplay configuration and auto-configuration classes configuration classes) and the reasons why they are applied or not appliedYes
configpropsDisplay a collection list of all @ConfigurationPropertiesYes
envDisplay properties of ConfigurableEnvironment from SpringYes
flywayDisplay the database migration path, if anyYes
healthDisplay the health information of the application (when A simple "status" is displayed when accessing using an unauthenticated connection, and full information details are displayed when accessing using an authenticated connection)Yes
infoDisplay any application informationYes
liquibaseDisplay any Liquibase database migration path, if anyYes
metricsDisplay the metrics information of the current applicationYes
mappingsDisplay a collection list of all @RequestMapping pathsYes
scheduledtasksDisplay scheduled tasks in the applicationYes
sessionsAllows the retrieval and deletion of user sessions from the session store supported by Spring sessions. Not available when using Spring Session's support for reactive web applications. Yes
shutdownAllow apps to shut down gracefully (not enabled by default)No
threaddumpExecute a thread dumpYes

If using web application (Spring MVC, Spring WebFlux, or Jersey), you can also use the following endpoints:

##prometheus Display metrics information in a format that can be crawled by the Prometheus serverYes
IDDescriptionEnabled by default
heapdumReturn a GZip compressed hprof heap dump fileYes
jolokia Exposing JMX beans over HTTP (WebFlux is not available when Jolokia is on the classpath) Yes
logfileReturn Log file content (if the logging.file or logging.path attribute is set), supports using the HTTP Range header to receive partial information about the log file contentYes
To change which endpoints are exposed, use the following technique Specific include and exclude properties:

##Propertymanagement. endpoints.jmx.exposure.exclude##management.endpoints.jmx.exposure.include*management.endpoints.web.exposure.exclude*info, health
Default
*
##management.endpoints.web.exposure.include

include属性列出了公开的端点的ID,

exclude属性列出了不应该公开的端点的ID

exclude属性优先于include属性。包含和排除属性都可以使用端点ID列表进行配置。

*可以用来选择所有端点。

例如,要通过HTTP公开除env和beans端点之外的所有内容,请使用以下属性:

management.endpoints.web.exposure.include=*
management.endpoints.web.exposure.exclude=env,beans
Copy after login

三、关闭鉴权

一般我们会将actuator和spring security鉴权组件结合使用,防止这些功能端口被随便调用。由于这里是功能演示,先放开actuator相关端口的权限认证。

What is the operation of SpringBoot to dynamically modify the log level?

此外,如果存在Spring Security,则需要添加自定义安全配置,以允许对端点进行未经身份验证的访问,如以下示例所示:放开所有Endpoint端点进行匹配

@Configuration
public class ActuatorSecurity extends WebSecurityConfigurerAdapter {
 
@Override
protected void configure(HttpSecurity http) throws Exception {
    http.requestMatcher(EndpointRequest.toAnyEndpoint()).authorizeRequests()
    .anyRequest().permitAll()
}

}
Copy after login

四 、通过/loggers端口查看日志级别

请求链接:http://localhost:8090/message/loggers

注意上面我说过的,我调整了management.endpoints.web.base-path=/message。如果没有设置此参数,则使用默认的/actuator去访问。

What is the operation of SpringBoot to dynamically modify the log level?

五、发起http请求修改日志级别

这里演示,修改目录com.wxswj.provider.message.controller的日志级别为debug

请求类型为POST,参数格式是JSON

curl -H "Content-Type: application/json" -X POST --data 
"
{
    "configuredLevel": "DEBUG"
}
" 
http://localhost:8090/message/loggers/com.wxswj.provider.message.controller
Copy after login

大家可以在服务器上通过curl发起http请求,或者通过Postman发起请求。

curl -H "Content-Type: application/json" -X POST --data "{"configuredLevel": "DEBUG"}" http://localhost:8090/loggers/com.wxswj.provider.message.controller
Copy after login

六、查询日志级别修改结果

http://localhost:8090/message/loggers/com.wxswj.provider.message.controller

{
"configuredLevel": "DEBUG",
"effectiveLevel": "DEBUG"
}
Copy after login

说明我们的修改日志级别的请求生效。

The above is the detailed content of What is the operation of SpringBoot to dynamically modify the log level?. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:yisu.com
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template