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.
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency>
#启用actuator端口 management.endpoints.enabled-by-default=fasle #设置actuator的访问根路径,默认是/actuator management.endpoints.web.base-path=/message #启用的端点 management.endpoints.web.exposure.include=loggers
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.
Method 1: (Recommended)
management.endpoints.web.exposure.include=loggers
Method 2: (Test in this way Not effective)
management.endpoint.loggers.enabled=true
Additional: How to disable the info port
management.endpoints.enabled-by-default=false management.endpoint.info.enabled=true
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.
ID | Description | Enabled by default |
---|---|---|
auditevents | Display the audit event information of the current application | Yes |
beans | Display a complete list of all Spring Beans in an application | Yes |
conditions | Display configuration and auto-configuration classes configuration classes) and the reasons why they are applied or not applied | Yes |
configprops | Display a collection list of all @ConfigurationProperties | Yes |
env | Display properties of ConfigurableEnvironment from Spring | Yes |
flyway | Display the database migration path, if any | Yes |
health | Display 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 |
info | Display any application information | Yes |
liquibase | Display any Liquibase database migration path, if any | Yes |
metrics | Display the metrics information of the current application | Yes |
mappings | Display a collection list of all @RequestMapping paths | Yes |
scheduledtasks | Display scheduled tasks in the application | Yes |
sessions | Allows 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 |
shutdown | Allow apps to shut down gracefully (not enabled by default) | No |
threaddump | Execute a thread dump | Yes |
ID | Description | Enabled by default |
---|---|---|
heapdum | Return a GZip compressed hprof heap dump file | Yes |
jolokia | Exposing JMX beans over HTTP (WebFlux is not available when Jolokia is on the classpath) | Yes |
logfile | Return 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 content | Yes |
Display metrics information in a format that can be crawled by the Prometheus server | Yes |
Default | |
---|---|
* | ##management.endpoints.jmx.exposure.include |
management.endpoints.web.exposure.exclude | |
##management.endpoints.web.exposure.include | |
*可以用来选择所有端点。 例如,要通过HTTP公开除env和beans端点之外的所有内容,请使用以下属性: management.endpoints.web.exposure.include=* management.endpoints.web.exposure.exclude=env,beans 三、关闭鉴权一般我们会将actuator和spring security鉴权组件结合使用,防止这些功能端口被随便调用。由于这里是功能演示,先放开actuator相关端口的权限认证。 此外,如果存在Spring Security,则需要添加自定义安全配置,以允许对端点进行未经身份验证的访问,如以下示例所示:放开所有Endpoint端点进行匹配 @Configuration public class ActuatorSecurity extends WebSecurityConfigurerAdapter { @Override protected void configure(HttpSecurity http) throws Exception { http.requestMatcher(EndpointRequest.toAnyEndpoint()).authorizeRequests() .anyRequest().permitAll() } } 四 、通过/loggers端口查看日志级别
注意上面我说过的,我调整了management.endpoints.web.base-path=/message。如果没有设置此参数,则使用默认的/actuator去访问。 五、发起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 大家可以在服务器上通过curl发起http请求,或者通过Postman发起请求。 curl -H "Content-Type: application/json" -X POST --data "{"configuredLevel": "DEBUG"}" http://localhost:8090/loggers/com.wxswj.provider.message.controller 六、查询日志级别修改结果
{ "configuredLevel": "DEBUG", "effectiveLevel": "DEBUG" } 说明我们的修改日志级别的请求生效。 |
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!