当前位置: 首页 > article >正文

.NETCore Serilog 代码设置相关参数说明及按Sink设置不同级别(不同日志级别),使用异步方式写日志

rollingInterval设置为RollingInterval.Day与fileSizeLimitBytes配合使用在.NET Core Serilog中同时设置rollingInterval RollingInterval.Day和fileSizeLimitBytes参数并不会产生配置冲突。这两个参数实际上是互补的共同提供了更灵活的日志文件管理策略。如果您喜欢此文章请收藏、点赞、评论谢谢祝您快乐每一天。正常普通配置参考这一篇.NETCore Serilog 代码设置 按指定大小生成日志方式https://blog.csdn.net/hefeng_aspnet/article/details/155065007参数协同工作原理Serilog的文件接收器能够同时处理基于时间和基于大小的滚动策略。当日志写入时系统会优先检查文件大小限制如果当前文件达到fileSizeLimitBytes指定的大小就会立即创建新的日志文件。同时无论文件大小如何每到新的一天根据RollingInterval.Day设置系统也会自动创建新的日志文件。实际文件生成示例假设配置如下.WriteTo.File(logs/app.log,rollingInterval: RollingInterval.Day,fileSizeLimitBytes: 10 * 1024 * 1024,rollOnFileSizeLimit: true)可能产生的文件序列包括app20251118_001.log当日第一个文件达到10MB后滚动app20251118_002.log当日第二个文件app20251119_001.log次日新建文件配置建议在实际应用中这种组合配置特别适用于高流量的生产环境既能防止单个日志文件过大影响性能又能按天归档便于日志分析。您可以根据具体需求调整这两个参数的值它们会协同工作而不会相互干扰。shared、flushToDiskInterval 配置在Serilog的File接收器配置中shared和flushToDiskInterval是两个用于控制文件写入行为的参数。shared参数设置为true时允许日志文件被多个进程共享访问这在多进程环境中特别有用。当启用此选项后多个应用程序实例可以同时向同一个日志文件写入内容而不会产生访问冲突。flushToDiskInterval参数则用于控制日志内容刷新到磁盘的时间间隔。通过设置此参数可以平衡日志记录的实时性与系统性能确保在指定时间间隔内将缓冲的日志数据持久化到存储介质中。以下是包含这两个参数的完整配置示例Log.Logger new LoggerConfiguration().WriteTo.File(logs/app.log,shared: true, // 允许多进程共享flushToDiskInterval: TimeSpan.FromSeconds(1) // 每秒刷新到磁盘).CreateLogger();在实际应用中可以根据具体需求调整flushToDiskInterval的值较短的间隔能提供更好的数据安全性但可能影响性能较长的间隔则相反。按Sink设置不同级别使用异步方式写日志在Serilog中按Sink设置不同级别并使用异步方式可以通过为每个Sink指定restrictedToMinimumLevel参数来限制日志级别同时使用Serilog.Sinks.Async包实现异步写入。以下是完整的配置示例using Serilog;using Serilog.Events;Log.Logger new LoggerConfiguration().MinimumLevel.Debug() // 全局最低级别// 信息级别日志 - 异步写入.WriteTo.Async(a a.File(logs/information/log-.txt,restrictedToMinimumLevel: LogEventLevel.Information,rollingInterval: RollingInterval.Day,fileSizeLimitBytes: 10 * 1024 * 1024,rollOnFileSizeLimit: true,retainedFileCountLimit: null))// 错误级别日志 - 异步写入.WriteTo.Async(a a.File(logs/error/log-.txt,restrictedToMinimumLevel: LogEventLevel.Error,rollingInterval: RollingInterval.Day,fileSizeLimitBytes: 5 * 1024 * 1024,rollOnFileSizeLimit: true))// 调试级别日志 - 异步写入到控制台.WriteTo.Async(a a.Console(restrictedToMinimumLevel: LogEventLevel.Debug))// 控制台输出所有级别.WriteTo.Console().CreateLogger();try{Log.Information(应用程序启动);// 测试不同级别的日志Log.Verbose(这是一条详细日志);Log.Debug(这是一条调试日志);Log.Information(这是一条信息日志);Log.Warning(这是一条警告日志);Log.Error(这是一条错误日志);Log.Fatal(这是一条严重错误日志);// 模拟应用程序运行await Task.Delay(1000);Log.Information(应用程序运行正常);}catch (Exception ex){Log.Fatal(ex, 应用程序异常终止);}finally{Log.CloseAndFlush();}此配置实现了以下功能特点通过异步写入机制避免了日志记录对主线程的阻塞为不同级别的日志配置了独立的Sink信息级别日志写入到logs/information/目录错误级别日志写入到logs/error/目录同时支持文件大小滚动和时间滚动策略确保日志文件管理的灵活性。如果您喜欢此文章请收藏、点赞、评论谢谢祝您快乐每一天。

相关文章:

.NETCore Serilog 代码设置相关参数说明及按Sink设置不同级别(不同日志级别),使用异步方式写日志

rollingInterval设置为RollingInterval.Day与fileSizeLimitBytes配合使用: 在.NET Core Serilog中,同时设置rollingInterval RollingInterval.Day和fileSizeLimitBytes参数并不会产生配置冲突。这两个参数实际上是互补的,共同提供了更灵活的…...

智慧城市中的时空AI:从路网数据到拥堵预测的完整项目拆解

智慧城市中的时空AI:从路网数据到拥堵预测的完整项目拆解 在省会城市早高峰的主干道上,交通信号灯与车流形成一场看不见的博弈。传统基于固定配时的信号控制系统,往往在突发拥堵面前显得力不从心。而某市"交通大脑"的落地案例显示&…...

Axure RP 中文语言包:3分钟消除语言障碍,释放原型设计效率

Axure RP 中文语言包:3分钟消除语言障碍,释放原型设计效率 【免费下载链接】axure-cn Chinese language file for Axure RP. Axure RP 简体中文语言包,不定期更新。支持 Axure 9、Axure 10。 项目地址: https://gitcode.com/gh_mirrors/ax/…...

REFramework技术实战指南:问题解决与架构优化

REFramework技术实战指南:问题解决与架构优化 【免费下载链接】REFramework REFramework 是 RE 引擎游戏的 mod 框架、脚本平台和工具集,能安装各类 mod,修复游戏崩溃、卡顿等问题,还有开发者工具,让游戏体验更丰富。 …...

掌握NLP实践:从环境搭建到应用部署的6步学习指南

掌握NLP实践:从环境搭建到应用部署的6步学习指南 【免费下载链接】nlp-tutorial A list of NLP(Natural Language Processing) tutorials 项目地址: https://gitcode.com/gh_mirrors/nlp/nlp-tutorial 自然语言处理(NLP)作为人工智能领…...

Docker构建速度太慢?试试替换Debian基础镜像的APT源为阿里云(附多版本Dockerfile写法)

加速Docker构建:Debian基础镜像APT源优化全指南 每次等待Docker镜像构建完成时,看着缓慢下载的进度条,是不是感觉时间仿佛被拉长了?特别是在国内网络环境下,从官方Debian源拉取软件包的速度简直让人抓狂。我曾经的一个…...

Redmine API实战指南:从数据同步到工作流自动化

Redmine API实战指南:从数据同步到工作流自动化 【免费下载链接】redmine Mirror of redmine code source - Official Subversion repository is at https://svn.redmine.org/redmine - contact: vividtone or maeda (at) farend (dot) jp 项目地址: https://gitc…...

如何快速掌握Sionna:下一代物理层研究开源库的5个实用技巧

如何快速掌握Sionna:下一代物理层研究开源库的5个实用技巧 【免费下载链接】sionna Sionna: An Open-Source Library for Next-Generation Physical Layer Research 项目地址: https://gitcode.com/gh_mirrors/si/sionna Sionna是一个基于TensorFlow的开源Py…...

ROS开发CMakeLists指南

1.常见命令1.1 find_packagefind_package(catkin REQUIRED COMPONENTSroscpprospy std_msgs )查找 catkin 构建系统和其他指定的 ROS 包加载 这些包的配置信息设置 相关变量供后续使用:${catkin_INCLUDE_DIRS} - 包含所有依赖包的头文件路径${catkin_LIBRARIES} - …...

Qt图形项事件处理全解析:从mousePressEvent到mouseReleaseEvent的正确姿势

1. Qt图形项鼠标事件处理的核心机制 在Qt框架中处理图形项的鼠标交互,本质上是在和事件传播机制打交道。我刚接触Qt图形视图框架时,也曾被mouseMoveEvent不触发的问题困扰过整整两天。后来才发现,这其实是一套设计精巧的事件处理哲学——只有…...

CVPR/ICML/TMI顶会风向标:医学图像分割三大落地范式,从模型精调到临床闭环

1. 医学图像分割的临床落地挑战与范式转变 医学图像分割作为AI在医疗领域最成熟的应用之一,正经历着从实验室精度竞赛到临床实用落地的关键转型。我在参与多家三甲医院PACS系统智能化改造时发现,临床医生对算法的需求呈现明显的"三高"特征&…...

Windows 11 + Ubuntu 20.04双系统安装避坑指南(附分区方案)

Windows 11与Ubuntu 20.04双系统安装全流程精解 对于想要在现有Windows 11系统上体验Ubuntu的用户来说,双系统安装是最佳选择。这种方式既能保留熟悉的Windows环境,又能探索Linux世界的无限可能。本文将详细解析从准备到安装的完整流程,特别针…...

从数据到洞察:如何利用2024版建筑高度SHP数据,5步完成城市热岛效应初步分析

从数据到洞察:如何利用2024版建筑高度SHP数据,5步完成城市热岛效应初步分析 城市热岛效应是城市化进程中普遍存在的环境问题,表现为城市中心区域温度明显高于周边郊区的现象。这种现象不仅影响居民的生活质量,还会加剧能源消耗和空…...

城市开车GPS总飘?试试给惯性导航(INS)加个“车轮锁”:NHC/ODO约束原理通俗解读

城市开车GPS总飘?试试给惯性导航(INS)加个“车轮锁”:NHC/ODO约束原理通俗解读 你是否遇到过这样的场景:开车穿过高楼林立的CBD时,车载导航突然开始"鬼畜漂移"?或是驶入隧道后&#x…...

SegFormer源码解读:从注意力机制到特征融合的实现细节

SegFormer源码解读:从注意力机制到特征融合的实现细节 【免费下载链接】SegFormer Official PyTorch implementation of SegFormer 项目地址: https://gitcode.com/gh_mirrors/se/SegFormer SegFormer是一个基于Transformer的语义分割模型,它通过…...

打开软件就弹出D3DCompiler_47.dll错误 免费下载修复方法分享

在使用电脑系统时经常会出现丢失找不到某些文件的情况,由于很多常用软件都是采用 Microsoft Visual Studio 编写的,所以这类软件的运行需要依赖微软Visual C运行库,比如像 QQ、迅雷、Adobe 软件等等,如果没有安装VC运行库或者安装…...

Ensp与SecureCRT高效连接指南及常见回车空行问题排查

1. Ensp与SecureCRT连接全流程详解 第一次用Ensp连接SecureCRT时,我也被那一堆串口参数搞得头晕。后来才发现,只要掌握几个关键步骤,整个过程其实非常简单。下面我就把踩坑后总结的最稳定连接方案分享给大家。 1.1 软件安装与环境准备 在开始…...

打开软件就弹出d3dcompiler_43.dll丢失找不到 免费下载修复方法分享

在使用电脑系统时经常会出现丢失找不到某些文件的情况,由于很多常用软件都是采用 Microsoft Visual Studio 编写的,所以这类软件的运行需要依赖微软Visual C运行库,比如像 QQ、迅雷、Adobe 软件等等,如果没有安装VC运行库或者安装…...

FOC算法中SIMULINK常用模块解析:从坐标变换到SVPWM(实践指南)

1. FOC算法与SIMULINK模块概述 第一次接触FOC(磁场定向控制)算法时,我被那些复杂的坐标变换搞得晕头转向。直到在SIMULINK里亲手搭建了完整的控制环路,才真正理解每个模块的作用。FOC算法的核心思想,简单来说就是把三相…...

GemPy:让三维地质建模从复杂算法变成简单Python代码

GemPy:让三维地质建模从复杂算法变成简单Python代码 【免费下载链接】gempy GemPy is an open-source, Python-based 3-D structural geological modeling software, which allows the implicit (i.e. automatic) creation of complex geological models from inter…...

OpenClaw多语言支持:百川2-13B量化模型国际化任务实践

OpenClaw多语言支持:百川2-13B量化模型国际化任务实践 1. 为什么需要多语言自动化助手 去年接手一个跨国协作项目时,我每天要处理来自五个国家的邮件、文档和会议记录。最头疼的不是时差问题,而是不同语言的文档混在一起——英文技术规范、…...

Java Spring Boot 中构造器循环依赖的处理

本文探讨了 Java Spring Boot 循环依赖问题是由于工程中结构设计不当造成的。通过分析示例代码,解释了循环依赖的原因,并提供了有效的解决方案来避免这些问题,重点是避免在结构中创建依赖对象的新例子,以防止无限递归调用 StackOv…...

手把手教你搭建轻量级Gitea代码托管平台:Windows本地部署实战

1. 为什么选择Gitea作为本地代码托管平台 作为一个长期在Windows环境下开发的程序员,我深知一个轻量级代码托管平台的重要性。以前我也用过Gitblit这类工具,但随着项目复杂度提升,越来越需要一个更现代的解决方案。Gitea就像是为个人开发者量…...

掌握NeuralForecast:构建企业级时间序列预测解决方案

掌握NeuralForecast:构建企业级时间序列预测解决方案 【免费下载链接】neuralforecast Nixtla/neuralforecast - 一个Python库,提供统一的接口来训练和预测时间序列数据,使用神经网络方法,如N-BEATS和N-HITS,以及传统的…...

4大价值点:旧设备复活开源工具如何让经典iOS设备重获新生?

4大价值点:旧设备复活开源工具如何让经典iOS设备重获新生? 【免费下载链接】Legacy-iOS-Kit An all-in-one tool to downgrade/restore, save SHSH blobs, and jailbreak legacy iOS devices 项目地址: https://gitcode.com/gh_mirrors/le/Legacy-iOS-…...

RVC与VITS技术对比:检索式vs端到端语音转换的适用场景分析

RVC与VITS技术对比:检索式vs端到端语音转换的适用场景分析 1. 引言 你有没有想过,为什么有些AI翻唱听起来特别像原唱,而有些则感觉“味儿”不太对?或者,为什么有些语音转换工具训练起来飞快,但效果时好时…...

利用Python和快速傅里叶变换解析振动传感器数据:从趋势图到频谱分析的完整指南

1. 振动传感器数据分析入门指南 当你第一次拿到振动传感器采集的数据时,可能会被满屏的数字搞得一头雾水。别担心,我刚开始接触时也是这样。振动数据就像是一本用密码写成的日记,而Python和快速傅里叶变换(FFT)就是我们破译这些密码的神奇工具…...

永磁同步电机矢量控制进阶:电流环前馈补偿的5个关键点与避坑指南

永磁同步电机矢量控制进阶:电流环前馈补偿的5个关键点与避坑指南 在工业伺服系统与新能源驱动领域,永磁同步电机(PMSM)凭借其高功率密度和动态响应特性占据主导地位。而电流环作为矢量控制的内环,其性能直接影响整个系…...

PowerPaint-V1 Gradio 新手入门指南:3步搞定图片修复,小白也能变大神

PowerPaint-V1 Gradio 新手入门指南:3步搞定图片修复,小白也能变大神 1. 为什么选择PowerPaint-V1? 如果你经常需要处理图片中的瑕疵、水印或者想替换某些元素,PowerPaint-V1绝对是你的得力助手。这个由字节跳动与香港大学联合研…...

这次终于选对了!2026年性价比拉满的专业AI论文网站

2026年AI论文写作工具已从“基础辅助”升级为融合多模态处理与学术合规的智能写作系统,核心评价维度涵盖文献真实性、格式合规性、长文本逻辑、查重降重、AIGC合规与跨语言支持。本次测评覆盖6款主流工具,测试场景包含中文与英文论文、全流程与专项功能、…...