- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我有一个分布式应用;也就是说,我有一个在多台计算机上运行的同构进程,它与中央数据库通信并访问网络文件共享。
此过程从网络文件共享(通过 CIFS)中获取集合文件,对这些文件运行转换算法并将输出复制回网络文件共享。
我需要锁定输入文件,以便运行相同进程的其他服务器不会处理相同的文件。为了便于争论,假设我的描述过于简单,并且锁是绝对必须的。
这是我提出的解决方案和一些想法。
1) 使用机会锁(oplocks)。此解决方案仅使用文件系统来锁定文件。这里的问题是,我们必须尝试获取锁才能确定锁是否存在。这似乎很昂贵,因为网络重定向器会协商锁定。这样做的好处是,机会锁可以以这样的方式创建,当出现错误时它们会自行删除。
2) 使用数据库应用程序锁(通过 sp_getapplock)。这样看起来会快很多,但是现在我们是用数据库来锁定一个文件系统。此外,数据库应用程序锁可以通过事务或 session 限定范围,这意味着如果我想保留并稍后释放应用程序锁,我必须保留连接。目前,我们正在使用连接池,这将不得不改变,而且这本身可能是一个更大的对话。这种方法的好处是,如果我们失去与服务器的连接,锁将被清除。当然,这意味着如果我们失去与数据库的连接,而不是网络文件共享,那么当我们仍在处理输入文件时,锁就会消失。
3) 创建一个数据库表和存储过程来表示我想锁定的项目。这个过程很简单。不利的一面当然是潜在的网络错误。如果由于某种原因,数据库变得不可访问,锁定将保持有效。然后我们需要推导出一些算法来在以后清理它。
什么是最好的解决方案,为什么?答案不限于上述那些。
最佳答案
对于您的情况,您应该使用共享模式锁。这正是它们的用途。
Oplocks 不会按照您的意愿进行 - oplock 不是锁,也不会阻止任何人做任何事情。这是一种通知机制,让客户端机器知道是否有人访问了该文件。这是通过“打破”你的 oplock 来传达给机器的,但这并不是进入应用程序层(即你的代码)的东西 - 它只是向客户端操作系统生成一条消息,告诉它使其缓存无效复制并再次从服务器获取。
在这里查看 MSDN:
有关当另一个进程打开您持有 oplock 的文件时发生的情况的解释如下:
然而重要的一点是机会锁不会阻止其他进程打开文件,它们只是允许客户端计算机之间的协调。因此,oplocks 不会在应用程序级别锁定文件 - 它们是网络文件系统堆栈用来实现缓存的网络协议(protocol)的一个功能。它们并不是真正供应用程序使用。
由于您是在 Windows 上编程,因此合适的解决方案似乎是共享模式锁定,即使用 SHARE_DENY_READ|SHARE_DENY_WRITE|SHARE_DENY_DELETE
打开文件。
如果 CIFS 服务器不支持共享模式锁,您可以考虑使用 flock()
类型的锁。 (以传统的 Unix 技术命名)。
如果您正在处理 xyz.xml
创建一个名为 xyz.xml.lock
的文件(使用 CREATE_NEW
模式,这样您就不会破坏现有的)。完成后,将其删除。如果您因为文件已经存在而无法创建该文件,则意味着另一个进程正在处理它。将对调试有用的信息写入锁定文件可能很有用,例如服务器名和 PID。您还必须有一些方法来清理废弃的锁定文件,因为这不会自动发生。
如果 CIFS 是一个复制系统,数据库锁可能是合适的,这样 flock()
锁就不会在整个系统中自动发生。否则我会坚持使用文件系统,因为只有一件事会出错。
关于database - 在分布式系统中锁定文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19229627/
我对 Java 并发性比较陌生(还没有阅读 JCIP,但它在我的列表中!)并且我有一个关于锁定行为的问题。具体来说,Java 是锁定对象的引用,还是锁定对象本身? 代码示例(不是 sscce,因为我不
我的团队使用 TortoiseSVN 编写版本控制代码。有时,有人使用“获取锁定”选项。是否有可能看到解决方案中的锁? 最佳答案 http://tortoisesvn.net/docs/nightly
我在使用 SVN 时遇到了一个小问题。 当我跑 svn stat我明白了: ~ some/dir 当我跑 svn commit -m "test"我明白了:svn: working copy
我启用了 jenkins 安全性,认为它会提示我创建一个帐户。我尝试在 c:/program files/jenkins 中删除和编辑我的 config.xml 文件,但我不确定如何在没有访问权限的情
实现与 S3 结合使用的简单锁定机制的推荐方法是什么? 我想做的例子: 通过对象 ID 获取锁 从 S3 读取对象 修改数据 将对象写入 S3 释放锁 理想情况下寻找基于云的锁定机制。我可以在本地使用
找到这个here : 一般来说,在以下任何情况下,请考虑在列上创建索引: 索引列上存在引用完整性约束,或者列。索引是避免全表锁的一种方法,否则,如果您更新父表主键,则需要,合并到父表中,或从父表中删除
在我的程序中,我将把每个“ block ”数据存储在一个单独的文件中。多个线程都会读取和写入各种文件,我想避免因未正确同步而可能出现的问题。本质上,我想要一个设置,其中每个文件的行为就好像它有自己的
我想使用此script作为资源,通过使用Windows API(重置管理器)与Go for Windows中的内容相同 到目前为止,我的代码是 Rstrtmgr := syscall.NewLazyD
这里的问题是:“这些选择中的哪一个对于线程安全选择的剧院具有最佳性能?” public static List lockList = initializeLocks(); public boolean
我有一个侧面菜单,单击图标时打开,单击页面或单击菜单上的项目时关闭。我正在尝试实现锁定,因此当单击锁定图标时,即使您单击菜单项或页面,菜单也不会关闭。 我能够将图标从锁定图标更改为解锁图标,但我在停止
使用 TRueType 字体编写 SDL 程序。我调用 TTF_Init() 来初始化 TTF 并使用 TTF_OpenFont( name, size ) 打开我的字体。 我有一个例程,可以使用以下
我正在尝试调试基于运行 FreeRTOS 的 STM32F3 uC 的应用程序。我已在应用程序的线程上下文中的随机位置手动将 PSP 设置为无效值(例如 0),希望触发 memManageFault/
我有以下 C# 代码: 1. List bandEdgeList; 2. 3. bandEdgeList = CicApplication.BandEdgeCache.Where(r
我正在用骰子制作游戏。这个想法是持有/锁定骰子。我把骰子做成按钮,这样现在就可以点击它们了。示例:我抛出一个“6”和一个“1”。我点击“6”,所以现在只会抛出“1”。 我对这个有点迷失了,我需要创建
我正在使用以下代码下载约 200mb 的播客并将其写入文档目录: var podcastRequest = NSURLRequest(URL: audioUrl) NSURLConnection.se
下面的类 DoStuff 启动一个线程并同步以保护监听器对象在 null 时不被访问。 现在,当从外部访问 DoStuff 类函数 setOnProgressListener() 时,我遇到了问题,因
我正在编写一个使用巨大背景 Canvas 的网站。我试图锁定浏览器调整大小处理程序以避免滚动问题(背景越界等) 这是我第一次做一个完整的后台网站。任何有关优化的建议(png 大小 580.72 KB
我是 C# 和线程的新手,我有这个问题要解决: 我有一个处理一些数据的线程,它会不时(必要时)触发我在启动线程之前设置的事件方法 (DataProcessor)。该线程位于专有 dll 中。所以我不能
我正在使用相机,我使用的是文档中给出的完全相同的示例: http://developer.android.com/resources/samples/ApiDemos/src/com/example/
我有几个座位可供用户预订。同一时间,只有一个用户可以参与预订过程,这样同一个座位就不会被多个用户预订。在我的 Java 代码中,我使用了“synchronized”关键字来完成它。这行得通。 但是,现
我是一名优秀的程序员,十分优秀!