slf4j 如何返回堆栈_Vertx 集成 SLF4J + Log4j2

Vertx 集成 SLF4J + Log4j2

本篇主要讲解 Vertx 中 如何集成日志 ,我选择的日志是 SLF4J + Log4j2 ,我也是比较推荐这种

因为在默认情况下,vert.x 会使用 Java 默认的日志 JULJava Util Log,并读取 resource 下的 vertx-default-jul-logging.properties 文件并且不需要加任何依赖 很显然这种方式其实并不好

如果我们想用 Log4j2 + SLF4J 的组合,直接选择 log4j-slf4j-impl 或者 log4j-slf4j18-impl 即可。这里当然选用 log4j-slf4j18-impl 使用最新版本 2.13.0。它包含如下依赖:

  • org.slf4j:slf4j-api:1.8.0-alpha2

  • org.apache.logging.log4j:log4j-api:2.13.0

  • org.apache.logging.log4j:log4j-core:2.13.0

这三个依赖已经包含了我们所有需要引入的东西。

fea611311815dccd5f6226f2f291a665.png

引入依赖

// https://mvnrepository.com/artifact/org.apache.logging.log4j/log4j-slf4j18-impl//注意 一定要 compile 不能是 testCompile 否则启动 绑定不上compile group: 'org.apache.logging.log4j', name: 'log4j-slf4j18-impl', version: '2.11.1'

日志框架加载顺序

从 vert.x 4 的官网文档中可以明确知道,他加载的顺序如下:

  1. 系统环境是否设置了 vertx.logger-delegate-factory-class-name,如果有,就是用设置的值。

  2. JUL 的配置文件 vertx-default-jul-logging.properties 是否在 classpath

  3. 如果上面都没有,就在 classPath 下按照顺序查找以下包是否存在

    1. SLF4J

    2. Log4J

    3. Log4J2

如果以上都没有,使用 vert.x 默认的 JUL 配置。

所以 vert.x 4 中,是不需要我们去手动设置 vertx.logger-delegate-factory-class-name 参数了,他会默认去加载 classpath 下的日志库的。因此我们需要添加相关的依赖。

Log4j2.xml 文件配置

log4j2.xml 放在 resources 下面 下面是我使用的 Log4j2.xml 文件 网上也有其他的 可以自己配置

<?xml  version="1.0" encoding="UTF-8"?><configuration status="info" packages="org.ysten.gdog.log4j2">    <Properties>                <Property name="LOG_PATH">/Users/johnny/Downloads/logs/Property>                <Property name="APP_NAME">vertx-demoProperty>                <Property name="MAX_FILE_SIZE">50MBProperty>                <Property name="I_MAX">40Property>                <Property name="PATTERN_LAYOUT">%d [%X{traceId}] [%t] %level (%F %M %L) - %msg%nProperty>        <Property name="CONSOLE_LAYOUT"                  value="%style{%d{yyyy-MM-dd HH:mm:ss.SSS}}{Blue,Bright} %highlight{${LOG_LEVEL_PATTERN:-%5p}}{FATAL=bg_red, ERROR=red, WARN=yellow, INFO=green, DEBUG=grey, TRACE=blue} %style{%pid}{magenta} --- %style{[%4.15t] %-10.40c{1.}}{cyan,Bright} : %m%n%ex"/>    Properties>    <appenders>        <Console name="CONSOLE" target="SYSTEM_OUT">            <PatternLayout pattern="${CONSOLE_LAYOUT}" />        Console>        <RollingFile name="ERROR-FILE"                     fileName="${LOG_PATH}/${APP_NAME}_error.log"                     filePattern="${LOG_PATH}/$${date:yyyy-MM}/${APP_NAME}_error_%d{yyyy-MM-dd}_%i.log">            <Filters>                <ThresholdFilter level="ERROR" onMatch="ACCEPT" onMismatch="DENY"/>            Filters>            <PatternLayout pattern="${PATTERN_LAYOUT}"/>            <Policies>                <TimeBasedTriggeringPolicy/>                <SizeBasedTriggeringPolicy size="${MAX_FILE_SIZE}"/>            Policies>            <DefaultRolloverStrategy max="${I_MAX}"/>        RollingFile>        <RollingFile name="INFO-FILE"                     fileName="${LOG_PATH}/${APP_NAME}_info.log"                     filePattern="${LOG_PATH}/$${date:yyyy-MM}/${APP_NAME}_info_%d{yyyy-MM-dd}_%i.log">            <PatternLayout pattern="${PATTERN_LAYOUT}"/>            <Policies>                <TimeBasedTriggeringPolicy/>                <SizeBasedTriggeringPolicy size="${MAX_FILE_SIZE}"/>            Policies>            <DefaultRolloverStrategy max="${I_MAX}"/>        RollingFile>    appenders>    <loggers>        <Root level="INFO" includeLocation="true">            <appender-ref ref="CONSOLE" />            <appender-ref ref="ERROR-FILE" />            <appender-ref ref="INFO-FILE" />        Root>    loggers>configuration>

测试代码

import org.slf4j.Logger;import org.slf4j.LoggerFactory;private static Logger log4jLogger2 = LoggerFactory.getLogger(VertxDemo.class);public static void main(String[] args) {        Vertx vertx = Vertx.vertx();      log4jLogger2.info("Hello SLF4J2");    vertx.createHttpServer()            .requestHandler(requestHandler -> {                //获取到 Response 直接返回消息                requestHandler.response().end("Hello Vertx !!!");            })            //监听在 8899 端口            .listen(8899);}

cb24ce56760d35b6afd0755ede2f5501.png

总结

本篇主要讲解 Vertx 中 如何集成日志,选择的是 Log4j2 + SLF4J 方法很简单 ,主要来记录一下。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Spring Boot可以很方便地集成SLF4JLog4j2。以下是集成步骤: 1. 在pom.xml文件中添加以下依赖: ``` <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-log4j2</artifactId> </dependency> ``` 2. 在application.properties文件中配置日志级别和日志输出路径: ``` logging.level.root=INFO logging.file=/var/log/myapp.log ``` 3. 在代码中使用SLF4J进行日志记录: ``` import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class MyClass { private static final Logger logger = LoggerFactory.getLogger(MyClass.class); public void doSomething() { logger.info("Doing something..."); } } ``` 以上就是Spring Boot集成SLF4JLog4j2的简单步骤。 ### 回答2: Spring Boot是一个开发web应用和微服务的框架,而SLF4JLog4j2是一种记录日志信息的工具。将SLF4JLog4j2这两种工具集成到Spring Boot应用中可以方便地进行日志记录。 SLF4J是一个抽象的日志接口,它允许您在不更改应用程序代码的情况下更改底层日志记录器。Log4j2是一个快速、灵活且配置方便的日志组件,它可以完全控制日志记录和输出。 在Spring Boot集成SLF4JLog4j2之前,需要在pom.xml文件中添加以下依赖项: ``` <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-log4j2</artifactId> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> </dependency> ``` 以上依赖项将引入Spring Boot和Log4j2所需的库。 在应用程序的配置文件application.yaml中,需要添加以下内容: ``` logging: config: log4j2.xml ``` 以上内容将告诉Spring Boot使用Log4j2记录日志,并使用log4j2.xml文件来配置Log4j2。 在log4j2.xml文件中,需要定义一个或多个logger,例如: ``` <Logger name="com.example.myapp" level="info"> <AppenderRef ref="stdout" /> </Logger> ``` 通过上述配置,当com.example.myapp的日志级别为info时,日志信息将被输出到stdout。 除此之外,还需要在应用程序的Java类中添加日志记录代码,例如: ``` import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class MyApp { private static final Logger logger = LoggerFactory.getLogger(MyApp.class); public void myMethod() { logger.info("This is an info message"); logger.error("This is an error message"); } } ``` 在上述代码中,使用LoggerFactory获取Logger对象,然后使用.info()和.error()方法记录日志信息。在日志信息中,可以添加变量,例如: ``` logger.info("This is a message with variables: {} {} {}", var1, var2, var3); ``` 上述代码中,var1、var2和var3是将被替换为实际值的变量。 总之,Spring Boot集成SLF4JLog4j2可以方便地进行日志记录,只需要在配置文件application.yaml和log4j2.xml中进行相应的配置即可。同时,在Java类中添加日志记录代码可以很容易地实现记录日志的功能。 ### 回答3: Spring Boot是一款非常流行的Java开发框架,而Slf4jLog4j2则是用于Java项目中的日志库。这两个库的集成是非常常见的需求,因为它们可以协同工作,帮助我们记录日志和排查问题。 首先,在pom.xml文件中添加Slf4jLog4j2的依赖项。这个过程非常简单,只需要在<dependencies>标签内添加以下代码段即可: ``` <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>1.7.30</version> </dependency> <dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-slf4j-impl</artifactId> <version>2.13.3</version> </dependency> <dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-core</artifactId> <version>2.13.3</version> </dependency> ``` 这里我们添加了Spring Boot Web启动器,以及Slf4jLog4j2的相关依赖项。我们还需要在application.properties文件中设置日志级别和输出格式。 在application.properties文件中添加以下代码: ``` logging.level.root=INFO logging.pattern.console=%d{yyyy-MM-dd HH:mm:ss.SSS} %5p [%t] - %m%n ``` 这里我们设置root日志的级别为INFO,表示只输出INFO级别及以上的日志信息。同时,我们设置日志输出格式,包括日期、日志级别、线程名和消息等。你可以根据项目的需求来自定义日志输出格式。 现在,我们已经完成了Slf4jLog4j2集成工作。在我们的Java代码中,可以通过Logger接口来记录日志信息,如下所示: ``` import org.slf4j.Logger; import org.slf4j.LoggerFactory; @Controller public class HomeController { private static final Logger logger = LoggerFactory.getLogger(HomeController.class); @GetMapping("/") public String home() { logger.info("Welcome home!"); return "home"; } } ``` 这里我们使用LoggerFactory类来获取Logger对象,Logger对象可以使用info()、debug()、error()等方法来记录不同级别的日志信息。在这个例子中,我们在HomeController类的home()方法中记录了一条info级别的日志信息。这个日志信息将会被Slf4j记录下来,并使用Log4j2将它输出到终端上。 以上就是Spring Boot集成Slf4jLog4j2的基本步骤。这个过程非常简单,只需要几步就可以完成。如果你想深入了解Slf4jLog4j2的更多特性,可以查看官方文档或其他相关资料。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值