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-04-01got an unexpected keyword argument
- 2024-03-30维多利亚的秘密 golang入坑系统
- 2024-03-29mongodb sort by date
- 2024-03-29go swagger
- 2024-03-25mongodb cdc
- 2024-03-25how to use go in vscode
- 2024-03-22mongooseserverselectionerror: connect econnrefused ::1:27017
- 2024-03-21pymongo insert_many
- 2024-03-18projection mongodb
- 2024-03-14clickhouse-go