Spring Cloud 2.x系列之springcloud整合logback打印sql语句

 

 Logback是由log4j创始人设计的又一个开源日志组件。logback当前分成三个模块:logback-core、logback- classic和logback-access。logback-core是其它两个模块的基础模块。logback-classic是log4j的一个 改良版本。此外logback-classic完整实现SLF4J API使你可以很方便地更换成其它日志系统如log4j或JDK14Logging。logback-access访问模块与Servlet容器集成提供通过Http来访问日志的功能。 Logback是要与SLF4J结合起来用的。

Logbacklog4j是非常相似的,如果你对log4j很熟悉,那对logback很快就会得心应手。spring boot内部使用CommonsLogging来记录日志,但也保留外部接口可以让一些日志框架来进行实现,例如Java UtilLogging,Log4J2还有Logback。如果想用某一种日志框架来进行实现的话,就必须先进行配置,默认情况下spring boot使用Logback作为日志实现的框架。spring boot从控制台打印出来的日志级别只有ERROR, WARN 还有INFO。

(1)如果你想要打印debug级别的日志,可以通过application.yml文件配置:

debug:
  true

也可以在启动脚本添加参数:

java -jar d: \sc-xxx.jar --debug

(2) 配置logging.level.*来具体输出哪些包的日志级别

logging:
  level:
    root: INFO
      org.springframework.web: DEBUG
      org.hibernate: ERROR
(3)  将日志输出到文件
默认情况下spring boot是不将日志输出到日志文件中,但可以通过在application.yml文件中配置logging.file文件名称和logging.path文件路径,将日志输出到文件

 

logging:
  path: F:\\springcloudLog
  file: info.log
  level:
    root: info

 

备注:

A、这里若不配置具体的包的日志级别,日志文件信息将为空

B、若只配置logging.path,那么将会在F:\ springcloudLog文件夹生成一个日志文件为spring.log(ps:该文件名是固定的,不能更改)。如果path路径不存在,会自动创建该文件夹

C、若只配置logging.file,那将会在项目的当前路径下生成一个info.log日志文件。这里可以使用绝对路径如,会自动在d盘下创建文件夹和相应的日志文件。

logging:
  file: d:\\ springcloudLog \\info.log 

D、logging.path和logging.file同时配置,不会在这个路径有F:\springcloudLog \ info.log日志生成,logging.path和logging.file不会进行叠加(要注意)

F、logging.path和logging.file的value都可以是相对路径或者绝对路径

这就是基础的日志配置,可以直接在application.yml配置,还可以在classpath路径下,通过定义具体的日志文件来配置,例如:logback.xml

 

1、       新建项目sc-eureka-client-provider-logback,对应的pom.xml文件如下

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

 xsi:schemaLocation="http://maven.apache.org/POM/4.0.0http://maven.apache.org/xsd/maven-4.0.0.xsd">

   <modelVersion>4.0.0</modelVersion>

   <groupId>spring-cloud</groupId>

   <artifactId>sc-eureka-client-provider-logback</artifactId>

   <version>0.0.1-SNAPSHOT</version>

   <packaging>jar</packaging>

   <name>sc-eureka-client-provider-logback</name>

   <url>http://maven.apache.org</url>

   <parent>

      <groupId>org.springframework.boot</groupId>

      <artifactId>spring-boot-starter-parent</artifactId>

      <version>2.0.4.RELEASE</version>

   </parent>

   <dependencyManagement>

      <dependencies>

        <dependency>

           <groupId>org.springframework.cloud</groupId>

           <artifactId>spring-cloud-dependencies</artifactId>

           <version>Finchley.RELEASE</version>

           <type>pom</type>

           <scope>import</scope>

        </dependency>

      </dependencies>

   </dependencyManagement>

   <properties>

      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>

      <maven.compiler.source>1.8</maven.compiler.source>

      <maven.compiler.target>1.8</maven.compiler.target>

   </properties>

   <dependencies>

      <!-- 说明是一个 eureka client-->

      <dependency>

        <groupId>org.springframework.cloud</groupId>

         <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>

      </dependency>

      <!-- spring boot实现Java Web服务 -->

      <dependency>

        <groupId>org.springframework.boot</groupId>

        <artifactId>spring-boot-starter-web</artifactId>

        <!-- 把tomcat-jdbc连接池排除掉,这样spring-boot就会寻找是否有HikariCP可用 -->

        <exclusions>

           <exclusion>

              <groupId>org.apache.tomcat</groupId>

              <artifactId>tomcat-jdbc</artifactId>

           </exclusion>

        </exclusions>

      </dependency>

      <dependency>

        <groupId>com.zaxxer</groupId>

        <artifactId>HikariCP</artifactId>

      </dependency>



      <dependency>

        <groupId>mysql</groupId>

        <artifactId>mysql-connector-java</artifactId>

      </dependency>

      <dependency>

        <groupId>org.mybatis</groupId>

        <artifactId>mybatis-spring</artifactId>

        <version>1.3.2</version>

      </dependency>

      <dependency>

        <groupId>org.mybatis.spring.boot</groupId>

        <artifactId>mybatis-spring-boot-starter</artifactId>

        <version>1.3.2</version>

      </dependency>

   </dependencies>

</project>

可以到默认已经引入logback的jar包

2、       新建spring boot 启动类LogbackApplication.java

packagesc.provider.logback;

//import org.mybatis.spring.annotation.MapperScan;

importorg.springframework.boot.SpringApplication;

importorg.springframework.boot.autoconfigure.SpringBootApplication;

importorg.springframework.cloud.netflix.eureka.EnableEurekaClient;

@EnableEurekaClient

@SpringBootApplication

//@MapperScan(basePackages="sc.provider.logback.dao")

publicclass LogbackApplication {

   publicstaticvoid main(String[] args) {



      SpringApplication.run(LogbackApplication.class, args);

   }

}

3、       新建配置文件bootstarp.yml和application.yml

bootstarp.yml

server:
  port: 7200

application.yml

spring:
  application:
    name: sc-eureka-client-provider-logback
  datasource:
    driverClassName: com.mysql.jdbc.Driver
    url:jdbc:mysql://localhost:3306/sc?serverTimezone=UTC&useUnicode=true&characterEncoding=UTF-8
    username:root
    password: root
    type: com.zaxxer.hikari.HikariDataSource
    hikari:
      minimum-idle: 5
      maximum-pool-size: 15
      auto-commit: true
      idle-timeout: 30000
      pool-name: DatebookHikariCP
      max-lifetime: 1800000
      connection-timeout: 30000
      connection-test-query: SELECT 1

eureka:
  client:
    registerWithEureka: true #是否将自己注册到Eureka服务中,默认为true
    fetchRegistry: true #是否从Eureka中获取注册信息,默认为true
    serviceUrl:
      defaultZone:http://localhost:5001/eureka/
mybatis:
  mapper-locations:classpath:sc/provider/logback/dao/*.xml
  config-location:classpath:mybatis-config.xml
  type-aliases-package:sc.provider.logback.model

logging:
  level:
   sc.provider.logback.dao: debug

 

备注:

可以看到配置文件application.yml多了如下配置项

4、       项目其他文件如下图

 

5、       启动注册中心sc-eureka-server后,启动项目sc-eureka-client-provider-logback

6、       验证sc-eureka-client-provider-logback是否启动成功

7、       访问相关接口看看是否能打印sql语句,例如访问获取用户接口

 http://127.0.0.1:7200/user/getUser/3

查看控制台:

 

源码:

https://gitee.com/hjj520/spring-cloud-2.x/tree/master/sc-eureka-client-provider-logback

看完本文有收获?请转发分享给更多人


欢迎关注“JAVA乐园”,我们分享最有价值的互联网技术干货文章,助力您成为有思想的全栈架构师,我们只聊互联网、只聊架构!打造最有价值的架构师圈子和社区。

  • 长按下方的二维码可以快速关注我们

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

BUG弄潮儿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值