标签:obj UnsynchronizedAppenderBase mongodb mongoTemplate put import 日志 logback
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
标签:obj,UnsynchronizedAppenderBase,mongodb,mongoTemplate,put,import,日志,logback 来源: https://www.cnblogs.com/wujf/p/16411117.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。