【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