.Net Core的Log方式:Serilog+Kibana
阿新 • • 發佈:2018-09-03
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