.Net Core的Log方式:Serilog+Kibana

前言

Serilog,支持对象,把log数据序列化成Json,好用方便,容易拓展。Github: https://github.com/handsomeyao77/serilog-sinks-elasticsearch

读取配置文件的

配置文件分为App.config和appsetting.json两种。
读取appsettings.json,主要是Web app 类型,首先在服务启动时要注入json文件:
600371-20180903112533706-1254277313.png

600371-20180903112613509-1099659706.png

读取配置:
600371-20180903161038549-1765100040.png

配置App.config,高亮部分是必要的key:
600371-20180903112952847-1349905468.png

读取配置:
600371-20180903112402429-1880483558.png

当然,有时候可以Hard code,这里分享一种方式:
600371-20180903113158561-2052339594.png

Serilog的常见类型

1.Information.
600371-20180903113328086-2048882899.png

2.Debug.
600371-20180903113406965-117950713.png

3.Error.
600371-20180903113437976-1523403215.png

因为LogEventBase作为基类,可以继承拓展一下。

public class LogEventBase
{
    [FieldOrder(0)]
    public LogEventType EventType { get; set; }

    [FieldOrder(1)]
    public string Role { get; set; }

    [FieldOrder(2)]
    public string RoleInstance { get; set; }

    [FieldOrder(3)]
    public string Ip { get; set; }

    [FieldOrder(4)]
    public int Port { get; set; }

    [FieldOrder(5)]
    public DateTime Timestamp => DateTime.UtcNow;

    [FieldOrder(6)]
    public string Message { get; set; }

    [FieldOrder(7)]
    public IActivity Activity { get; set; }

    [FieldOrder(8)]
    public string EnvironmentName => Environment.MachineName;
}

根据业务拓展:

public class LatencyEvent : LogEventBase
{
    [FieldOrder(9)]
    public long Latency { get; set; }

    [FieldOrder(10)]
    public string SearchId { get; set; }
}

public class SearchEvent : LogEventBase
{
    [FieldOrder(9)]
    public string SearchId { get; set; }
    [FieldOrder(10)]
    public string SearchString { get; set; }
}

public class LuisEvent : LogEventBase
{
    [FieldOrder(9)]
    public LuisResult LuisResult { get; set; }
}

public class ExceptionEvent : LogEventBase
{
    [FieldOrder(10)]
    public Exception Exception { get; set; }
}

LogEventType是比较实用的,在kibana查看log是作为过滤条件能节省很多时间。

使用方法

1.Information

600371-20180903114049065-1614573570.png

2.Error

600371-20180903114137628-1772833004.png

Kibana

打开kibana主页,选择对应的template,可以说非常好用的log工具。可以按照log的时间,或者输入查询条件:

600371-20180903114448764-1797234676.png

或者按照LogEventType,可以快速定位到target:
600371-20180903114744198-1401370947.png

转载于:https://www.cnblogs.com/shy-huang/p/9577735.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值