SpringBoot集成Logback将日志写入文件夹

一、logback简介:

目前比较常用的ava日志框架:Logback、log4j、log4j2、JUL等等。
Logback是在log4j的基础上重新开发的一套日志框架,是完全实现SLF4J接口API(也叫日志门面)。
Logback 的架构非常通用,可以应用于不同的环境。目前logback分为三个模块,logback-core,logback-classic和logback-access。
logback-core模块为其他两个模块奠定了基础。logback-classic模块原生实现了SLF4JAPI,因此您可以轻松地在logback和其他日志记录框架(例如 log4j1.x或java.util.logging (JUL))之间来回切换。
logback-access模块与Tomcat和 Jetty 等 Servlet容器集成,以提供HTTP访问日志功能。请注意,您可以轻松地在logback-core之上构建自己的模块。

二、 SpringBoot集成Logback

  1. 创建项目:不做过多的描述,不会点这里
  2. 导入pom依赖
<dependencies><!-- Spring Boot Starter --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter</artifactId></dependency><!-- Spring Boot Starter Logging (默认已经包含在starter中) --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-logging</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency></dependencies>
  1. 编写logback.xml
<?xml version="1.0" encoding="UTF-8"?>
<configuration><!-- 控制台输出 --><appender name="console" class="ch.qos.logback.core.ConsoleAppender"><encoder><pattern>%white(%contextName - %d{yyyy-MM-dd HH:mm:ss}) %green([%c][%t][%L]) %highlight(%-5level) - %yellow(%msg%n)</pattern></encoder></appender><!-- 文件输出 --><appender name="file" class="ch.qos.logback.core.rolling.RollingFileAppender"><file>logs/springboot.log</file><rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"><fileNamePattern>logs/springboot-%d{yyyy-MM-dd}.log</fileNamePattern><maxHistory>30</maxHistory></rollingPolicy><!--文件中的输出格式--><encoder><pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%c][%t][%L][%p] - %msg%n</pattern></encoder></appender><!-- 日志级别配置 --><root level="info"><appender-ref ref="console"/><appender-ref ref="file"/></root>
</configuration>
  1. 编写Controller层
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;/*** @Author Ysl* @Date 2024/5/22* @name Myselflean**/
@RestController
public class LogController {private static final Logger log = LoggerFactory.getLogger(LogController.class);@GetMapping("/log")public String log() {log.info("开始输出日志--------start");String msg = "编写业务代码";log.info("日志输出结束--------end:"+ msg);return msg;}
}
  1. 输入网址进行访问:http://localhost:8080/log
    在这里插入图片描述
  2. 控制台输出后会出现logs文件夹,里面存放.log日志
    在这里插入图片描述
    在这里插入图片描述
  3. 如果需要更改输出格式,可在logback.xml中进行修改配置,可查相关资料完善。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/14289.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LeetCode题练习与总结:从前序与中序遍历序列构造二叉树--105

一、题目描述 给定两个整数数组 preorder 和 inorder &#xff0c;其中 preorder 是二叉树的先序遍历&#xff0c; inorder 是同一棵树的中序遍历&#xff0c;请构造二叉树并返回其根节点。 示例 1: 输入: preorder [3,9,20,15,7], inorder [9,3,15,20,7] 输出: [3,9,20,nul…

什么是经典蓝牙模块?

什么是经典蓝牙模块&#xff1f;   前面我们已经就蓝牙模块的概念做了了解&#xff0c;随着时间的推移&#xff0c;产品越来越智能&#xff0c;需要的蓝牙模块也就越来越广泛&#xff0c;本篇文章我们就一起了解下什么是经典蓝牙模块。   经典蓝牙模块(BT)泛指支持蓝牙协议…

SwiftUI中的手势(DragGesture拖拽手势及Drag动画组件)

上一篇文章我们了解了如何使用.gesture修饰符和GestureState属性包装器&#xff0c;让我们看看另一种常见的手势&#xff1a;DragGesture拖拽手势。 下面先看个效果图&#xff1a; 这个效果中&#xff0c;我们实现了一个Text文本&#xff0c;并添加了拖拽手势&#xff0c;可以…

代码随想录算法训练营第三十八天| 435. 无重叠区间 、763.划分字母区间、56. 合并区间

435. 无重叠区间 题目链接&#xff1a;435. 无重叠区间 文档讲解&#xff1a;代码随想录/无重叠区间 视频讲解&#xff1a;视频讲解-无重叠区间 状态&#xff1a;已完成&#xff08;1遍&#xff09; 解题过程 看到题目的第一想法 这道题我的想法是首先将集合按照start从小到…

看上去好坑的运算符重载

#include <iostream> using namespace std; class MyInt {int nVal; public:MyInt(int n) { nVal n};MyInt & operator-(int n){ //运算符重载-nVal - n;return *this; } operator int() {return nVal;} //类型转换函数};int Inc(int n){return n1; }int ma…

代码随想录训练营|一刷总结

代码随想录一刷完成啦&#xff01;&#xff01;&#xff01; 自己曾经尝试过刷力扣&#xff0c;但是却不知道从何刷起、按什么顺序刷题&#xff0c;直到遇到了卡哥、遇到了代码随想录。研一上有着刷题的决心&#xff0c;但是却没有刷题的动力很难坚持下去&#xff0c;所以也就只…

【削水果game】

编写一个完整的削水果游戏代码是一个复杂的过程&#xff0c;涉及到游戏引擎的使用和游戏逻辑的编写。在这里&#xff0c;我可以提供一个非常简化的版本&#xff0c;使用Python和Pygame库来创建一个基本的削水果游戏概念。请注意&#xff0c;这只是一个示例&#xff0c;用于展示…

Flutter Text导致A RenderFlex overflowed by xxx pixels on the right.

使用Row用来展示两个Text的时候页面出现如下异常,提示"A RenderFlex overflowed by xxx pixels on the right." The following assertion was thrown during layout: A RenderFlex overflowed by 4.8 pixels on the right.The relevant error-causing widget was:…

【仿RabbitMQ消息队列项目day2】使用muduo库中基于protobuf的应用层协议进行通信

一.什么是muduo? muduo库是⼀个基于非阻塞IO和事件驱动的C高并发TCP网络编程库。 简单来理解&#xff0c;它就是对原生的TCP套接字的封装&#xff0c;是一个比socket编程接口更好用的编程库。 二.使用muduo库完成一个英译汉翻译服务 TranslateServer.hpp: #pragma once #in…

MyBatis中Where标签:揭秘高效SQL构建的秘密

哈喽&#xff0c;大家好&#xff0c;我是木头左&#xff01; 理解Where标签的基础概念 在MyBatis中&#xff0c;<where>标签是用于构建SQL查询语句中的一个非常重要的元素。它允许你在一个动态的SQL语句中添加WHERE子句&#xff0c;而不需要担心SQL语法错误或额外的逗号…

如何利用51建模网,实现3D模型线上展示和应用?

按照下面的步骤&#xff0c;在51建模网上传3D模型&#xff0c;并编辑完成后&#xff0c;接下来就是如何让这些3D模型得到更好的展示、传播和应用。 一、3D内容快速分享与传播 3D模型在51建模网上传发布后&#xff0c;即可获得一个可分享的链接和二维码&#xff0c;直接分享给客…

20240520解决在Ubuntu20.04下编译RK3588的Android12的SDK出现C2_GIT_BUILD_VERSION未定义的问题

20240520解决在Ubuntu20.04下编译RK3588的Android12的SDK出现C2_GIT_BUILD_VERSION未定义的问题 2024/5/20 20:19 缘起&#xff1a;通过./repo/repo/repo sync -l得到的SDK正常&#xff0c;但是解压缩之后的SDK却出错了&#xff01; 通过grep很容易发现有三个地方有&#xff0c…

深入分析 Android Activity (一)

深入分析 Android Activity (一) 接下来我们会深入分析 Activity 的一些高级特性和内部实现&#xff0c;包括窗口管理、生命周期管理、以及与 Fragment 的交互。 1. Activity 的窗口管理 在 Android 中&#xff0c;每个 Activity 都与一个 Window 相关联。Window 是一个抽象…

如何选购尼龙输送带

尼龙输送带选购攻略&#xff1a;从入门到精通&#xff0c;一篇文章全搞定&#xff01; 在工业生产中&#xff0c;尼龙输送带作为关键的物流传输设备&#xff0c;其选择和使用直接关系到生产效率和成本控制。面对市面上琳琅满目的尼龙输送带产品&#xff0c;如何选购到性价比高…

PointCloudLib 点云投影到XOY平面功能实现 C++版本

0.实现效果 左图为原始点云,右图为投影到XOY平面上的点云 将三维的点云投影到二维平面,方便处理一些二维轮廓方面的计算。 可以投影到空间中任意平面上。 1.算法原理 原理 点云投影是将三维空间中的点云数据映射到一个二维平面上的过程。这通常通过以下步骤实现: 确定投…

使用Golang开发一个HTTP客户端请求命令行工具

什么是Golang Golang&#xff0c;也被称为Go语言&#xff0c;是由Google开发的一种开源的编程语言。它于2007年开始设计&#xff0c;于2009年首次公开发布。Golang被设计成一种通用的编程语言&#xff0c;旨在提供简单、高效和可靠的软件开发方式。Golang具有静态类型、垃圾回…

微服务实践k8sdapr开发部署调用

前置条件 安装docker与dapr: 手把手教你学Dapr - 3. 使用Dapr运行第一个.Net程序安装k8s dapr 自托管模式运行 新建一个webapi无权限项目 launchSettings.json中applicationUrl端口改成5001,如下: "applicationUrl": "http://localhost:5001" //Wea…

c#实现视频播放

在winform上实现视频播放常用的控件时media player&#xff0c;vs工具栏初始状态下没有&#xff0c;需要我们到com组件中添加。添加完成后&#xff0c;把media player控件拖拽到一个Form窗口中。 在此实现遍历某个文件夹下是否有mp4视频&#xff0c;如果有则播放视频。&#x…

BeautifulSoup4通过lxml使用Xpath,以及获取(定位)元素和其文本或者属性

环境&#xff1a;win10&#xff0c;python3.8.10 首先需要安装&#xff1a;beautifulsoup4&#xff0c;lxml 使用命令&#xff1a; pip38 install beautifulsoup4 pip38 install lxml 安装完毕后查看一下&#xff1a; 写代码&#xff1a; from bs4 import BeautifulSoup …

Go 图像处理

Golang中的image包提供了基本的图像类型、颜色模型、以及用于处理图像的各种函数和接口。 常用类型与接口 image.Image 接口 这是Go语言中处理图像的核心接口&#xff0c;定义了所有图像必须实现的方法&#xff1a; type Image interface {// Bounds returns the domain for…