当前位置: 首页 > 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.lryc.cn/news/492052.html

相关文章:

  • Jmeter中的测试片段和非测试原件
  • 利用 Jsoup 进行高效 Web 抓取与 HTML 处理
  • 【Java】二叉树:数据海洋中灯塔式结构探秘(上)
  • 微信小程序 WXS 的概念与基本用法教程
  • Vue.js 中 v-bind 和 v-model 的用法与异同
  • K8s的水平自动扩容和缩容HPA
  • 【AI日记】24.11.26 聚焦 kaggle 比赛
  • 大型语言模型LLM - Finetuning vs Prompting
  • 【IEEE独立出版 | 厦门大学主办】第四届人工智能、机器人和通信国际会议(ICAIRC 2024,12月27-29日)
  • 【GPT】力量训练是什么,必要吗,有可以替代的方式吗
  • 【03】Selenium+Python 八种定位元素方法
  • 笔记:jQuery追加js时会自动加“_时间戳“参数,导致百度统计失败
  • 【PyTorch】(基础二)---- 张量
  • 充满智慧的埃塞俄比亚狼
  • 基于STM32设计的智能桌面暖风机(华为云IOT)
  • 零基础学安全--云技术基础
  • Spring Boot中配置Flink的资源管理
  • 51单片机从入门到精通:理论与实践指南入门篇(二)
  • Notepad++ 替换所有数字给数字加单引号
  • 【CANOE】【Capl】【RS232】控制串口设备
  • 查找相关题目
  • 《独立开发:Spring 框架的综合应用》
  • 数据工程流程
  • Linux宝塔部署wordpress网站更换服务器IP后无法访问管理后台和打开网站页面显示错乱
  • 区块链知识体系
  • 力扣第 66 题 “加一”
  • C语言数据结构与算法--简单实现队列的入队和出队
  • 代码美学:MATLAB制作渐变色
  • 排序算法之冒泡排序篇
  • WPF ItemsControl控件