ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

logback日志输出到mongodb

2022-06-25 12:32:24  阅读:185  来源: 互联网

标签: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. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有