最近公司有个需求,要对业务日志进行记录并根据日志排查问题,以前都是使用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; }
}

未完待续

使用MongoDB 记录业务日志的更多相关文章

  1. 使用NLog记录业务日志到数据库

    项目中很多时候要记录业务日志,其实是可以直接用日志框架计入数据库的. 使用NLog并不是只能将日志主体插入数据库,而是可以根据实际情况自定义任意列记入.非常方便.而且很容易实现 下面是用NLog记录业 ...

  2. spring集成mongodb通过aop记录业务日志

    1. 编辑 pom.xml 添加 maven 依赖 <!-- mongodb --> <dependency> <groupId>org.mongodb</g ...

  3. aop 例外通知就是记录业务方法出现错误 并保存到日志里面的功能

    aop 例外通知就是记录业务方法出现错误 并保存到日志里面的功能

  4. 十:SpringBoot-配置AOP切面编程,解决日志记录业务

    SpringBoot-配置AOP切面编程,解决日志记录业务 1.AOP切面编程 1.1 AOP编程特点 1.2 AOP中术语和图解 2.SpringBoot整合AOP 2.1 核心依赖 2.2 编写日 ...

  5. ASP.NET记录错误日志的方式

    程序记录错误日志是一种看起来对一般用户没什么作用,但对程序开发者用处很大的东西,它能查出错误或异常的程序马迹.那么,常用的记录错误日志的方式有哪些呢? 大多数情况下使用的是 1.直接记录为txt/xm ...

  6. Appfuse:记录操作日志

    appfuse的数据维护操作都发生在***form页面,与之对应的是***FormController,在Controller中处理数据的操作是onSubmit方法,既然所有的操作都通过onSubmi ...

  7. MongoDB实战指南(四):MongoDB的Journaling日志功能

    mongoDB的Journaling日志功能与常见的log日志是不一样的,mongoDB也有log日志,它只是简单记录了数据库在服务器上的启动信息.慢查询记录.数据库异常信息.客户端与数据库服务器连接 ...

  8. 采用Spring AOP+Log4j记录项目日志

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6567672.html 项目日志记录是项目开发.运营必不可少的内容,有了它可以对系统有整体的把控,出现任何问题 ...

  9. Spring AOP+Log4j记录项目日志

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6567672.html 项目日志记录是项目开发.运营必不可少的内容,有了它可以对系统有整体的把控,出现任何问题 ...

随机推荐

  1. Sum of bit differences among all pairs

    This article was found from Geeksforgeeks.org. Click here to see the original article. Given an inte ...

  2. Bean的实例化--构造器

    1,编写Bean对象 package com.songyan.ico; public class Bean1 { } 2,配置xml <?xml version="1.0" ...

  3. 在Android App中集成Google登录

    技术文章 来源:码农网 发布:2016-09-19 浏览:194 摘要:今天,几乎所有的web和移动app都自带谷歌和Facebook登录,这对app开发者和用户来说是一个非常有用的功能,因为几乎每个 ...

  4. VUE -- JSONP的诞生、原理及应用实例

    问题: 页面中有一个按钮,点击之后会更新网页中的一个盒子的内容. Ajax可以很容易的满足这种无须刷新整个页面就可以实现数据变换的需求. 但是,Ajax有一个缺点,就是他不允许跨域请求资源. 如果我的 ...

  5. [Android Traffic] 调整定时更新的频率(C2DM与退避算法)

    转载自: http://blog.csdn.net/kesenhoo/article/details/7395253 Minimizing the Effect of Regular Updates[ ...

  6. Object 类中的 equals方法

    1 相等与同一 如果两个对象具有相同的类型以及相同的属性值,则称这两个对象相等.如果两个引用对象指的是同一个对像,则称这两个变量同一.Object类中定义的equals 函数原型为:public bo ...

  7. UVa 407

    此问题与求上升序列最大和类似,可以作为DAG模型计算.将每一快砖分解为3块,将所有砖块按照底排序,注意sort排序中涉及到底的两个参数x,y,这时候一定要有优先排,比如先排x再排y,不能同时排x和y, ...

  8. 怎样从server获取图片

    今天写了安卓程序与server通信.当中须要从server获取图片.本来以为下载流.处理文件流非常复杂.结果几句话就轻松搞定了.如今记在这里. // (2014.5.1第一种方法)通过server返回 ...

  9. Python开发easy忽略的问题

    这篇文章主要介绍了Python程序猿代码编写时应该避免的17个"坑",也能够说成Python程序猿代码编写时应该避免的17个问题,须要的朋友能够參考下 一.不要使用可变对象作为函数 ...

  10. ElasticSearch获取指定Field数据的Java方法

    ElasticSearch(ES)检索后需要结果时,可能通过source接口读出.但是这样的话,返回的结果会很多.在调用search方法时,我们可以添加addfield或addfields方法,仅仅读 ...