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

 

posted @   wujf  阅读(461)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
历史上的今天:
2019-06-25 go日志输入到es
2019-06-25 logback整合Logstash
点击右上角即可分享
微信分享提示