PostgreSQL启动过程中的那些事十二:为postmaster进程设置信号句柄

现在离数据库启动过程的高潮只有几步之遥,这几步比较简单,简要描述之。

这几步包括:

八:设置虚拟文件描述符

九:初始化活跃backend进程列表

十:创建opts文件

十一:保存非默认GUC参数到文件

十二:为postmaster进程安装信号句柄

十三:为统计进程启动准备资源

十四:为autovuc进程启动做条件检查

十五:加载客户端认证配置文件

再接着调用pqinitmask方法和pqsignal方法,为postmaster进程安装信号句柄

pqinitmask();

PG_SETMASK(&BlockSig);

pqsignal(SIGHUP,SIGHUP_handler); /* reread config file and have
* children do same */
pqsignal(SIGINT,pmdie); /* send SIGTERM and shut down */
pqsignal(SIGQUIT,pmdie); /* send SIGQUIT and die */
pqsignal(SIGTERM,pmdie); /* wait for children and shut down */
pqsignal(SIGALRM,SIG_IGN); /* ignored */
pqsignal(SIGPIPE,SIG_IGN); /* ignored */
pqsignal(SIGUSR1,sigusr1_handler); /* message from child process */
pqsignal(SIGUSR2,dummy_handler); /* unused,reserve for children */
pqsignal(SIGCHLD,reaper); /* handle child termination */
pqsignal(SIGTTIN,SIG_IGN); /* ignored */
pqsignal(SIGTTOU,SIG_IGN); /* ignored */
/* ignore SIGXFSZ,so that ulimit violations work like disk full */
#ifdef SIGXFSZ
pqsignal(SIGXFSZ,SIG_IGN); /* ignored */
#endif

其中pqsignal(SIGCHLD,reaper);是如果发生SINGCHLD信号,就reaper方法处理。这个后面数据库启动的时候会体现。


初始化信号句柄调用流程图

相关文章

文章浏览阅读601次。Oracle的数据导入导出是一项基本的技能,...
文章浏览阅读553次。开头还是介绍一下群,如果感兴趣polardb...
文章浏览阅读3.5k次,点赞3次,收藏7次。折腾了两个小时多才...
文章浏览阅读2.7k次。JSON 代表 JavaScript Object Notation...
文章浏览阅读2.9k次,点赞2次,收藏6次。navicat 连接postgr...
文章浏览阅读1.4k次。postgre进阶sql,包含分组排序、JSON解...