-
Notifications
You must be signed in to change notification settings - Fork 16
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
数据库读锁的优化的思路 #7
Comments
之前考虑过解开读sqlite的线程锁,但可能是sqlite的文件级访问原因,多线程访问会概率性出现文件游标报错,概率低但经测试多次反馈确实会出现并导致异常,才重新加上的线程锁(可以看看sqlite多线程访问使用的相关文档,实际sqlite只有不被多个线程同时使用才是安全的),确实存在问题是connect定义为self,还一个问题没设计成单列,这都是遗留问题之前没时间去重新整理,下个版本开发会在数据库访问这块发力,重新规范整理,初步打算是单列多线程带线程锁访问,感谢! |
我写了两个脚本,测试了一下,在单例模式下读可以不用线程锁,但是更新和插入是必须用线程锁的
dbTest.py
|
在dbmanager里有很多在读取的时候加上了线程锁,感觉可以把锁去掉,让读取更快,但是这样的话应该就需要把在初始化里的self.cursor = self.connect.cursor()去掉,变成cursor=self.connect.cursor(),放到每个方法里,让他变成私有变量,这样就不会串了,这只是我的猜测,不知道能不能,当然,update是需要加锁的,insert可以考虑一下能不能也去除,让数据库操作更快,不用在线程里等待锁,因为连读都要加锁的话就感觉怪怪的,请指教
The text was updated successfully, but these errors were encountered: