使用MongoDB 记录业务日志
最近公司有个需求,要对业务日志进行记录并根据日志排查问题,以前都是使用log4net之类的日志组件来记录到文件,这种方式已经不能满足业务的需要,因为日志文件会很大,即使进行分割后,查找也是很不方便,何况现在项目基本都是分布式,会有多台应用服务器,那么就需要把多台服务器上的日志弄到一起,十分的麻烦,经过选择后ELK进入视线,测试环境也搭建了一套,现在唯一的问题就是怎么把多台服务器上的日子泵出到elstaticsearch中,我们的应用服务器都是windows,所以需要在每一台应用服务器上安装一个服务,如:NXlog之类的,经过考虑觉得这种方式太麻烦,所以决定把日志先记录到MongoDb,先实现简单的日志查询,再统一从MongoDb将数据泵出到elstaticsearch中,思路有了,开始动手测试。
第一步,插入测试数据,MongoDb数据库我是安装在本地一个linux虚拟机里,插入1000000条数据耗时8分钟,有兴趣的童鞋自己测试一下,用来存储日志完全没有问题,废话不多说了,上代码:
- static void Main(string[] args)
- {
- try
- {
- #region 插入测试数据
- //var sw = new Stopwatch();
- //sw.Start();
- //string tableName = "InsuranceLog";
- //for (var i = 0; i < 1000000; i++)
- //{
- // var lb = new LogBase<InsuranceLog>()
- // {
- // Message = new InsuranceLog
- // {
- // BusinessKey = i.ToString(),
- // BusinessName = "政策查询" + i,
- // BusinessParameters = "根据实际需要组织<xml><OrderId>AutoHome" + i + "</OrderId></xml>"
- // }
- // };
- // InsertOneLogToMongoDbAsync(lb, tableName);
- //}
- //sw.Stop();
- //Console.WriteLine("插入100000条数据耗时:" + sw.ElapsedMilliseconds + "ms");
- #endregion
- #region 根据条件从1000000条数据中获取指定数据
- var sw = new Stopwatch();
- sw.Start();
- var obj = GetList();
- sw.Stop();
- Console.WriteLine("从100000条数据获取指定数据耗时:" + sw.ElapsedMilliseconds + "ms");
- foreach (var o in obj)
- {
- if (o.Message != null)
- {
- Console.WriteLine("调用时间:"+o.CallTime);
- Console.WriteLine("业务key:" + o.Message.BusinessKey);
- Console.WriteLine("业务名称:" + o.Message.BusinessName);
- Console.WriteLine("业务参数:" + o.Message.BusinessParameters);
- }
- }
- #endregion
- Console.ReadKey();
- }
- catch (Exception ex)
- {
- throw;
- }
- }
- /// <summary>
- /// 从MongoDb 获取数据
- /// </summary>
- /// <returns></returns>
- static List<LogBase<InsuranceLog>> GetList()
- {
- try
- {
- var client = new MongoClient("mongodb://192.168.21.129:27017");
- var database = client.GetDatabase("logs");
- var collection = database.GetCollection<LogBase<InsuranceLog>>("InsuranceLog");
- var b = (from x in collection.AsQueryable()
- where x.CallTime.StartsWith("")
- && x.CallTime.EndsWith("")
- select x).ToList();
- return b;
- }
- catch (Exception ex)
- {
- throw;
- }
- }
- /// <summary>
- /// 插入单条数据
- /// </summary>
- /// <typeparam name="T"></typeparam>
- /// <param name="t"></param>
- /// <param name="name"></param>
- static async Task InsertOneLogToMongoDbAsync<T>(T t, string name)
- {
- try
- {
- var client = new MongoClient("mongodb://192.168.21.129:27017");
- var database = client.GetDatabase("logs");
- var collection = database.GetCollection<T>(name);
- await collection.InsertOneAsync(t);
- }
- catch (Exception ex)
- {
- throw;
- }
- }
主要测试点在查询上,要根据条件快速检索出需要的数据,我测试了一下,单条数据大概是800ms左右,我的查询条件取出来38条数据,耗时842ms,
重点:日志基类,扩展性很好,支持自定义实体类
- /// <summary>
- /// 日志基类
- /// </summary>
- [BsonIgnoreExtraElements]
- public class LogBase<T>
- {
- public LogBase()
- {
- CallTime = DateTime.Now.ToString("yyyyMMddHHmmssfff");
- SerialNo = Guid.NewGuid().ToString("N");
- ClientType = "";
- Message = default(T);
- var myEntry = Dns.GetHostEntry(Dns.GetHostName());
- var address = myEntry.AddressList.FirstOrDefault(e => e.AddressFamily.ToString().Equals("InterNetwork"));
- if (address == null) return;
- var ip = address.ToString();
- HostIp = ip;
- }
- /// <summary>
- /// 调用时间,格式:yyyyMMddHH24mmss
- /// </summary>
- public string CallTime { get; private set; }
- /// <summary>
- /// 消息序列号 UUID
- /// </summary>
- public string SerialNo { get; private set; }
- /// <summary>
- /// 客户端IP地址
- /// </summary>
- public string HostIp { get; private set; }
- /// <summary>
- /// 客户端类型:1:pc 2:手机
- /// </summary>
- public string ClientType { get; private set; }
- /// <summary>
- /// 业务信息
- /// </summary>
- public T Message { get; set; }
- }
测试程序用到的自定义日志类:
- public class InsuranceLog
- {
- /// <summary>
- /// 当前登录用户
- /// </summary>
- public string UserName { get; set; }
- /// <summary>
- /// 业务key
- /// </summary>
- public string BusinessKey { get; set; }
- /// <summary>
- /// 业务名称 如:查询政策 下订单 查看订单
- /// </summary>
- public string BusinessName { get; set; }
- /// <summary>
- /// 业务参数
- /// </summary>
- public string BusinessParameters { get; set; }
- }
未完待续
G_)6X1MFICCXY]G6JZ}2[M.png)
使用MongoDB 记录业务日志的更多相关文章
- 使用NLog记录业务日志到数据库
项目中很多时候要记录业务日志,其实是可以直接用日志框架计入数据库的. 使用NLog并不是只能将日志主体插入数据库,而是可以根据实际情况自定义任意列记入.非常方便.而且很容易实现 下面是用NLog记录业 ...
- spring集成mongodb通过aop记录业务日志
1. 编辑 pom.xml 添加 maven 依赖 <!-- mongodb --> <dependency> <groupId>org.mongodb</g ...
- aop 例外通知就是记录业务方法出现错误 并保存到日志里面的功能
aop 例外通知就是记录业务方法出现错误 并保存到日志里面的功能
- 十:SpringBoot-配置AOP切面编程,解决日志记录业务
SpringBoot-配置AOP切面编程,解决日志记录业务 1.AOP切面编程 1.1 AOP编程特点 1.2 AOP中术语和图解 2.SpringBoot整合AOP 2.1 核心依赖 2.2 编写日 ...
- ASP.NET记录错误日志的方式
程序记录错误日志是一种看起来对一般用户没什么作用,但对程序开发者用处很大的东西,它能查出错误或异常的程序马迹.那么,常用的记录错误日志的方式有哪些呢? 大多数情况下使用的是 1.直接记录为txt/xm ...
- Appfuse:记录操作日志
appfuse的数据维护操作都发生在***form页面,与之对应的是***FormController,在Controller中处理数据的操作是onSubmit方法,既然所有的操作都通过onSubmi ...
- MongoDB实战指南(四):MongoDB的Journaling日志功能
mongoDB的Journaling日志功能与常见的log日志是不一样的,mongoDB也有log日志,它只是简单记录了数据库在服务器上的启动信息.慢查询记录.数据库异常信息.客户端与数据库服务器连接 ...
- 采用Spring AOP+Log4j记录项目日志
转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6567672.html 项目日志记录是项目开发.运营必不可少的内容,有了它可以对系统有整体的把控,出现任何问题 ...
- Spring AOP+Log4j记录项目日志
转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6567672.html 项目日志记录是项目开发.运营必不可少的内容,有了它可以对系统有整体的把控,出现任何问题 ...
随机推荐
- -------------》》》【Vim】vim的一些简单配置~
在linux下使用 :vsp ~/.vimrc 来打开配置文件 一些命令[任何命令前加上 ! 强制执行]: :w 保存 :wq 保存退出 :q 退出 ctrl ...
- [LOJ6278]数列分块入门 2
题目大意: 给你一个长度为$n(n\leq 50000)$的序列$A$,支持进行以下两种操作: 1.将区间$[l,r]$中所有数加上$c$: 2.询问区间$[l,r]$中小于$c^2$的数的个数.思路 ...
- iOS 自定义字体设置
有时候客户都要求使用方正兰亭刊黑字体,可是iOS没有自带这个字体,肿么办 ,只能自己自定义字体了,下面是自定义字体的几个重要步骤: 1.下载字体资源文件(.ttf或.otf格式的文件) 比如说你要使用 ...
- 检索COM 类工厂中CLSID 为{00024500-0000-0000-C000-000000000046}组件时失败
检索 COM 类工厂中 CLSID 为{00024500-0000-0000-C000-000000000046} 的组件时失败,原因是出现以下错误: 80070005 当在ASP.NET应用程序中引 ...
- 小程序 wx:for 循环嵌套
json数据: [//library-6F [//library-6F-601 [//id:1-1 ,8(Y/N),9(Y/N)……21(Y/N) 'Y','Y','Y' ...
- mysql行转列,单列转多行
行转列 使用CASE语句: SELECT SUM(CASE USER_NAME='A' THEN KILLS END) AS 'A', SUM(CASE USERNAME='B' THEN KILL ...
- Unable to list target platforms. Please make sure the android sdk path is correct. See the Console for more details.
在android上发布遇到 androidSDK无法找到的问题 http://www.jianshu.com/p/fe4c334ee9fe
- Python 面向对象三(转载)
来源:Mr.Seven www.cnblogs.com/wupeiqi/p/4766801.html 四.类的特殊成员 上文介绍了Python的类成员以及成员修饰符,从而了解到类中有字段.方法和属性三 ...
- ElasticSearch的内存设置
编辑ElasticSearch中bin目录下 vi elasticsearch中 加上 export ES_HEAP_SIZE=24g 修改配置文件 config/elasticsearch.ya ...
- How to dynamically load directive into page
https://stackoverflow.com/questions/23556398/how-to-dynamically-load-directive-into-page I have an h ...