有网站吗推荐一下,广西兴业县建设局网站,网站建设的岗位名称,居民瑞app下载目录
一、日志Sink(接收器)
二、Trace追踪实现日志
三、日志滚动 一、日志Sink(接收器)
安装NuGet包#xff1a;Serilog Sink有很多种#xff0c;这里介绍两种#xff1a; Console接收器#xff08;安装Serilog.Sinks.Console#xff09;; File接收器#xff08;安装…目录
一、日志Sink(接收器)
二、Trace追踪实现日志
三、日志滚动 一、日志Sink(接收器)
安装NuGet包Serilog Sink有很多种这里介绍两种 Console接收器安装Serilog.Sinks.Console; File接收器安装Serilog.Sinks.File; MinimumLevel最小记录级别 rollingInterval:生成日志文件周期 outputTemplate:输出日志模板 继承ILogEventSink接口实现 Emit当Sink器接收到新日志时触发 通过该接口将接收器接收的日志添加进内部日志集合 将该接口实现类实例化对象通过WriteTo.Sink(myEventSink)与Logger绑定 实现 ILogEventSink接口示例 public Liststring Logs new Liststring();private readonly ITextFormatter _formatternew MessageTemplateTextFormatter(Message:{Message} [{Level}] Location:{FilePath}[{LineNumber}]);public void Emit(LogEvent logEvent){if (logEvent ! null){var textWriternew StringWriter();_formatter.Format(logEvent, textWriter);Logs.Add(textWriter.ToString());}} Main程序 MyEventSink myEventSink new MyEventSink();string path Logs\\Error\\.txt;string outputTemplate {NewLine}Date: {Timestamp:yyyy-MM-dd HH:mm:ss.fff}\tLevel: {Level}\tCallName: {SourceContext}-{MemberName} {NewLine}Path: {FilePath}[{LineNumber}] {NewLine}Message: {Message};Log.Logger new LoggerConfiguration().Enrich.FromLogContext()//记录相关上下文信息.MinimumLevel.Debug().WriteTo.Sink(myEventSink).WriteTo.Logger(log log.Filter.ByIncludingOnly(p p.Level LogEventLevel.Error).WriteTo.File(path, rollingInterval: RollingInterval.Day, outputTemplate: outputTemplate)).WriteTo.Console().CreateLogger();Log.Warning(*****************Warning***************);Log.Logger.Information(*******************Info****************);Log.Logger.CallErrorTest(#####################Error##################);foreach (string str in myEventSink.Logs){Console.WriteLine(str);} static class LogExtension{public static void CallErrorT(this ILogger logger, string message,[CallerMemberName] string meberName ,[CallerFilePath] string filepath ,[CallerLineNumber] int lineNum 0) logger.ForContextT().ForContext(MemberName, meberName).ForContext(FilePath, filepath).ForContext(LineNumber, lineNum).Error(message);public static void CallErrorT(this ILogger logger, Exception e, string message,[CallerMemberName] string meberName ,[CallerFilePath] string filepath ,[CallerLineNumber] int lineNum 0) logger.ForContextT().ForContext(MemberName, meberName).ForContext(FilePath, filepath).ForContext(LineNumber, lineNum).Error(e, message);}
二、Trace追踪实现日志 继承抽象类TraceListener重写方法TraceEvent 注意添加监听对象Trace.Listeners.Add(this); public override void TraceEvent(TraceEventCache? eventCache, string source, TraceEventType eventType, int id, string? message){switch (eventType){case TraceEventType.Error:Log.Logger.CallErrorMyTraceListen(message);break;case TraceEventType.Warning:Log.Logger.Warning(message);break;case TraceEventType.Information:Log.Logger.Information(message);break;default:break;}}
三、日志滚动 通过ObservableCollection类的CollectionChanged事件实现日志自动滚动到底部 集合改变触发事件更改附加属性AutoScroll值值更改触发CallBack将日志滚动到底部 注意MouseEnter与MouseLeave两事件的响应原因查看日志时防止日志自动滚动到底部 DataGrid attach:ScrollHelper.AutoScroll{Binding AutoScroll}AutoGenerateColumnsFalseCanUserAddRowsFalseCanUserDeleteRowsFalseCanUserReorderColumnsFalseCanUserResizeColumnsFalseCanUserResizeRowsFalseCanUserSortColumnsFalseItemsSource{Binding LogService.Logs}i:Interaction.Triggersi:EventTrigger EventNameMouseEnteri:InvokeCommandAction Command{Binding MouseEnterCommand} //i:EventTriggeri:EventTrigger EventNameMouseLeavei:InvokeCommandAction Command{Binding MouseLeaveCommand} //i:EventTrigger/i:Interaction.TriggersDataGrid.ColumnsDataGridTextColumn Binding{Binding Time} Header时间 /DataGridTextColumn Binding{Binding Lev} Header级别 /DataGridTextColumn Binding{Binding Message} Header信息DataGridTextColumn.ElementStyleStyleSetter PropertyTextBlock.TextWrapping ValueWrap /Setter PropertyTextBlock.TextAlignment ValueLeft //Style/DataGridTextColumn.ElementStyle/DataGridTextColumn/DataGrid.ColumnsDataGrid.RowStyleStyle TargetTypeDataGridRow BasedOn{StaticResource DataGridRowStyle}Style.TriggersDataTrigger Binding{Binding Lev} ValueErrorSetter PropertyForeground ValueRed//DataTriggerDataTrigger Binding{Binding Lev} ValueWarnSetter PropertyForeground ValueOrange//DataTrigger/Style.Triggers/Style/DataGrid.RowStyle/DataGrid public LogService LogService { get; set; }LogService.GetInstance();private bool _autoScroll;public bool AutoScroll{get { return _autoScroll; }set SetProperty(ref _autoScroll, value);}[RelayCommand]public void MouseEnter(){LogService._logs.CollectionChanged - Scroll;}[RelayCommand]public void MouseLeave(){LogService._logs.CollectionChanged Scroll;}private void Scroll(object sender, NotifyCollectionChangedEventArgs e){AutoScroll !AutoScroll;}public MainWinViewModel(){LogService.OpenListen();LogService._logs.CollectionChanged Scroll;}