windows – 没有锁定的优雅文件阅读

白板概述

下面的图像是在ImageShack上托管的1000 x 750像素,~130 kB JPEG.

> Internal
> Global

附加信息

我应该提到每个用户(客户端盒子)将直接在/ Foo共享.由于业务的性质,用户永远不需要同时查看或处理彼此的文档,因此这种性质的冲突永远不会成为问题.访问需要对它们尽可能简单,这可能意味着将驱动器映射到它们各自的/ Foo / username子目录.

此外,除了我的应用程序(内部和服务器上的应用程序)之外,没有人会直接使用FTP目录.

可能的实施

不幸的是,看起来我不能使用WinSCP等现成的工具,因为其他一些逻辑需要与流程密切相关.

我认为有两种简单的方法让我在内部完成上述工作.

>方法一(慢):

>每N分钟走一次/ Foo目录树.
>使用时间戳的组合(可以通过文件复制工具伪造,但在这种情况下不相关)与校验和进行前一树的差异.
>与异地FTP服务器合并更改.

>方法二:

>注册目录更改通知(例如,使用WinAPI中的ReadDirectoryChangesW,如果使用.NET,则使用FileSystemWatcher).
>记录更改.
>每N分钟与异地FTP服务器合并更改.

由于性能方面的考虑,我可能最终会使用第二种方法.

问题

由于此同步必须在工作时间进行,因此出现的第一个问题是在非现场上载阶段.

当我在异地传输文件时,我实际上需要阻止用户写入文件(例如,使用带有FILE_SHARE_READ的CreateFile或其他东西),而我正在阅读它.他们办公室的互联网上游速度与他们正在使用的文件大小几乎没有对称,因此他们很可能会回到文件并尝试修改它,而我仍在阅读它.

可能解决方

解决上述问题的最简单方法是在文件系统的其他位置创建相关文件的副本,并在不受干扰的情况下传输这些“快照”.

这些人将使用的文件(有些将是二进制的)相对较小,可能≤20MB,因此复制(因此暂时锁定)它们几乎是即时的.他们试图在我复制它的同一瞬间写入文件的机会应该接近于零.

不过,这个解决方案似乎很难看,而且我很确定有更好的方法来处理这类问题.

我想到的一件事就是文件系统过滤器,它负责IRP级别的复制和同步,就像一些A / V那样.然而,这对我的项目来说太过分了.

问题

这是我第一次不得不处理这类问题,所以也许我在想太多.

我对干净的解决方案感兴趣,这些解决方案不需要过多地实现其复杂性.也许我错过了WinAPI中优雅处理这个问题的东西?

我还没有决定我会写什么,但我很满意:C,C,C#,D和Perl.

评论讨论后,我的建议如下:

>在数据服务器上创建一个分区,大约5GB以确保安全.
>在C#中创建一个用于监视数据驱动程序/位置的Windows服务项目.
>修改文件后,创建文件的本地副本,其中包含相同的目录结构并放置在新分区上.
>创建另一项服务,执行以下操作:

>监控带宽使用情况
>监视临时分区上的文件创建.
>一次将多个文件(使用线程)传输到FTP服务器,遵守当前时间的带宽使用情况,根据网络流量减少/增加工作线程.
>从已成功传输的分区中删除文件.

所以基本上你有你的驱动器:

> C:Windows安装
> D:共享存储
> X:临时分区

然后你会有以下服务:

> LocalMirrorService – 使用dir结构观察D:并复制到X :.
> TransferClientService – 将文件从X:移动到ftp服务器,从X中删除

>还可以使用多线程来移动倍数并监控带宽.

我敢打赌,这是你想到的想法,但这似乎是一种合理的方法,只要你的应用程序开发非常好,并且你能够创建一个可以处理大多数问题的可靠系统.

例如,当用户在Microsoft Word中编辑文档时,该文件将在共享上更改,并且可能会被复制到X:即使用户仍在使用它,在Windows中也会有API查看文件句柄是否为仍然由用户打开,如果是这种情况,那么你可以创建一个钩子来观察用户实际关闭文档以便所有编辑完成,然后你可以迁移到驱动器X:.

这就是说,如果用户正在处理文档并且由于某种原因PC崩溃,则文档/文件句柄可能在以后打开文档之前不会被释放,从而导致问题.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Windows注册表操作基础代码 Windows下对注册表进行操作使用的一段基础代码Reg.h:#pragmaonce#include<assert.h>#include<windows.h>classReg{HKEYhkey;public:voidopen(HKEYroot
黑客常用WinAPI函数整理之前的博客写了很多关于Windows编程的内容,在Windows环境下的黑客必须熟练掌握底层API编程。为了使读者对黑客常用的Windows API有个更全面的了解以及方便日后使用API方法的查询,特将这些常用的API按照7大分类进行整理如下,希望对大家的学习有所帮助。一
一个简单的Windows Socket可复用框架说起网络编程,无非是建立连接,发送数据,接收数据,关闭连接。曾经学习网络编程的时候用Java写了一些小的聊天程序,Java对网络接口函数的封装还是很简单实用的,但是在Windows下网络编程使用的Socket就显得稍微有点繁琐。这里介绍一个自己封装的一
Windows文件操作基础代码 Windows下对文件进行操作使用的一段基础代码File.h,首先是File类定义:#pragmaonce#include<Windows.h>#include<assert.h>classFile{HANDLEhFile;//文件句柄publ
Winpcap基础代码 使用Winpcap进行网络数据的截获和发送都需要的一段代码:#include<PCAP.H>#pragmacomment(lib,"wpcap.lib")//#pragmacomment(lib,"ws2_32.lib")#
使用vbs脚本进行批量编码转换 最近需要使用SourceInsight查看分析在Linux系统下开发的项目代码,我们知道Linux系统中文本文件默认编码格式是UTF-8,而Windows中文系统中的默认编码格式是Gb2312。系统内的编码格式有所区别倒无伤大雅,关键的是SourceInsigh...
缓冲区溢出攻击缓冲区溢出(Buffer Overflow)是计算机安全领域内既经典而又古老的话题。随着计算机系统安全性的加强,传统的缓冲区溢出攻击方式可能变得不再奏效,相应的介绍缓冲区溢出原理的资料也变得“大众化”起来。其中看雪的《0day安全:软件漏洞分析技术》一书将缓冲区溢出攻击的原理阐述得简洁
Windows字符集的统一与转换一、字符集的历史渊源在Windows编程时经常会遇到编码转换的问题,一直以来让刚接触的人摸不着头脑。其实只要弄清Win32程序使用的字符编码方式就清楚了,图1展示了一个Win32控制台项目的属性中的字符集选项。这里有两个不同的字符集:一个是Unicode字符集,另一个
远程线程注入引出的问题一、远程线程注入基本原理远程线程注入——相信对Windows底层编程和系统安全熟悉的人并不陌生,其主要核心在于一个Windows API函数CreateRemoteThread,通过它可以在另外一个进程中注入一个线程并执行。在提供便利的同时,正是因为如此,使得系统内部出现了安全
windows系统启动项怎么打开
win10系统文件夹的只读属性去不掉怎么办
windows.old可以删掉吗?
windows的网络功能主要通过什么来实现?
win10系统以太网不见了怎么办
win10安装cad缺少net组件怎么办
win10系统鼠标移动方向相反怎么办
如何ping局域网内所有IP
windows10的系统保留分区有什么用
win10系统无法删除账户怎么办
win10系统音频服务未响应怎么办