现在离数据库启动过程的高潮只有几步之遥,这几步比较简单,简要描述之。
这几步包括:
八:设置虚拟文件描述符
九:初始化活跃 backend 进程列表
十:创建 opts 文件
十一:保存非默认 GUC 参数到文件
十二:为 postmaster 进程安装信号句柄
十三:为统计进程启动准备资源
十四:为 autovuc 进程启动做条件检查
十五:加载客户端认证配置文件
这一节 pg 调用 pgstat_init 方法,主要是给统计进程初始化 一个发送和统计信息的UDP 套接字,并验证这个UDP 套接字,以备后面启动统计进程时使用。如果成功创建了UDP 套接字,设置该套接字为非阻塞IO ,以保证统计收集进程失败时,统计信息将被丢弃,backend 进程不用阻塞以等待发送消息给统计收集器。 如果创建 UDP 套接字失败, postmaster 不失败,而是使 postmaster 进程开始,而使统计收集进程为 disabled 。 pg 的统计文件路径: data\pg_stat_tmp\pgstat.stat
接着调用了 autovuc_init 方法,检查配置参数 autovacuum 和 track_counts 的配置是否冲突,如果 autovacuum 为 on 而 track_counts 不是 on ,则在操作日志文件中写一个警告: "autovacuum not started because of misconfiguration" 。
调用流程图如下 :