Sqlite3同步机制
模式设置
- PRAGMA synchronous = FULL; (2)
- PRAGMA synchronous = NORMAL; (1)
- PRAGMA synchronous = OFF; (0)
参数含义
当synchronous设置为FULL (2), SQLite数据库引擎在紧急时刻会暂停以确定数据已经写入磁盘。这使系统崩溃或电源出问题时能确保数据库在重起后不会损坏。FULL synchronous很安全但很慢。
当synchronous设置为NORMAL, SQLite数据库引擎在大部分紧急时刻会暂停,但不像FULL模式下那么频繁。 NORMAL模式下有很小的几率(但不是不存在)发生电源故障导致数据库损坏的情况。但实际上,在这种情况 下很可能你的硬盘已经不能使用,或者发生了其他的不可恢复的硬件错误。
synchronous 设置为OFF (0)时,SQLite在传递数据给系统以后直接继续而不暂停。若运行SQLite的应用程序崩溃, 数据不会损伤,但在系统崩溃或写入数据时意外断电的情况下数据库可能会损坏。另一方面,在synchronous OFF时 一些操作可能会快50倍甚至更多。在SQLite 2中,缺省值为NORMAL.而在3中修改为FULL。
sync拓展
数据库为了执行备份,备份文件依赖于写磁盘,然后才会写到数据库文件磁盘中。关键在于这里的写磁盘,都是调用系统的write接口,绝大部分都是直接写缓冲区的,只有调用sync才会将缓冲区中的数据flush到磁盘。所以在write,sync,再wirte再sync的过程中,掉电后是否能恢复数据,依赖于sync是否有真正执行。从这个角度看,FULL和NORMAL的区别,似乎就只有sync调用的频率,FULL按照多人的意见是一个transaction一个sync,而NORMAL是多个transactions调一个sync。