logback日志输出到mongodb
2022/6/26 2:20:49
本文主要是介绍logback日志输出到mongodb,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
1、继承UnsynchronizedAppenderBase
package com.xf.config; import java.util.Map; import org.springframework.data.mongodb.core.MongoTemplate; import org.springframework.util.StringUtils; import com.alibaba.fastjson.JSONObject; import ch.qos.logback.classic.spi.LoggingEvent; import ch.qos.logback.core.UnsynchronizedAppenderBase; import cn.hutool.extra.spring.SpringUtil; import lombok.Data; @Data public class MongoDBAppender extends UnsynchronizedAppenderBase<LoggingEvent> { private MongoTemplate mongoTemplate; String appName; String collectionName; @Override protected void append(LoggingEvent e) { if (mongoTemplate == null) mongoTemplate = SpringUtil.getBean(MongoTemplate.class); JSONObject obj = new JSONObject(); obj.put("appName", appName); obj.put("Level", e.getLevel().toString()); obj.put("Message", e.getFormattedMessage()); obj.put("TimeStamp", e.getTimeStamp()); obj.put("Class", e.getCallerData()[0].toString()); Map<String, String> map = e.getMDCPropertyMap(); map.forEach((k, v) -> { obj.put(k, v); }); if (StringUtils.isEmpty(collectionName)) mongoTemplate.save(obj, "wjflog"); else mongoTemplate.save(obj, collectionName); } }
2、xml配置
<appender name="MONGODB" class="com.xf.config.MongoDBAppender"> <appName>odvapi</appName> <collectionName>mylog</collectionName> </appender>
3、mongdb配置
spring: data: mongodb: database: test port: 27017 host: 127.0.0.1
这篇关于logback日志输出到mongodb的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-15SendGrid 的 Go 客户端库怎么实现同时向多个邮箱发送邮件?-icode9专业技术文章分享
- 2024-11-15SendGrid 的 Go 客户端库怎么设置header 和 标签tag 呢?-icode9专业技术文章分享
- 2024-11-12Cargo deny安装指路
- 2024-11-02MongoDB项目实战:从入门到初级应用
- 2024-11-01随时随地一键转录,Google Cloud 新模型 Chirp 2 让语音识别更上一层楼
- 2024-10-25Google Cloud动手实验详解:如何在Cloud Run上开发无服务器应用
- 2024-10-24AI ?先驱齐聚 BAAI 2024,发布大规模语言、多模态、具身、生物计算以及 FlagOpen 2.0 等 AI 模型创新成果。
- 2024-10-20goland工具下,如修改一个项目的标准库SDK的版本-icode9专业技术文章分享
- 2024-10-17Go学习:初学者的简单教程
- 2024-10-17Go学习:新手入门完全指南