执行检查点失败
Failed to do checkpoint
int iReturn = sqlite3_wal_checkpoint_v2(m_poDB, NULL, SQLITE_CHECKPOINT_FULL, &iSizeOfWalLog, &iNumOfCheckpointedFrames);
返回iReturn = 5 (SQLITE_BUSY)。写入器不时地醒来,向数据库中添加或删除一些行,执行检查点并再次进入睡眠。
问题1:如果我使用WAL模式并且有4个读取器和一个写入器,这怎么可能?
问题2:在日志消息中,我看到检查点经常工作,但只是有时报告SQLITE_BUSY。如果它有时有效,但不是总是有效,我应该担心吗?这会破坏数据库吗?
问题3:我应该不使用sqlite3_wal_checkpoint_v2或SQLITE_CHECKPOINT_FULL?
完整的检查点要求没有并发的读或写程序。
您可以尝试增加繁忙超时,但如果您尝试定期执行检查点,则可以忽略单个失败。
相关文章:
- 如果没有malloc,链表实现将失败
- 模板参数替换失败,并且未完成隐式转换
- 具有默认模板参数的多态类的模板推导失败
- 视图中的参数推导失败:take_while
- 链接到自行创建的dll失败
- 带有特殊路径部分的"std::filesystem::weakly_canonical"失败
- GetShortPathName在网络驱动器上使用中文文件夹时失败
- gcc和c++17的过载解析失败
- 为什么使用 P/Invoke 调用 dll 时,某些计算机中的 LoadLibrary 失败?
- 在WSL:configure_file上对config_file的每次调用都失败:配置文件时出现问题
- 使用 GCC 卸载的 OpenMP 卸载失败,并出现"Ptx assembly aborted due to errors"
- 使用cmake从源代码构建MySQL连接器/C++失败(与以前的声明冲突)
- 链接阶段在Ubuntu上失败,但在MacOS上失败
- 从父数组测试用例构造二叉树失败
- LibGit2 SSH身份验证失败
- 如何让LLDB在成功时退出,在失败时等待
- VS2017,C++包含目录与附加包含目录,子文件夹包含失败-但为什么
- 生成MRPT库时cmake配置失败
- 为什么除非添加括号,否则构造函数上的模板替换会失败?
- 使用TensorFlow检查点在C 中还原模型