- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我想让许多联网计算机上的许多进程通过 OpenAFS 1.4.12.1 同时访问同一个 SQLite 数据库。写操作会很少,所以SQLite的单写设计应该不是问题。
我想知道这是否可行。我无法找到两条关键信息:
SQLite documentation声明“SQLite 使用 POSIX 建议锁来实现 Unix 上的锁定”。它还警告说“你最好的防御是不要对网络文件系统上的文件使用 SQLite”。但是,它似乎没有具体说明 SQLite 是否只使用整个文件锁定,或者它是否也使用字节范围锁定。
我也无法确定 OpenAFS 1.4.12.1 支持哪些类型的锁定。这unofficial source from 1998不幸的是,这是我能找到的最好的来源。那时,支持整个文件锁定,但不支持字节范围锁定。
官方文档只出现this page ,尽管它的标题很友好,但实际上并没有说明最新的 OpenAFS 是否支持 POSIX 字节范围咨询锁定。
编辑:这可能吗?如果是这样,是否需要任何编译时 SQLite 标志?
最佳答案
我使用 SQLite 已经有一段时间了,并且有幸处理了一些锁定问题。我非常确定 SQLite 默认在 Unix 文件系统上使用字节范围锁。
更准确地说,它包含一些替代锁定方法的代码(例如使用 flock()
和 dotlock-style 整个文件锁)。使用 SQLITE_ENABLE_LOCKING_STYLE
option 编译时它会尝试自动检测底层文件系统的正确锁定方法。
自动检测代码包含一些硬编码的情况(例如“ufs”、“nfs”和“smbfs”),这些都不是 AFS。如果没有硬编码大小写匹配,SQLite 会尝试使用 fcntl()
获取文件的字节范围锁。 .然后假设如果 fcntl()
调用成功,则字节范围锁可用。
这就是 OpenAFS 让事情变得有趣 的地方。显然([1]、[2]、[3])OpenAFS 有长期向用户空间应用程序撒谎字节范围锁的历史。来自 openafs-1.4.14
源代码:
/* next line makes byte range locks always succeed,
* even when they should block */
if (af->l_whence != 0 || af->l_start != 0 || af->l_len != 0) {
DoLockWarning();
afs_PutFakeStat(&fakestate);
return 0;
}
一句话:哎哟!
无论如何,它都允许字节范围锁成功。在 Linux 上,情况可能更糟:它使用内核基础结构在同一系统的进程之间 提供字节范围锁。这意味着应用程序不能只派生一个新进程并测试锁定机制 - 字节范围锁似乎工作正常,但无法保护文件免受远程进程的影响。
简而言之:您不能将未修改的 SQLite 可靠地用于 OpenAFS。大多数其他网络文件系统也有问题,因此建议完全避免使用网络文件系统。
一些可能的变通方法(排名不分先后):
使用适当的 DBMS,例如 PostgreSQL .如果可以做到这一点,从长远来看,您会过得更好。
如果成熟的 DBMS 过于强大,请为您的应用程序实现您自己的服务器。
修改 SQLite 源代码以默认为 OpenAFS 上的 flock()
。我不确定这是否会正常工作,因为 OpenAFS 有很长的锁定问题历史([1],[2]),即使是普通的 flock()
,但你不会知道直到您对其进行测试。
使用 OpenAFS 用户空间,而不是通过内核,为 SQLite 实现您自己的 OpenAFS VFS。
使用另一个网络文件系统试试运气。
无论您做什么,如果它以任何方式涉及 SQLite3 和共享数据库文件,您都必须执行大量测试。
编辑:
评论者建议使用点锁文件机制。我没有深入研究 OpenAFS 源代码,但乍一看它似乎支持 open(O_CREAT|O_EXCL)
SQLite 使用的创建点锁文件的方法。如果它按预期工作,那么如果您强制它使用 dotlock 方法,那么 SQLite 可能确实可以与 OpenAFS 一起使用。
也就是说,在不将网络文件系统的复杂性引入混合的情况下,点锁在常规本地文件系统上就足够了 - 这就是为什么我一开始没有建议它。
关于SQLite 与 OpenAFS 锁定兼容吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5468349/
我对 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”关键字来完成它。这行得通。 但是,现
我是一名优秀的程序员,十分优秀!