What is the operation of SpringBoot to dynamically modify the log level?
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>
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
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
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.
actuator’s endpoint port description:
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 |
If using web application (Spring MVC, Spring WebFlux, or Jersey), you can also use the following endpoints:
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 Copy after login 三、关闭鉴权一般我们会将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() } } Copy after login 四 、通过/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 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 六、查询日志级别修改结果
{ "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! 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
![]() Hot AI Tools![]() Undresser.AI UndressAI-powered app for creating realistic nude photos ![]() AI Clothes RemoverOnline AI tool for removing clothes from photos. ![]() Undress AI ToolUndress images for free ![]() Clothoff.ioAI clothes remover ![]() AI Hentai GeneratorGenerate AI Hentai for free. ![]() Hot Article
R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
3 weeks ago
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
3 weeks ago
By 尊渡假赌尊渡假赌尊渡假赌
Assassin's Creed Shadows: Seashell Riddle Solution
2 weeks ago
By DDD
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
3 weeks ago
By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: How To Unlock Everything In MyRise
3 weeks ago
By 尊渡假赌尊渡假赌尊渡假赌
![]() Hot Tools![]() Notepad++7.3.1Easy-to-use and free code editor ![]() SublimeText3 Chinese versionChinese version, very easy to use ![]() Zend Studio 13.0.1Powerful PHP integrated development environment ![]() Dreamweaver CS6Visual web development tools ![]() SublimeText3 Mac versionGod-level code editing software (SublimeText3) ![]() Hot Topics
CakePHP Tutorial
![]() ![]() ![]() Introduction to Jasypt Jasypt is a java library that allows a developer to add basic encryption functionality to his/her project with minimal effort and does not require a deep understanding of how encryption works. High security for one-way and two-way encryption. , standards-based encryption technology. Encrypt passwords, text, numbers, binaries... Suitable for integration into Spring-based applications, open API, for use with any JCE provider... Add the following dependency: com.github.ulisesbocchiojasypt-spring-boot-starter2. 1.1Jasypt benefits protect our system security. Even if the code is leaked, the data source can be guaranteed. ![]() Usage scenario 1. The order was placed successfully but the payment was not made within 30 minutes. The payment timed out and the order was automatically canceled. 2. The order was signed and no evaluation was conducted for 7 days after signing. If the order times out and is not evaluated, the system defaults to a positive rating. 3. The order is placed successfully. If the merchant does not receive the order for 5 minutes, the order is cancelled. 4. The delivery times out, and push SMS reminder... For scenarios with long delays and low real-time performance, we can Use task scheduling to perform regular polling processing. For example: xxl-job Today we will pick ![]() 1. Redis implements distributed lock principle and why distributed locks are needed. Before talking about distributed locks, it is necessary to explain why distributed locks are needed. The opposite of distributed locks is stand-alone locks. When we write multi-threaded programs, we avoid data problems caused by operating a shared variable at the same time. We usually use a lock to mutually exclude the shared variables to ensure the correctness of the shared variables. Its scope of use is in the same process. If there are multiple processes that need to operate a shared resource at the same time, how can they be mutually exclusive? Today's business applications are usually microservice architecture, which also means that one application will deploy multiple processes. If multiple processes need to modify the same row of records in MySQL, in order to avoid dirty data caused by out-of-order operations, distribution needs to be introduced at this time. The style is locked. Want to achieve points ![]() Springboot reads the file, but cannot access the latest development after packaging it into a jar package. There is a situation where springboot cannot read the file after packaging it into a jar package. The reason is that after packaging, the virtual path of the file is invalid and can only be accessed through the stream. Read. The file is under resources publicvoidtest(){Listnames=newArrayList();InputStreamReaderread=null;try{ClassPathResourceresource=newClassPathResource("name.txt");Input ![]() SpringBoot and SpringMVC are both commonly used frameworks in Java development, but there are some obvious differences between them. This article will explore the features and uses of these two frameworks and compare their differences. First, let's learn about SpringBoot. SpringBoot was developed by the Pivotal team to simplify the creation and deployment of applications based on the Spring framework. It provides a fast, lightweight way to build stand-alone, executable ![]() When Springboot+Mybatis-plus does not use SQL statements to perform multi-table adding operations, the problems I encountered are decomposed by simulating thinking in the test environment: Create a BrandDTO object with parameters to simulate passing parameters to the background. We all know that it is extremely difficult to perform multi-table operations in Mybatis-plus. If you do not use tools such as Mybatis-plus-join, you can only configure the corresponding Mapper.xml file and configure The smelly and long ResultMap, and then write the corresponding sql statement. Although this method seems cumbersome, it is highly flexible and allows us to ![]() 1. Customize RedisTemplate1.1, RedisAPI default serialization mechanism. The API-based Redis cache implementation uses the RedisTemplate template for data caching operations. Here, open the RedisTemplate class and view the source code information of the class. publicclassRedisTemplateextendsRedisAccessorimplementsRedisOperations, BeanClassLoaderAware{//Declare key, Various serialization methods of value, the initial value is empty @NullableprivateRedisSe ![]() In projects, some configuration information is often needed. This information may have different configurations in the test environment and the production environment, and may need to be modified later based on actual business conditions. We cannot hard-code these configurations in the code. It is best to write them in the configuration file. For example, you can write this information in the application.yml file. So, how to get or use this address in the code? There are 2 methods. Method 1: We can get the value corresponding to the key in the configuration file (application.yml) through the ${key} annotated with @Value. This method is suitable for situations where there are relatively few microservices. Method 2: In actual projects, When business is complicated, logic ![]() |