当前位置: 首页 > news >正文

sqlite3 相关知识

WAL 模式 VS 回滚模式

特性WAL 模式回滚模式(Rollback Journal)
定义使用写前日志来记录变更。使用回滚日志来记录事务的所有修改。
特点更高的并发性和性能;支持多读者和单写者。支持安全的事务回滚,但并发性较低。
性能写入性能更好,尤其是读多写少的场景。写操作会造成较大的性能开销,尤其是在事务开始时。
写入流程数据首先写入 WAL 文件,然后才从 WAL 刷新到主数据库。数据在开始事务时写入日志文件,完成后再更新主数据库。
读操作读取主数据库时不需要排队,因此多个读者可以平行读取。当写入时,读取者可能会被阻塞,直到写入完成。
数据完整性数据可以在写入过程中保持完整,写入发生之前可以回退。在异常情况下,使用回滚日志恢复数据,但会使写性能降低。
空间使用WAL 文件会持续增大,直到执行 CHECKPOINT 操作。日志文件会在事务完成后被删除,空间使用相对较小。
CHECKPOINT 操作定期将 WAL 文件中的数据合并到主数据库。不需要 CHECKPOINT 操作,事务完成后立即释放日志文件。
数据恢复可以在 WAL 文件中恢复未提交的事务。通过回滚日志恢复未完成的事务。
配置复杂性需要手动控制 WAL 文件刷新和 CHECKPOINT。相对简单,主要关注事务和日志保存。
适用场景- 读多写少的应用
- 高并发读取的应用
- 需要快速响应的桌面应用或移动应用
- 需要确保数据回滚的场景
- 事务完整性重要的金融应用
- 低并发负载的环境

WAL 模式的优缺点:

  • 优点

    • 高并发性:
      • WAL 模式允许多个读操作并行执行,而不必等待写操作完成。这对读多写少的应用程序非常有利。
    • 写入性能:
      • 由于写操作是先写入 WAL 文件而不是直接更改数据库,写操作的性能通常优于传统的日志模式,尤其是在进行大量插入时。
    • 避免写阻塞:
      • 在 WAL 模式下,写操作不会阻塞读取操作。只有在强制检查点(checkpoint)过程中,才会进行某种程度的阻塞。
    • 崩溃恢复能力:
      • WAL 文件在发生崩溃时可以帮助恢复未提交的事务。WAL 模式允许在发生故障后更加稳健地恢复数据库状态。
    • 逐步更新:
      • WAL 文件支持逐步刷新到主数据库文件,这样可以避免在每次写入时立即更新主数据库,减少了大量 I/O 操作。
  • 缺点

    • 存储空间:
      • WAL 文件可能变得很大,尤其是在频繁写入的场景中。需要定期执行 CHECKPOINT 操作以清理 WAL 文件,从而释放存储空间。
    • 检查点管理:
      • 有时需要手动管理 CHECKPOINT 操作来将 WAL 文件中的数据写入主数据库,这增加了管理复杂性。如果不定期进行 CHECKPOINT,可能导致 WAL 文件无限增大。
    • 写操作延迟:
      • 初始写操作会写入 WAL 文件,在强制将数据从 WAL 刷新到主数据库之前,可能会有一定延迟。这对某些特定场景(例如实时系统)可能不利。
    • 持久性配置需求:
      • 在某些情况下(特别是嵌入式系统),WAL 模式可能需要更多的内存和存储资源来管理 WAL 文件和进行 CHECKPOINT。
    • 旧版本支持:
      • WAL 模式可能不被所有 SQLite 版本支持,使用时需要确保兼容性。

回滚模式优缺点

  • 优点
    • 数据完整性:
      • 回滚日志确保了数据的一致性和完整性,即使在事务异常中断或发生崩溃的情况下,可以通过回滚日志恢复到事务开始之前的状态。
    • 简单的故障恢复:
      • 如果发生错误或系统崩溃,可以通过日志文件回滚未完成的事务,减少数据损失的风险。
    • 自动管理:
      • 当事务结束时,日志文件可以自动清理,不需要手动管理(例如 CHECKPOINT 操作)。
    • 易于实现:
      • 对于一些简单的应用,Rollback Journal 模式的设置和使用相对简单,因为它不会涉及复杂的参数配置或管理。
    • 低内存需求:
      • 与 WAL 模式相比,Rollback Journal 模式通常对内存的需求较低,因为它的工作方式不需要持有大量的日志文件。
  • 缺点
    • 性能开销:
      • 在执行写操作时,Rollback Journal 模式需要创建和写入日志文件,可能会导致性能下降,特别是在频繁写入的状况下。
    • 读操作阻塞:
      • 在执行写操作时,读操作通常会被阻塞,直到写入完成。这可能影响多用户环境下的并发性。
    • 写延迟:
      • 对于每个事务,数据库在应用实际更改之前都必须首先写入回滚日志,这会引入额外的延迟。
    • 日志文件管理:
      • 虽然不需要手动进行 CHECKPOINT 操作,但仍需要管理日志文件的大小和数量,特别是在大事务完成后,及时清理日志很重要。
    • 不适合高并发应用:
      • 在高并发读写的场合,Rollback Journal 模式可能导致性能瓶颈,因为写入会严重影响读取性能。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 【佳学基因检测】在bagisto中,grouped products(同组产品)和bundled products(打包产品)有什么不同?
  • Nvidia GPU benchmark压力测试工具
  • 003: Visual Studio 配置 VTK 开发环境的方法与比较
  • Qt工程实践_06_Qt MSVC2O17编译器下的程序添加VS2017生成的动态链接库方法
  • Windows用户取消共享文件夹密码方法(Method for Windows Users to Cancel Shared Folder Password)
  • 科研绘图系列:R语言柱状图分布(histogram plot)
  • Mybatis【分页插件,缓存,一级缓存,二级缓存,常见缓存面试题】
  • 重头开始嵌入式第三十四天(数据库二)
  • html备忘录
  • IDEA 2024最新软件下载
  • 【全网最全】2024年数学建模国赛C题超详细保奖思路+可视化图表+成品论文+matlab/python代码等(后续会更新
  • Elastic Stack--ELFK实例与Dashboard界面
  • docker实战基础四(如何在容器中调试和排查运行问题)
  • 基于PyTorch分布式训练的实现与优化(以CIFAR-10为例)
  • 如何搭建RGBD GS-ICP SLAM环境以及如何与自己编的pcl并存
  • 【399天】跃迁之路——程序员高效学习方法论探索系列(实验阶段156-2018.03.11)...
  • 【技术性】Search知识
  • C# 免费离线人脸识别 2.0 Demo
  • CAP 一致性协议及应用解析
  • golang 发送GET和POST示例
  • GraphQL学习过程应该是这样的
  • Hibernate【inverse和cascade属性】知识要点
  • Intervention/image 图片处理扩展包的安装和使用
  • Java比较器对数组,集合排序
  • Java编程基础24——递归练习
  • Js实现点击查看全文(类似今日头条、知乎日报效果)
  • MD5加密原理解析及OC版原理实现
  • MyEclipse 8.0 GA 搭建 Struts2 + Spring2 + Hibernate3 (测试)
  • Python_网络编程
  • scala基础语法(二)
  • webgl (原生)基础入门指南【一】
  • 开发基于以太坊智能合约的DApp
  • 开年巨制!千人千面回放技术让你“看到”Flutter用户侧问题
  • 批量截取pdf文件
  • 使用Maven插件构建SpringBoot项目,生成Docker镜像push到DockerHub上
  • 手写双向链表LinkedList的几个常用功能
  • 新版博客前端前瞻
  • ​埃文科技受邀出席2024 “数据要素×”生态大会​
  • ​如何在iOS手机上查看应用日志
  • ​学习笔记——动态路由——IS-IS中间系统到中间系统(报文/TLV)​
  • #mysql 8.0 踩坑日记
  • (1)Nginx简介和安装教程
  • (14)学习笔记:动手深度学习(Pytorch神经网络基础)
  • (3)医疗图像处理:MRI磁共振成像-快速采集--(杨正汉)
  • (Arcgis)Python编程批量将HDF5文件转换为TIFF格式并应用地理转换和投影信息
  • (Matlab)基于蝙蝠算法实现电力系统经济调度
  • (NO.00004)iOS实现打砖块游戏(十二):伸缩自如,我是如意金箍棒(上)!
  • (windows2012共享文件夹和防火墙设置
  • (更新)A股上市公司华证ESG评级得分稳健性校验ESG得分年均值中位数(2009-2023年.12)
  • (区间dp) (经典例题) 石子合并
  • (三)模仿学习-Action数据的模仿
  • (一)Spring Cloud 直击微服务作用、架构应用、hystrix降级
  • (一)插入排序
  • (转)JAVA中的堆栈
  • (转)机器学习的数学基础(1)--Dirichlet分布