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
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
2019-06-25 go日志输入到es
2019-06-25 logback整合Logstash