0

0

C#实现日志文件滚动 C#如何按日期或大小分割日志文件

畫卷琴夢

畫卷琴夢

发布时间:2026-02-22 14:13:02

|

209人浏览过

|

来源于php中文网

原创

nlog按日期滚动最直接,需设archiveevery="day"且enablearchivefilecompression="false";serilog按大小滚动更可控,须设rollonfilesizelimit=true和filesizelimitbytes;手动实现需避免filestream锁与时钟误差。

c#实现日志文件滚动 c#如何按日期或大小分割日志文件

NLog 配置按日期滚动最直接

绝大多数 C# 项目不需要手写滚动逻辑,NLog 内置的 FileTarget 支持开箱即用的日期滚动。关键不是“能不能”,而是“怎么配不踩坑”。

常见错误是只设 archiveEvery="Day" 却没关掉 enableArchiveFileCompression="false"(默认为 true),结果每天生成一堆 .zip 文件而非纯文本,排查日志时反而更麻烦。

推荐配置片段:

<target xsi:type="File" name="file" fileName="${basedir}/logs/app.log"
      archiveFileName="${basedir}/logs/app.{#}.log"
      archiveEvery="Day"
      archiveNumbering="Rolling"
      maxArchiveFiles="30"
      enableArchiveFileCompression="false" />
  • archiveNumbering="Rolling":旧文件编号递增(app.1.log, app.2.log…),比 Date 模式更易脚本清理
  • maxArchiveFiles="30":硬性限制归档数,否则磁盘可能被撑爆——这是生产环境最容易被忽略的点
  • 路径中避免使用 ${date:format=yyyy-MM-dd}fileName,会导致日志写入失败(NLog 不支持在主文件名里动态插日期)

Serilog + File sink 按大小切分更可靠

按大小滚动比按日期更可控,尤其适合高吞吐服务。Serilog 的 Serilog.Sinks.File 默认就支持,但默认行为容易误导人。

它不叫“按大小滚动”,而叫“按文件大小限制 + 自动重命名”。关键参数是 rollingIntervalretainedFileCountLimit,但真正触发切割的是 fileSizeLimitBytes

示例代码:

Log.Logger = new LoggerConfiguration()
    .WriteTo.File("logs/app.log",
        fileSizeLimitBytes: 10_485_760, // 10MB
        rollOnFileSizeLimit: true,
        retainedFileCountLimit: 7,
        rollingInterval: RollingInterval.Day) // 这个值其实不影响大小滚动,仅用于命名后缀
    .CreateLogger();
  • rollOnFileSizeLimit: true 必须显式开启,否则即使设了 fileSizeLimitBytes 也无效
  • retainedFileCountLimit: 7 是保留的**总文件数**(当前 + 归档),不是“最多存 7 天”——这点文档写得模糊,实际测试会发现第 8 个归档产生时,最老的就被删了
  • 归档文件名形如 app.log.20240520.txtapp.log.1.txt,取决于 rollingInterval 设置;若只想按大小切、不掺日期,设成 RollingInterval.Infinite 即可

手动实现滚动要绕开 FileStream 锁和时间判断误差

真要自己写(比如嵌入式场景或规避第三方依赖),核心难点不在逻辑,而在两个地方:FileStream 的独占锁导致无法安全重命名正在写的文件;以及服务器时钟跳变让“是否跨天”判断出错。

Motiff
Motiff

Motiff是由猿辅导旗下的一款界面设计工具,定位为“AI时代设计工具”

下载

解决方案不是修判断,而是换思路:

  • File.Move() 前先 stream.Dispose(),别试图在流开着时移动文件
  • 不依赖 DateTime.Now.Date 判断是否换日,改用“记录上一次滚动时间戳 + 24 小时检查”,避免 NTP 校时或夏令时导致误切
  • 大小判断别用 FileInfo.Length(可能因缓存不准),而是在每次 WriteLine 后累加已写字节数,更实时

一句话:手动滚动不是“写个计时器+判断大小”,而是“管好文件句柄生命周期 + 用增量计数替代查询”。

log4netRollingFileAppender 容易卡在 StaticLogFileName

老项目还在用 log4net 的话,RollingFileAppenderStaticLogFileName="false" 是开关,但默认是 true——这意味着即使你配了 datePattern,它也只写一个文件,不滚动。

典型错误配置:

<appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
  <file value="logs/app.log" />
  <datePattern value=".yyyy-MM-dd" />
  <rollingStyle value="Date" />
</appender>

缺了 <staticlogfilename value="false"></staticlogfilename>,上面配置完全无效。加上之后还要注意:datePattern 中的 . 会被当字面量,所以 .yyyy-MM-dd 生成的是 app.log.2024-05-20,而不是 app.2024-05-20.log

真正想按日期生成 app.YYYY-MM-DD.log,得把 <file></file> 设为空,靠 datePattern 构建完整文件名,且必须配合 staticLogFileName="false"

滚动逻辑本身不复杂,难的是边界:文件锁、时钟漂移、归档清理策略、压缩与可读性的权衡。选库时别只看“支持滚动”,要看它默认行为是否贴合你的运维习惯。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

866

2023.07.31

python中的format是什么意思
python中的format是什么意思

python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

452

2024.06.27

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

421

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

595

2023.08.10

length函数用法
length函数用法

length函数用于返回指定字符串的字符数或字节数。可以用于计算字符串的长度,以便在查询和处理字符串数据时进行操作和判断。 需要注意的是length函数计算的是字符串的字符数,而不是字节数。对于多字节字符集,一个字符可能由多个字节组成。因此,length函数在计算字符串长度时会将多字节字符作为一个字符来计算。更多关于length函数的用法,大家可以阅读本专题下面的文章。

952

2023.09.19

length函数用法
length函数用法

length函数用于返回指定字符串的字符数或字节数。可以用于计算字符串的长度,以便在查询和处理字符串数据时进行操作和判断。 需要注意的是length函数计算的是字符串的字符数,而不是字节数。对于多字节字符集,一个字符可能由多个字节组成。因此,length函数在计算字符串长度时会将多字节字符作为一个字符来计算。更多关于length函数的用法,大家可以阅读本专题下面的文章。

952

2023.09.19

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

928

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

307

2026.02.13

Flutter跨平台开发与状态管理实战
Flutter跨平台开发与状态管理实战

本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

183

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 9.9万人学习

C 教程
C 教程

共75课时 | 4.9万人学习

C++教程
C++教程

共115课时 | 18.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号