最近公司有个需求,要对业务日志进行记录并根据日志排查问题,以前都是使用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. [BZOJ2460][BJOI2011]元素(线性基)

    2460: [BeiJing2011]元素 Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 2195  Solved: 1119[Submit][Sta ...

  2. Java类的定义及其实例化

    如果你不了解类和对象的概念,请猛击这里:Java类和对象的概念 类必须先定义才能使用.类是创建对象的模板,创建对象也叫类的实例化. 下面通过一个简单的例子来理解Java中类的定义: public cl ...

  3. linux 下查看硬件信息(mac,IP地址,硬盘型号,序列号等)

    一.查看网卡mac地址 #安装lshw [root@server ~]# yum install lshw #使用方法 [root@rsync-server ~]# lshw -c network * ...

  4. redis批量删除多个keys

    Redis的官网redis.io,大家可以查看很多命令的使用方法 说明:删除单个key比较简单,直接使用命令del xxxkey,批量删除多个keys可利用如下命令: 假设:redis的安装目录如下: ...

  5. JS或jQuery获取当前屏幕宽度

    Javascript: 网页可见区域宽: document.body.clientWidth网页可见区域高: document.body.clientHeight网页可见区域宽: document.b ...

  6. 【共享单车】—— React后台管理系统开发手记:项目工程化开发

    前言:以下内容基于React全家桶+AntD实战课程的学习实践过程记录.最终成果github地址:https://github.com/66Web/react-antd-manager,欢迎star. ...

  7. Visual Studio 2015 Update 1 安装到最后 KB3022398 错误解决方法

    最后一步遇到一个错误的确让人心寒 只是我们还是得一步步解决.别去卸载重装.太费时 首先打开 regedit 注冊表,依次进入: 1:HKEY_LOCAL_MACHINE\SOFTWARE\Micros ...

  8. Eclipse对于多个Java项目的支持并不友好!

    本文吐槽! 如果我们创建两个Java项目.一个叫StatsReader.把数据从网上下载到本地数据库里.一个叫StatsViewer.把数据从数据库里拿出来呈现给用户.这两个项目都要用同一个外部类库m ...

  9. Sql Server 表分区(转)

    什么是表分区 一般情况下,我们建立数据库表时,表数据都存放在一个文件里. 但是如果是分区表的话,表数据就会按照你指定的规则分放到不同的文件里,把一个大的数据文件拆分为多个小文件,还可以把这些小文件放在 ...

  10. iOS项目开发实战——使用同步请求获取网页源码

    网络请求一般分为同步请求和异步请求,同步请求假设訪问时间过长,会造成界面卡死状态,用户体验不是非常好.可是请求速度较快的话,也能够考虑使用同步訪问.如今先来学习同步訪问. (1)在viewDidLoa ...