PostgreSQL启动过程中的那些事十三_十四:初始化统计进程需要的资源、为autovuc进程启动做条件检查

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

 

    这几步包括:

       八:设置虚拟文件描述符

       九:初始化活跃 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"

    调用流程图如下


 

猜你喜欢

转载自beigang.iteye.com/blog/1544519
今日推荐