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

    前言 通过ReactiveCocoa(一)的学习,相信大家对ReactiveCocoa有了一些基本认识吧.下面就让我们来学习ReactiveCocoa的一些基本使用吧! ReactiveCocoa基本 ...

  2. my-git-wiki-doing

    github项目quick setup git初始化 git init git添加remote git remote add origin YOURS_REMOTE_URL git修改remote的u ...

  3. Number of Connected Components in an Undirected Graph -- LeetCode

    Given n nodes labeled from 0 to n - 1 and a list of undirected edges (each edge is a pair of nodes), ...

  4. [BZOJ 1509] 逃学的小孩

    Link: BZOJ 1509 传送门 Solution: 一开始受样例影响又犯了想当然的毛病……图中的C点不一定在直径上! 3次$dfs$求出树的直径及直径的两个端点$rt1,rt2$到每个点的距离 ...

  5. HNOI2016 游记

    题外 忽然想起去年的HNOI2015总结里好像引了一句诗: 此情可待成追忆,只是当时已惘然. Day0 唔,感觉不知道想些什么,只是觉得其实还没有做好准备,想学的东西学的仓促,想复习的东西,也只能看一 ...

  6. Bluetooth篇 开发实例之六 蓝牙RSSI计算距离

    计算公式: d = 10^((abs(RSSI) - A) / (10 * n)) 其中: d - 计算所得距离 RSSI - 接收信号强度(负值) A - 发射端和接收端相隔1米时的信号强度 n - ...

  7. espresso 元素遮挡问题。

    在使用espresso进行测试的时候,点击一个横向列表的时候会在点击的项目下出现对应的横线. 实现方式是在FrameLayout下放两个TextView, 一个TextView包含下划线,默认是Fra ...

  8. JAVA常见算法题(九)

    package com.xiaowu.demo; /** * * 一个数如果恰好等于它的因子之和,这个数就称为"完数".例如6=1+2+3.编程找出1000以内的所有完数. * * ...

  9. NFS 服务配置篇

    安装.配置NFS服务 1.NFS简介 NFS(network file system) NFS是一个主机A通过网络,允许其他主机B可以来共享主机A的一个目录文件的一个文件系统 2.需要安装两个包nfs ...

  10. python下性能提示

    性能提示 3.1 嵌套if/else结构比一系列单选if结构块,因为只要有一个条件满足,其余测试就会终止. 3.2 在嵌套if/else结构中,把最可能成立的条件放在该嵌套结构的开始处.和把不常见的条 ...