7.2 独享访问模式
sqlite从3.3.14版本之后增加一个“独享访问模式”概念。当处于独享访问模式时,sqlite会在一个事务完成之后仍然保留独享锁。这将阻止其他进程访问这个数据库;由于大部分的开发都只有一个进程访问数据库,所以大部分情况下这不是一个严重的问题。独享访问模式的好处可以在三个方面减少磁盘IO数量:
1) 不再需要为每个事务完成之后修改文件头部的变更计数器。这可以为回滚日志及数据库文件减少一次页写入。
2) 没有其他进程会修改数据库,所以不必在一个事务开始的时候去检查变更计数器或者清除掉用户空间的缓存。
3) 当一个事务完成之后,可以采用清空日志文件的方式,而不必去删除这个文件。在大多数的操作系统中,清空文件要远快于删除一个文件。
上述的第三点优化,清空而不是删除回滚日志文件,不再要求一直取得一个独享锁。在理论上,我们可以在任何时刻做这项优化,并不是只有在独享访问模式时。在将来的sqlite版本中我们或许可能这么做。但当前的版本(3.5.0)回滚日志文件清空优化只发生在独享访问模式。
原文链接:https://www.f2er.com/sqlite/202744.html