返回顶部
首页 > 资讯 > 后端开发 > Python >SpringCloud使用logback日志框架教程详解
  • 537
分享到

SpringCloud使用logback日志框架教程详解

springcloud LogBack日志框架springcloud LogBack 2023-05-19 05:05:48 537人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

目录前言一.依赖引入二.logback-spring.xml配置其中要修改配置的地方:三.配置文件application.properties所需配置1.配置文件中声明项目名称:2.

前言

Logback是一个功能强大的日志框架,它是一个基于slf4j的日志系统,提供了可靠的日志服务,比log4j更快,更灵活,更容易使用。它可以定义日志消息的输出格式,支持灵活的日志输出,支持多种日志文件格式,支持按时间和大小分割日志等功能。本文将教会你快速让你的项目集成logback日志框架。

一.依赖引入

如果项目是spring WEB项目,并且已经引入了下面依赖,可以直接使用:

<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-web</artifactId>
</dependency>

如果你的项目不是web应用,则可以引入依赖:

<properties>
    <logback.version>1.1.11</logback.version>
</properties>

<dependency>
    <groupId>ch.qos.logback</groupId>
	<artifactId>logback-access</artifactId>
	<version>${logback.version}</version>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
	<artifactId>logback-classic</artifactId>
	<version>${logback.version}</version>
	</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
    <artifactId>logback-core</artifactId>
	<version>${logback.version}</version>
</dependency>

如果你项目中是spring cloud 2.x版本,则logback版本号${logback.version}可以用:

  <version>1.2.3</version>

Spring Cloud 1.x 依赖的logback-classic版本号是:

  <version>1.1.11</version>

二.logback-spring.xml配置

logback-spring.xml命名要加上-spring,表明它是一个专门为Spring应用准备的Logback配置文件,此文件将把Spring的日志信息输出到Logback的日志系统中,而且这样才可以使用 <springProfile name="dev">这种根据不同环境切换不同日志输出规则的配置。

提供一个完整的配置文件,可以根据自己项目定制配置:

<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="false" scan="true" scanPeriod="1 seconds">

    <contextName>logback</contextName>
       <!--必须修改:改成你的日志文件名,下面配置表示:在项目启动目录下,创建个logs文件夹,并将日志写入到demo.log文件中-->
    <property name="log.name" value="logs/demo"/>

    <!--输出到控制台 ConsoleAppender-->
    <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>%d{HH:mm:ss.SSS} %contextName [%thread] %-5level %logger{36} - %msg%n</pattern>
        </encoder>
    </appender>

  <!--必须要配置:下面配置含义,当单个日志文件大小超过100M后,会生成新日志文件,并将旧其按日志进行打包压缩,当日志总大小超过10G或者日志时间超过7天,就吧最老的日志删除,避免日志撑爆服务器硬盘导致服务器宕机-->
    <appender name="file" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${log.name}.log</file>
        <!--滚动策略,按照时间滚动 TimeBasedRollingPolicy-->
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <!--文件路径,定义了日志的切分方式——把每一天的日志归档到一个文件中,以防止日志填满整个磁盘空间-->
            <FileNamePattern>${log.name}.%d{yyyy-MM-dd}.%i.log.gz</FileNamePattern>
            <!-- 单个日志文件最多 100MB -->
            <maxFileSize>100MB</maxFileSize>
            <!--只保留最近7天的日志-->
            <maxHistory>7</maxHistory>
            <!--用来指定日志文件的上限大小,那么到了这个值,就会删除旧的日志-->
            <totalSizeCap>10GB</totalSizeCap>
        </rollingPolicy>
        <!--日志输出编码格式化-->
        <encoder>
            <charset>UTF-8</charset>
            <pattern>%d [%t] %-5level %logger{36}.%M\(%file:%line\) - %msg%n</pattern>
        </encoder>
    </appender>

<!--  <root level="info">
        <appender-ref ref="console"/>
        <appender-ref ref="file"/>
    </root>-->

    <logger name="org.springframework" level="warn"/>

    <springProfile name="local">
        <!-- 打印mybatis日志 -->
        <logger name="cn.enn.smart.mapper" level="debug"/>
        <root level="info">
            <appender-ref ref="console"/>
            <!--本地环境时,不写入日志文件 -->
        </root>
    </springProfile>

    <springProfile name="dev">
        <!-- 打印mybatis日志 -->
        <logger name="cn.enn.smart.mapper" level="debug"/>
        <root level="debug">
            <appender-ref ref="console"/>
            <appender-ref ref="file"/>
        </root>
    </springProfile>

    <springProfile name="test">
        <!-- 打印mybatis日志 -->
        <logger name="cn.enn.smart.mapper" level="debug"/>
        <root level="info">
            <appender-ref ref="console"/>
            <appender-ref ref="file"/>
        </root>
    </springProfile>

    <springProfile name="pro">
        <!-- 打印mybatis日志 -->
        <logger name="cn.enn.smart.mapper" level="debug"/>
        <root level="info">
            <appender-ref ref="console"/>
            <appender-ref ref="file"/>
        </root>
    </springProfile>

</configuration>

其中要修改配置的地方:

1.日志文件名要配置,这个最好以自己项目名称命名,如:xxx.log
2.日志保留策略要配置,上面默认保留7天并且总日志大小不能超过10G,否则logback会自动删除
3.项目配置文件名称要配置,如果你的配置文件命名是application-local.properties、application-dev.properties、application-test.properties、application-pro.properties可使用上述配置,如果不是则需要按自己配置文件真实后缀名,修改: <springProfile name="local">、 <springProfile name="dev">、 <springProfile name="test">、 <springProfile name="pro">这四行配置。

三.配置文件application.properties所需配置

1.配置文件中声明项目名称:

spring.application.name=demo

2.可以根据不同的配置文件,决定是不是要打印Mybatis日志,配置如下:

①.关闭生产Mybatis日志

修改application-pro.propertities文件,增加配置:

#关闭Mybatis日志
mybatis.configuration.log-impl=org.apache.ibatis.logging.nologging.NoLoggingImpl

②.打开开发、测试环境Mybatis日志

application.properties中增加配置:

#打印Mybatis日志
mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl

四.如果想让开发、测试、生产等环境共用一套logback配置,可使用logback.xml:

文件名可直接用logback.xml,不需要用logback-spring.xml来命名了,因为不需要使用 <springProfile name="dev">这种配置来区分环境了。

<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="false" scan="true" scanPeriod="1 seconds">

    <contextName>logback</contextName>
    <property name="log.name" value="logs/demo"/>

    <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>%d{HH:mm:ss.SSS} %contextName [%thread] %-5level %logger{36} - %msg%n</pattern>
        </encoder>
    </appender>

    <appender name="file" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${log.name}.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <FileNamePattern>${log.name}.%d{yyyy-MM-dd}.%i.log.zip</FileNamePattern>
            <!-- 单个日志文件最多 100MB -->
            <maxFileSize>100MB</maxFileSize>
            <!--只保留最近7天的日志-->
            <maxHistory>7</maxHistory>
            <!--用来指定日志文件的上限大小,那么到了这个值,就会删除旧的日志-->
            <totalSizeCap>10GB</totalSizeCap>
        </rollingPolicy>
        <!--日志输出编码格式化-->
        <encoder>
            <charset>UTF-8</charset>
            <pattern>%d [%t] %-5level %logger{36}.%M\(%file:%line\) - %msg%n</pattern>
        </encoder>
    </appender>

    <root level="info">
        <appender-ref ref="console"/>
        <appender-ref ref="file"/>
    </root>

</configuration>

五.如何高效的使用log.debug()打印日志

log.debug()使用时,最好增加判断,防止条件不满足时候,也会执行打印日志的代码,造成不必要的资源消耗。比如打印日志语句中存在对象转字符串等操作时,增加判断后,将不再消耗系统资源。

if (log.isDebugEnabled()) {
    log.debug("1.完成将文本数据导入到XML文件中");
}

总结

本文介绍了如何使用SpringCloud使用Logback日志框架,文章总结提供了使用Logback框架的实现步骤,以及可能出现的一些问题,以及一些常用的配置项,包括根据不同的环境配置不同日志输出,控制日志文件大小等保留策略,以便读者了解如何构建可靠的微服务应用程序。

以上就是SprinGCloud使用logback日志框架教程详解的详细内容,更多关于SpringCloud logback日志框架的资料请关注编程网其它相关文章!

--结束END--

本文标题: SpringCloud使用logback日志框架教程详解

本文链接: https://lsjlt.com/news/212503.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • SpringCloud使用logback日志框架教程详解
    目录前言一.依赖引入二.logback-spring.xml配置其中要修改配置的地方:三.配置文件application.properties所需配置1.配置文件中声明项目名称:2....
    99+
    2023-05-19
    springcloud LogBack日志框架 springcloud LogBack
  • springboot]logback日志框架配置教程
    目录一、application配置文件实现日志配置日志格式占位符二、使用logback-spring.xml实现日志配置2.1.需求2.2.需求实现2.3.测试一下logback既可...
    99+
    2024-04-02
  • ASP教程:如何使用框架记录日志?
    在开发ASP应用程序的过程中,记录日志是一个非常重要的环节。这有助于开发人员及时发现和解决问题,并提高应用程序的稳定性和可靠性。本篇文章将介绍如何使用框架记录日志。 一、为什么需要记录日志? 在应用程序中,记录日志是非常必要的。通过记录日...
    99+
    2023-07-02
    教程 框架 日志
  • Java接口测试中日志框架Logback该怎样使用
    这篇文章主要为大家分析了Java接口测试中日志框架Logback该怎样使用的相关知识点,内容详细易懂,操作细节合理,具有一定参考价值。如果感兴趣的话,不妨跟着跟随小编一起来看看,下面跟着小编一起深入学习“Java接口测试中日志框架Logba...
    99+
    2023-06-28
  • Java接口测试之日志框架Logback的具体使用
    目录一、引言二、前言三、LogBack、Slf4j和Log4j之间的关系四、默认日志Logback五、配置详解1、添加日志依赖2、配置文件六、多环境日志输出七、单元测试八、工程目录九...
    99+
    2024-04-02
  • SpringBoot应用自定义logback日志详解
    目录概述logback配置详解配置内容概念介绍配置介绍SpringBoot中自定义logback多环境输出日志文件读取配置文件配置概述 默认情况下,SpringBoot内部使用log...
    99+
    2024-04-02
  • .Net使用日志框架NLog
    在Nuget中安装NLog NLog可以直接使用Nuget安装:PM > Install-Package Nlog 使用NLog NLog的使用方式基本上和其它的Log库差不多...
    99+
    2024-04-02
  • SpringCloud中Gateway的使用教程详解
    目录1.基础教程2.将配置放在配置文件里3.放在springcloud里面4.使用服务名而不是IP1.基础教程 pom.xml <parent> ...
    99+
    2022-11-13
    SpringCloud Gateway使用 SpringCloud Gateway
  • Node.js中Express框架的使用教程详解
    目录Express简介Express生成器1. 什么是Express生成器2. 安装Express生成器创建Express项目安装项目依赖运行Express项目Express目录结构...
    99+
    2024-04-02
  • springboot log4j2日志框架整合与使用过程解析
    目录一、引入maven依赖二、添加配置文件log4j2-spring.xml三、自定义配置文件四、测试一下 一、引入maven依赖 Spring Boot默认使用LogBack,但是...
    99+
    2024-04-02
  • .NET日志框架Nlog使用介绍
    目录快速安装快速配置快速使用详解配置添加支持Console输出输出至CSV文件配置日志大小配置日志分级配置生成规则日志过滤器条件语言条件函数NLog是一个基于.NET平台编写的类库,...
    99+
    2024-04-02
  • .net项目使用日志框架log4net
    目录一、log4net简介二、log4net结构1、Logger:2、APPender:3、Filter:4、Layout:5、Object Render三、Log4net参数:四、...
    99+
    2024-04-02
  • .NET日志框架Nlog怎么使用
    这篇文章主要介绍“.NET日志框架Nlog怎么使用”,在日常操作中,相信很多人在.NET日志框架Nlog怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”.NET日志框架Nlog怎么使用”的疑惑有所帮助!...
    99+
    2023-06-29
  • .net日志框架Serilog怎么使用
    本篇内容介绍了“.net日志框架Serilog怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!首先安装Nuget包:Install-P...
    99+
    2023-07-02
  • .Net怎么使用日志框架NLog
    这篇文章主要讲解了“.Net怎么使用日志框架NLog”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“.Net怎么使用日志框架NLog”吧!在Nuget中安装NLogNLog可以直接使用Nuge...
    99+
    2023-07-02
  • 深入理解 SpringBoot 日志框架:从入门到高级应用——(三)Logback 输出日志到 MySQL 数据库
    文章目录 添加依赖导入 SQL 文件配置 logback-spring.xml运行结果 Logback 是一个开源的日志框架,它支持多种日志输出方式,包括控制台输出、文件输出、邮件输出...
    99+
    2023-09-09
    数据库 mysql logback
  • Laravel日志和Go框架日志:哪个更容易使用?
    随着Web应用程序的不断发展,日志记录已成为一项必不可少的任务。对于开发人员来说,日志记录是一种追踪和调试应用程序的重要方式。在本文中,我们将比较Laravel和Go框架的日志记录功能,以便开发人员可以更好地了解哪种框架更适合他们的需求。...
    99+
    2023-06-04
    框架 日志 laravel
  • google c++程序测试框架googletest使用教程详解
    目录什么是googletest?googletest简介谁在使用 GoogleTest?相关开源项目googletest的下载与编译cmake gui编译在vs2019中使用...
    99+
    2024-04-02
  • Python 第三方日志框架loguru使用
    解决中文乱码问题 项目地址 github: https://github.com/Delgan/loguru 文档:https://loguru.readthedocs.io/en/stable/index.html...
    99+
    2022-06-02
    Python 日志框架loguru Python 第三方日志框架
  • Flutter路由框架Fluro使用教程详细讲解
    目录1.Navigator使用简介2.fluro1.配置2.使用方法3.路由拦截3.封装1.Navigator使用简介 使用Flutter 的Navigator 导航器可以实现页面的...
    99+
    2022-11-13
    Flutter路由框架Fluro Flutter Fluro
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作