- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在连续写入具有 PRAGMA journal_mode=WAL、PRAGMA journal_size_limit=0 的 db 文件。我的 C++ 程序有两个线程,一个读取器(每隔 15 秒查询一次)和一个写入器(每隔 5 秒插入一次)。
每 3 分钟,我就会暂停插入以从编写器线程运行 sqlite3_wal_checkpoint_v2(),模式参数为 SQLITE_CHECKPOINT_RESTART。为了确保此时没有事件的读取操作正在进行,我设置了一个标志,表示检查点即将发生并在运行检查点之前等待读取器完成(连接仍然打开)。检查点完成后,我再次向读者表明可以继续查询。
sqlite3_wal_checkpoint_v2() 返回 SQLITE_OK,并且 pnLog 和 Ckpt 相等(大约 4000),表明完整的 wal 文件已与主数据库文件同步。所以下一次写应该根据文档从头开始。然而,这似乎并没有发生,因为后续的写入会导致 WAL 文件无限增长,最终达到一些 GB。
我做了一些搜索,发现阅读器可能会由于打开的事务而导致检查点失败。但是,我使用的唯一读取器是在检查点开始之前结束其事务。还有什么可能阻止 WAL 文件不增长?
最佳答案
这作为答案为时已晚,但可能对其他人有用。
根据SQLite documentation ,您的期望应该是正确的,但是如果您阅读此 SO post ,在非最终声明的情况下也会出现问题。因此,如果您只是 sqlite3_reset()
您的声明,无论如何,数据库可能看起来很忙或锁定检查点。请注意,这也可能发生在更高级别的 SQLITE_CHECKPOINT_values
中。 .
另外,SQLITE_CHECKPOINT_TRUNCATE
值,如果checkout操作成功,会截断-wal
文件长度为零。这可以帮助您检查所有页面是否已插入数据库中。
另一个讨论在其中-wal
由于未完成的语句,文件越来越大是 this .
关于SQLITE wal 文件大小不断增长,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27544006/
如果这不是一个错误,那就是另一个错误。如果不是那样的话,那就是别的东西了。我觉得我的项目已经改变了很多,现在只是试图解决代码签名问题,结果一切都搞砸了。我严格按照说明进行操作,但出现错误,例如当前的“
我不确定是否有一些我不知道的内置变量或规则,或者 make 是否有问题,或者我只是疯了。 对于我的一个项目,我有一个如下的 makefile: CC=g++ CFLAGS=-O3 `libpng-co
我有大约 10 个 div,它们必须不断翻转,每个 div 延迟 3 秒 这个 codrops 链接的最后一个效果是我正在寻找的,但无需单击 div http://tympanus.net/Devel
我如何使用 jQuery 持续运行 PHP 脚本并每秒获取响应,以及将鼠标上的少量数据发送到同一脚本? 我真的必须添加一些随机扩展才能让这么简单的计时器工作吗? 最佳答案 To iterate is
JBoss 4.x EJB 3.0 我见过如下代码(大大简化): @Stateless @TransactionAttribute(TransactionAttributeType.NOT_SUPPO
使用 PHPStorm,我试图忽略每次尝试进行 git 提交时 pop 的 workspace.xml。 我的 .gitignore 看起来像: /.idea/ .idea/workspace.xml
我是一名优秀的程序员,十分优秀!