六狼论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博账号登陆

只需一步,快速开始

搜索
查看: 137|回复: 0

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

[复制链接]

升级  53.67%

117

主题

117

主题

117

主题

举人

Rank: 3Rank: 3

积分
361
 楼主| 发表于 2013-1-30 01:25:11 | 显示全部楼层 |阅读模式
现在离数据库启动过程的高潮只有几步之遥,这几步比较简单,简要描述之。
 

    这几步包括:

       八:设置虚拟文件描述符

       九:初始化活跃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"。
    调用流程图如下:


 
您需要登录后才可以回帖 登录 | 立即注册 新浪微博账号登陆

本版积分规则

快速回复 返回顶部 返回列表