首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Python2.7:跨多台计算机的SQlite和并发

Python2.7:跨多台计算机的SQlite和并发
EN

Stack Overflow用户
提问于 2016-05-19 03:39:41
回答 1查看 109关注 0票数 1

我有一个程序,多台计算机将运行,所有需要从相同的sqlite数据库读/写。每个程序都在一个文件上执行一个操作,它从存储在sqlite表中的一个列表中请求一个“可用”的文件名。最多只有6-10个用户在运行它。伪代码将是...

代码语言:javascript
复制
con = sqlite.connection(db,timeout=60)
filename = select file from tablename limit 1;
update tablename set status ="busy" where file = filename;
<..perform action.  takes 2-5 minutes..>
update tablename set status ="Finished" where file = filename;
repeat

因此,每个事务都非常快,但不幸的是,即使我将连接超时设置得非常高,我仍然会遇到"db已锁定“的问题。我已经阅读了apsw中的异步vfs,但听起来队列管理器似乎只在一台机器上。对于如何进行,有什么建议吗?

编辑:我应该补充说,我受到IT限制,无法在我的办公桌上设置适当的SQL服务器。

EN

回答 1

Stack Overflow用户

发布于 2016-06-06 10:40:34

(披露:我是APSW的作者)异步虚拟文件系统在很长一段时间前就被SQLite团队弃用了,并且已经多年没有包含在APSW中了。使用write ahead logging在SQLite核心中提供了更好的集成等效功能。

...本地到一台机器...

这意味着您正在尝试通过网络使用SQLite。不要那样做。这是行不通的。它最初看起来似乎是有效的,但最终你会得到损坏。您不能提前测试以证明不会发生损坏。More details here

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37308720

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档