使用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 项目日志记录是项目开发.运营必不可少的内容,有了它可以对系统有整体的把控,出现任何问题 ...
随机推荐
- #请用索引取出下面list的指定元素:
#!/usr/bin/python # -*- coding: utf-8 -*- L = [ ['Apple', 'Google', 'Microsoft'], ['Java', 'Python', ...
- 最近公共祖先LCA Tarjan 离线算法
[简介] 解决LCA问题的Tarjan算法利用并查集在一次DFS(深度优先遍历)中完成所有询问.换句话说,要所有询问都读入后才开始计算,所以是一种离线的算法. [原理] 先来看这样一个性质:当两个节点 ...
- The Art of Mocking
One of the challenges developers face when writing unit tests is how to handle external dependencies ...
- Linqpad使用(调试Linq、结合linq调试业务场景、表格内编辑数据)
linqpad是一款linq语句调试工具,功能如下: 1.直接执行linq语句并查看生成的原生sql语句 2.可结合linq+C#代码进行业务场景调试 3.表格内直接新增.修改.删除数据 4.直接 ...
- VUE -- ejs模板的书写
1.EJS是一个简单高效的模板语言,通过数据和模板,可以生成HTML标记文本.可以说EJS是一个JavaScript库,EJS可以同时运行在客户端和服务器端,客户端安装直接引入文件即可,服务器端用np ...
- JAVA常见算法题(九)
package com.xiaowu.demo; /** * * 一个数如果恰好等于它的因子之和,这个数就称为"完数".例如6=1+2+3.编程找出1000以内的所有完数. * * ...
- Quartz配置CronTrigger
CronTrigger 构造器 String name, //触发器名称 String group, //触发器的组名 String jobName, //job名称 String jobGroup, ...
- 转换流的使用(InputStreamReader,OutputStreamWriter)
我们如何设置字节输入流.字节输出流的编码和解码格式? 在字节输入流(InputStream).字节输出流(OutputStream)中,并没有提供设置编码和解码格式的方法. InputStream的A ...
- 关于各浏览器的cookie上限
IE6~IE6以下,每个域名最多20个cookie IE7及以上,每个域名最多50个cookie Firefox,每个域名最多50个cookie Opera,每个域名最多30个cookie Safar ...
- Git历险记(二)——Git的安装和配置
各位同学,上回Git历险记(一)讲了一个 “hello Git” 的小故事.有的同学可能是玩过了其它分布式版本控制系统(DVCS),看完之后就触类旁通对Git就了然于胸了:也有的同学可能还如我当初入手 ...