加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

PostgreSQL启动过程中的那些事十三_十四:初始化统计进程需要的

发布时间:2020-12-13 17:45:14 所属栏目:百科 来源:网络整理
导读:现在离数据库启动过程的高潮只有几步之遥,这几步比较简单,简要描述之。 这几步包括: 八:设置虚拟文件描述符 九:初始化活跃backend进程列表 十:创建opts文件 十一:保存非默认GUC参数到文件 十二:为postmaster进程安装信号句柄 十三:为统计进程启动准

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

这几步包括:

八:设置虚拟文件描述符

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

调用流程图如下:


(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读