实现:

  1. 将日志保存在MongoDb中;
  2. 自定义日志字段;
  3. 日志按照日期拆分集合;

第一部分:将日志保存在MongoDb中

  1. 新建控制台程序Log4MongoDemo

  2. 通过NuGet安装Log4Net (v2.0.8)、log4mongo-net(v2.2.0)

  3. 项目根目录下添加log4net.config配置文件

    <?xml version="1.0"?>
    <configuration>
    <!--声明一个名为“log4net”的自定义配置节-->
    <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/>
    </configSections>
    <!--log4net配置信息-->
    <log4net>
    <logger name="MongoDBLogger">
    <level value="ALL"/>
    <appender-ref ref="MongoDBAppender" />
    </logger>
    <appender name="MongoDBAppender" type="Log4Mongo.MongoDBAppender, Log4Mongo">
    <connectionString value="mongodb://(登录名):(密码)@(服务器地址)/app" />
    <CollectionName value="logs"/>
    </appender>
    </log4net>
    </configuration>
  4. 日志记录方法

    public class LogHelper
    {
    private static readonly ILog log = LogManager.GetLogger("MongoDBLogger");
    /// <summary>
    /// 记录一般日志
    /// </summary>
    public static void LogInfo(AppOpLog opLog)
    {
    if (log.IsInfoEnabled)
    {
    log.Info(opLog);
    }
    }
    }
  5. 记录日志

    static void Main(string[] args)
    {
    log4net.Config.XmlConfigurator.Configure(
    new System.IO.FileInfo(AppDomain.CurrentDomain.BaseDirectory + "\\log4net.config")
    );
    LogHelper.LogInfo(null);
    Console.ReadKey();
    }
  6. 查看结果

第二部分:自定义日志字段

从github上下载【log4mongo-net】源码进行修改,日志中记录的字段定义在BackwardCompatibility.cs下BuildBsonDocument方法和BuildExceptionBsonDocument方法中,只需要修改这两个方法就可以按照根据自己的需求记录日志内容

  1. 将自定义的日志内容通过 log.Info(object) 传递

  2. 在BuildBsonDocument方法中通过LoggingEvent的MessageObject属性来获取自定义的日志内容

    public class BackwardCompatibility
    {
    public static BsonDocument BuildBsonDocument(LoggingEvent loggingEvent)
    {
    if(loggingEvent == null)
    {
    return null;
    } BsonDocument bs = loggingEvent.MessageObject.ToBsonDocument();
    var toReturn = bs;
    toReturn.Add("TimeStamp", loggingEvent.TimeStamp);
    toReturn.Add("ThreadId", loggingEvent.ThreadName); if(loggingEvent.ExceptionObject != null)
    {
    toReturn.Add("Exception", BuildExceptionBsonDocument(loggingEvent.ExceptionObject));
    } PropertiesDictionary compositeProperties = loggingEvent.GetProperties();
    if(compositeProperties != null && compositeProperties.Count > 0)
    {
    var properties = new BsonDocument();
    foreach(DictionaryEntry entry in compositeProperties)
    {
    properties.Add(entry.Key.ToString(), entry.Value.ToString());
    } toReturn.Add("Properties", properties);
    } return toReturn;
    } private static BsonDocument BuildExceptionBsonDocument(Exception ex)
    {
    var toReturn = new BsonDocument {
    {"Message", ex.Message},
    {"Source", ex.Source},
    {"StackTrace", ex.StackTrace}
    }; if(ex.InnerException != null)
    {
    toReturn.Add("InnerException", BuildExceptionBsonDocument(ex.InnerException));
    } return toReturn;
    }
    }
  3. 日志记录:LogHelper.LogInfo(object),object为自定义类型

第三部分:日志按照日期拆分集合

因为MongoDb不需要预先定义集合结构,所以我们只需要根据自己的需求修改集合的生成规则就可以拆分日志到不同的集合中,这里实现将日志按天拆分。

  1. 在log4net.config配置文件中将CollectionName的value修改为“yyyyMMdd”
  2. 修改MongoDBAppender.cs下的GetCollection()方法:
private IMongoCollection<BsonDocument> GetCollection()
{
var db = GetDatabase();
var collectionName = CollectionName ?? "logs"; if (collectionName == "yyyyMMdd")
{
collectionName = $"Log{DateTime.Now.ToString("yyyyMMdd")}" ;
} EnsureCollectionExists(db, collectionName); var collection = db.GetCollection<BsonDocument>(collectionName);
return collection;
}

完整代码地址:https://github.com/zhrong92/Log4NetDemo

参考文章:https://www.cnblogs.com/zeallag/p/5205571.html

Log4Net + Log4Mongo 将日志记录到MongoDb中的更多相关文章

  1. 也用 Log4Net 之将自定义属性记录到文件中 (三)

    也用 Log4Net  之将自定义属性记录到文件中 (三)  即解决了将自定义属性记录到数据库之后.一个新的想法冒了出来,自定义属性同样也能记录到文件中吗?答案是肯定的,因为Log4Net既然已经考虑 ...

  2. 也用 Log4Net 之将日志记录到数据库的后台实现 (二)

    也用 Log4Net 之将日志记录到数据库的后台实现 (二)  大家下午好,昨天讲了配置,今天我们讲讲后台实现,在完成了后台实现后,我们才能真正意义上的解决把自定义属性字段值录入到数据库中. 在开写之 ...

  3. 也用 Log4Net 之将日志记录到数据库的配置 (一)

    也用 Log4Net  之将日志记录到数据库的配置 (一) 前段时间我一直想做一个通用一点的日志记录系统,可以便于不同的业务组调用进行日志记录及分析.本来打算着自己下手写一个,后面发现各业务组可能会需 ...

  4. Log4Net 之将自定义属性记录到文件中 (三)

    原文:Log4Net 之将自定义属性记录到文件中 (三) 即解决了将自定义属性记录到数据库之后.一个新的想法冒了出来,自定义属性同样也能记录到文件中吗?答案是肯定的,因为Log4Net既然已经考虑到了 ...

  5. Log4Net 之将日志记录到数据库的后台实现 (二)

    原文:Log4Net 之将日志记录到数据库的后台实现 (二) 大家下午好,昨天讲了配置,今天我们讲讲后台实现,在完成了后台实现后,我们才能真正意义上的解决把自定义属性字段值录入到数据库中. 在开写之前 ...

  6. Log4Net 之将日志记录到数据库的配置 (一)

    原文:Log4Net 之将日志记录到数据库的配置 (一) 前段时间我一直想做一个通用一点的日志记录系统,可以便于不同的业务组调用进行日志记录及分析.本来打算着自己下手写一个,后面发现各业务组可能会需要 ...

  7. asp.net Web项目中使用Log4Net进行错误日志记录

      使用log4net可以很方便地为应用添加日志功能.应用Log4net,开发者可以很精确地控制日志信息的输出,减少了多余信息,提高了日志记录性能.同时,通过外部配置文件,用户可以不用重新编译程序就能 ...

  8. 使用log4net无法将日志记录插入mysql数据库解决办法

    写在前面 今天没事研究了下,将日志文件写入mysql数据库,因为新公司用的数据库也是mysql,项目中需要将日志信息写入数据库,没办法,就研究了下.在使用过程中遇到一个很蛋疼的问题.最后解决了,郁闷了 ...

  9. 通过代码配置 Log4net来实现日志记录

    通过代码来创建配置文件,优点看起来更为简洁,不过还得看需求吧,之前我博客也写了一篇通过读取不同的配置文件还实现配置不同日志类型. //记录异常日志数据库连接字符串 private const stri ...

随机推荐

  1. duoxiao OJ #910 【高手训练】【动态规划】梦中漫步 期望 LCA

    LINK:梦中漫步 当然也可以去一本通的Oj/loj上交(loj可能没有.. 期望好题.期望和dp往往是在一起的. 前置知识:1. 期望是线性可加的.2.和的期望等于期望的和. 从u出发每次随机选一条 ...

  2. 重学c#系列——异常(六)

    前言 用户觉得异常是不好的,认为出现异常是写的人的问题. 这是不全面,错误的出现并不总是编写程序的人的原因,有时会因为应用程序的最终用户引发的动作或运行代码的环境而发生错误,比如你用android4去 ...

  3. Selenium多窗口切换代码

    # #!/usr/bin/python3 # -*- coding: utf-8 -*- # @Time : 2020/7/31 16:05 # @Author : Gengwu # @FileNam ...

  4. 学习使用CompletableFuture

    CompletableFuture 一.前言 1.JDK5的异步处理方式 2.JDK8的异步处理方式 二.学习CompletableFuture 1.结果获取方式 2.创建CompletableFut ...

  5. LVS-DR:实现VIP和RIP不在同一个网络中的集群

    目录 LVS-DR:实现VIP和RIP不在同一个网络中集群 1. router上配置ip转发,并测试 2. DR上配置VIP和转发规则 3. RS上配置arp内核参数和VIP 4. 配置HTTP访问 ...

  6. python爬虫学习05-爬取图片

    python爬虫学习05-爬取图片 确定要爬取的网址:https://shenan.tuchong.com/20903415/#image309854686 要爬取的内容:使用浏览器插件xpath对图 ...

  7. iOS开发实战之搜索控制器UISearchController使用

    当tableView中的数据过多的时候,在tableView上加一个搜索框就变的很必要了,本文就讨论搜索控制器的使用,以及谓词的简单实现. .m文件中代码如下 添加搜索控制器的各种协议 <UIS ...

  8. day23:单继承&多继承&菱形继承&__init__魔术方法

    1.单继承 1.1 关于继承的一些基本概念 1.2 子类可以调用父类的公有成员 1.3 子类无法调用父类的私有成员 1.4 子类可以改写父类的方法 2.多继承 2.1 多继承的基本语法 2.2 sup ...

  9. GPS位置显示在地图上

    源码分析博客地址:https://blog.csdn.net/wuquan_1230/article/details/79614974 工具下载地址:http://download.csdn.net/ ...

  10. Mac 系统更新怎么忽略

    1.在“终端”命令行中输入以下命令: sudo softwareupdate --ignore “macOS Catalina” 2.按回车键,然后输入管理员密码*,然后再次按回车键,以超级用户权限执 ...