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

PostgreSQL的walwriter和archiver进程区别

PostgreSQL的walwriter和archiver进程区别

在PostgreSQL中,walwriterarchiver进程是两个重要的后台进程,它们负责管理WAL(Write-Ahead Logging,预写日志)文件,但它们的职责和功能有所区别。理解这两个进程的不同点对于数据库管理员来说至关重要,因为这影响到数据库的性能和数据持久性。

walwriter 进程

walwriter进程负责的主要任务是将WAL缓冲区中的数据写入WAL文件。

主要作用

  1. 写入WAL文件(WAL Write)

    • 将在内存中的WAL日志缓冲区(WAL buffers)定期写入磁盘上的WAL文件。
    • 确保事务日志被快速、安全地记录,以便在数据库崩溃时能够通过应用这些日志恢复数据库一致性。
  2. 减少延迟

    • 通过定期写入WAL日志,walwriter进程减少了事务提交的延迟,因为提交时所需的写操作已经通过walwriter进程处理了。
  3. 优化性能

    • 减少写入磁盘的I/O操作被批量处理的次数,提高系统的整体性能。

archiver 进程

archiver进程负责的主要任务是将已完成的WAL段文件复制到一个指定的归档存储位置。

主要作用

  1. WAL归档(WAL Archiving)

    • 将已完成和关闭的WAL文件段复制到指定的归档位置,用于备份和恢复。
    • 确保WAL文件在被新日志覆盖前被安全地存储,以便需要进行基于时间点恢复(Point-In-Time Recovery,PITR)时可以使用。
  2. 数据持久性

    • 通过归档WAL文件,即使主数据库服务器发生了故障,备份文件仍然能够用于恢复数据库到某个特定时间点。

主要区别

特性walwriter 进程archiver 进程
主要功能将WAL缓冲区中的数据写入WAL文件将已完成的WAL文件复制到归档位置
工作目标保证WAL日志的快速、安全写入,减少事务提交延迟,提高性能确保WAL文件安全备份,支持灾难恢复和时间点恢复
触发条件定期触发(基于配置的延迟时间)当WAL段文件完成或达到超时条件时触发
关键配置参数wal_writer_delayarchive_mode, archive_command, archive_timeout
影响影响实时写性能和系统响应时间影响备份可用性和恢复时间
http://www.lryc.cn/news/426568.html

相关文章:

  • 前端字体没有授权,字体版权检测(是否为方正字体)
  • 在 SOCKS 和 HTTP 代理之间如何选择?
  • C++适配windows和linux下网络编程TCP简单案例
  • OpenDDS的GUID是如何构造的?
  • 初识MySQL(安装与配置环境)
  • druid+logback打印sql执行日志
  • C++编程:无锁环形队列 (LockFreeRingQueue)的简单实现、测试和分析
  • 植物生长时为什么会扭动?科学家解开令查尔斯·达尔文困惑的千古之谜
  • SAP LE学习笔记02 - WM和库存管理(IM)之间的关系,保管Lot(Quant)
  • Span<T> 是 C# 7.2 引入的重要类型
  • Python办公自动化:初识 `openpyxl`
  • Pocketbase实战体验:内置数据库与实时功能如何超越传统MySQL
  • ChatGPT 3.5/4.0 新手使用手册(详细版)
  • 【Java学习】Stream流详解
  • Oracle(69)什么是表压缩(Table Compression)?
  • java JUC编程
  • vue3+element-plus表格分页选中加默认回显选中
  • Erupt 项目搭建
  • HarmonyOS Next 系列之列表下拉刷新和触底加载更多数据实现(十一)
  • 比特位的计算
  • SQLAlchemy 学习笔记
  • Linux内核分析(调度类和调度实体)
  • 用输入输出流(I/O)流,递归复制和删除多级文件
  • kafka监控工具EFAK
  • Page与自定义Components生命周期
  • Chain of Thought (CoT) 系列论文:大模型思维链,提升 LLM 的推理能力
  • 已解决:java.net.BindException: 地址已在使用
  • 看书标记【数据科学:R语言实战 8】
  • STM32标准库学习笔记-1.基础知识
  • Nginx:高效HTTP服务器与反向代理