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

【346】Postgres内核 Startup Process 通过 signal 与 postmaster 交互实现 (5)

1. Startup Process 进程

postmaster 初始化过程中, 在进入 ServerLoop() 函数之前,会先通过调用 StartChildProcess() 函数来开启辅助进程,这些进程的目的主要用来完成数据库的 XLOG 相关处理。 如:

  • 核实 pg_wal 和 pg_wal/archive_status 文件是否存在
  • Postgres先前是否发送崩溃;若崩溃,则尝试读取XLOG 重放、恢复
  • 归档恢复、REDO 等等

本文将讲解一个非常重要的知识点,就是 辅助进程执行完成后,如何与 postmaster 进程交互(因为辅助进程也是 fork(), 在子进程中处理自己的业务逻辑。)

请添加图片描述

1.1 信号交互实现关键

Postgres 内核实现主要过程如下:

  • StartupProcessMain() 函数处理完成后,会调用 proc_exit(0) 。(正常退出。退出代码 0 向 postmaster 表明我们已成功完成恢复)

    • proc

http://www.mrgr.cn/news/78216.html

相关文章:

  • 【vue】导航守卫
  • # DBeaver 连接hive数仓
  • JavaScript中的箭头函数以及编写优化
  • window系统下使用open-webui+ollama部署大模型
  • Java 获取本机 IP 地址的方法
  • 波点音乐自动点击
  • NUXT3学习日记四(路由中间件、导航守卫)
  • Python的3D可视化库 - vedo (3)visual子模块 点对象的可视化控制
  • 【小白学机器学习35】数据表:整洁数据表,交叉表/列联表,以及两者转化pd.pivot_table()
  • 深度学习基础1
  • WinFrom调用webapi接口另一个方法及其应用实例
  • JVM调优篇之JVM基础入门AND字节码文件解读
  • STM32C011开发(2)----nBOOT_SEL设置
  • LLamafactory 批量推理与异步 API 调用效率对比实测
  • 【11-20期】Java面试进阶:深入解析核心问题与实战案例
  • 【机器学习】机器学习学习笔记 - 数据预处理 - 01
  • 【机器学习】机器学习学习笔记 - 监督学习 - KNN线性回归岭回归 - 02
  • QUICK 调试camera-xml解析
  • QT6学习第四天
  • HT4089电子雾化芯片耐高压40V,带OVP保护功能锂电池线性充电管理芯片,应用带屏幕电子雾化行业MCU解决方案
  • win10中使用ffmpeg的filter滤镜
  • 图论入门编程
  • Python学习34天
  • maven <scope>compile</scope>作用
  • 【小白学机器学习34】基础统计2种方法:用numpy的方法np().mean()等进行统计,pd.DataFrame.groupby() 分组统计
  • day01