0

0

C#文件系统观察器可靠性 C#如何解决FileSystemWatcher事件丢失或重复的问题

畫卷琴夢

畫卷琴夢

发布时间:2026-02-25 08:48:11

|

121人浏览过

|

来源于php中文网

原创

filesystemwatcher 丢事件或重复触发的根本原因是其底层依赖的 readdirectorychangesw 使用固定大小内核缓冲区(默认8kb),溢出即丢弃且不报错;重命名等操作被拆分为多个底层事件导致应用层误判。

c#文件系统观察器可靠性 c#如何解决filesystemwatcher事件丢失或重复的问题

FileSystemWatcher 为什么总是丢事件或重复触发

根本原因是 FileSystemWatcher 底层依赖 Windows API 的 ReadDirectoryChangesW,它用固定大小的内核缓冲区(默认 8KB)暂存文件系统通知。缓冲区溢出时,事件直接丢弃,且不报错;而重命名、移动等操作可能被拆成多个底层事件(如先删除再新建),导致应用层看到重复或错乱的 Created/Renamed

如何避免缓冲区溢出导致的事件丢失

关键不是盲目调大 InternalBufferSize,而是结合业务节奏合理设置:

  • InternalBufferSize 必须是 4096 的整数倍,建议从 65536(64KB)起步,但不要超过 640KB(Windows 限制)
  • 高频写入场景下,必须监听 Error 事件并检查 EventArgs.Error 是否为 ERROR_NOTIFY_ENUM_DIR(即缓冲区已满)
  • 一旦捕获该错误,应立即记录告警,并考虑临时降级:比如暂停非关键监听、触发一次全量扫描补漏
  • 避免在事件回调中做耗时操作(如 IO、网络请求),否则会阻塞后续事件分发线程,间接加剧丢事件风险

如何识别和合并重复的 Renamed 或 Created 事件

Rename 是最易误判的操作——例如 VS 编译器保存文件时,常先写临时文件再原子替换,FileSystemWatcher 会报告 Created + Deleted + Renamed 一连串事件。解决思路是加时间窗口+路径指纹去重:

HIX.AI
HIX.AI

HIX.AI是一个多功能的一体化AI写作助手,集成了120多种AI写作工具,支持50多种语言,能够满足各种写作需求。

下载
  • ConcurrentDictionary<string datetime></string> 缓存最近 5 秒内所有事件的 FullPath 及时间戳
  • Renamed 回调里,检查 e.OldFullPathe.FullPath 是否都在缓存中且时间差
  • Created 事件,可配合 File.GetLastWriteTimeUtc() 检查是否与上一个同名文件的修改时间接近(防编辑器临时文件干扰)

替代方案:什么时候该放弃 FileSystemWatcher

当业务要求强一致性(如备份工具、审计日志),FileSystemWatcher 不适合单独使用:

  • 短生命周期文件(如日志轮转生成的 .tmp 文件)极易被漏掉
  • 跨卷移动、硬链接、符号链接等操作无法被可靠捕获
  • 推荐组合策略:用 FileSystemWatcher 做“快响应”提示,再辅以定时扫描(如每 30 秒查 Directory.EnumerateFiles() + FileInfo.LastWriteTimeUtc)做最终校验
  • 更重场景可考虑 Windows 的 USN Journal(需管理员权限 + 驱动级访问),但开发成本陡增,多数应用没必要

真正难处理的永远不是“怎么监听”,而是“怎么确认监听到了全部”。缓冲区溢出无声无息,重复事件又常发生在调试环境里不复现——上线前务必用高并发写入脚本压测,别只靠单步调试信誓旦旦。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

850

2023.08.02

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

391

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

348

2023.10.25

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

720

2023.08.10

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

1256

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1153

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

823

2023.08.01

windows查看端口被占用的情况
windows查看端口被占用的情况

windows查看端口被占用的情况的方法:1、使用Windows自带的资源监视器;2、使用命令提示符查看端口信息;3、使用任务管理器查看占用端口的进程。本专题为大家提供windows查看端口被占用的情况的相关的文章、下载、课程内容,供大家免费下载体验。

460

2023.08.02

Golang 生态工具与框架:扩展开发能力
Golang 生态工具与框架:扩展开发能力

《Golang 生态工具与框架》系统梳理 Go 语言在实际工程中的主流工具链与框架选型思路,涵盖 Web 框架、RPC 通信、依赖管理、测试工具、代码生成与项目结构设计等内容。通过真实项目场景解析不同工具的适用边界与组合方式,帮助开发者构建高效、可维护的 Go 工程体系,并提升团队协作与交付效率。

1

2026.02.24

热门下载

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

精品课程

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

共94课时 | 10.2万人学习

C 教程
C 教程

共75课时 | 4.9万人学习

C++教程
C++教程

共115课时 | 19.3万人学习

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

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