1. 程式人生 > >.Net Core的Log方式:Serilog+Kibana

.Net Core的Log方式:Serilog+Kibana

ron href onf exce har json https setting github

前言

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

讀取配置文件的

配置文件分為App.config和appsetting.json兩種。
讀取appsettings.json,主要是Web app 類型,首先在服務啟動時要註入json文件:
技術分享圖片

技術分享圖片

讀取配置:

配置App.config,高亮部分是必要的key:
技術分享圖片

讀取配置:
技術分享圖片

當然,有時候可以Hard code,這裏分享一種方式:
技術分享圖片

Serilog的常見類型

1.Information.

技術分享圖片

2.Debug.
技術分享圖片

3.Error.
技術分享圖片

因為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

技術分享圖片

2.Error

技術分享圖片

Kibana

打開kibana主頁,選擇對應的template,可以說非常好用的log工具。可以按照log的時間,或者輸入查詢條件:

技術分享圖片

或者按照LogEventType,可以快速定位到target:
技術分享圖片

.Net Core的Log方式:Serilog+Kibana