Find centralized, trusted content and collaborate around the technologies you use most.
Teams
Q&A for work
Connect and share knowledge within a single location that is structured and easy to search.
我有一个不幸的情况,多个 Perl 进程同时写入和读取同一个 SQLite3 数据库。
这通常会导致 Perl 进程崩溃,因为两个进程会同时写入,或者一个进程正在从数据库中读取,而另一个进程试图更新相同的记录。
有谁知道我如何协调多个进程以使用同一个 sqlite 数据库?
我将努力将此系统移至不同的数据库引擎,但在此之前,我需要修复它以使其按原样工作。
SQLite 旨在用于多个进程。如果您将 sqlite 文件托管在网络驱动器上,则存在一些例外情况,并且可能有一种方法可以编译它以使其期望从一个进程中使用,但我经常从多个进程中使用它。如果您遇到问题,请尝试增加超时值。SQLite 使用文件系统锁来保护数据不被同时访问。如果一个进程正在写入文件,则第二个进程可能必须等待。我将超时设置为 3 秒,并且对此几乎没有问题。
这是设置超时值的链接