PostgreSQL启动过程中的那些事十三_十四:初始化统计进程需要的资源、为autovuc进程启动做条件检查
2012-05-30 08:09
375 查看
现在离数据库启动过程的高潮只有几步之遥,这几步比较简单,简要描述之。
这几步包括:
八:设置虚拟文件描述符
九:初始化活跃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"。
调用流程图如下:
这几步包括:
八:设置虚拟文件描述符
九:初始化活跃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"。
调用流程图如下:
相关文章推荐
- PostgreSQL启动过程中的那些事七:初始化共享内存和信号十四:shmem中初始化PMSignal
- PostgreSQL启动过程中的那些事五:初始化世界上现有行政区时区
- PostgreSQL启动过程中的那些事九_十_十一:初始化活跃backend进程列表、创建opts文件、保持非默认GUC参数文件
- PostgreSQL启动过程中的那些事七:初始化共享内存和信号十三:shmem中初始化SharedInvalidationState
- PostgreSQL启动过程中的那些事七:初始化共享内存和信号二十:shmem中初始化堆同步扫描、pg子进程相关结构
- PostgreSQL服务过程中的那些事一:启动postgres服务进程一.五:初始化relcache管理环境
- PostgreSQL启动过程中的那些事十八:bgwriter进程一
- PostgreSQL启动过程中的那些事七:初始化共享内存和信号十七:shmem中初始化AutoVacuum相关结构
- PostgreSQL服务过程中的那些事一:启动postgres服务进程一.七:初始化portal管理环境
- PostgreSQL服务过程中的那些事一:启动postgres服务进程一.八:加载DB基础设施,完成服务进程初始化
- PostgreSQL启动过程中的那些事十八:bgwriter进程二
- PostgreSQL服务过程中的那些事一:启动postgres服务进程一.六:初始化系统表缓存catcache
- PostgreSQL启动过程中的那些事十二.五:启动系统日志进程syslogger
- PostgreSQL启动过程中的那些事七:初始化共享内存和信号十:shmem中初始化PROC索引、辅助进程和信号
- PostgreSQL启动过程中的那些事十二:为postmaster进程设置信号句柄
- PostgreSQL启动过程中的那些事八:设置文件描述符个数
- PostgreSQL启动过程中的那些事七:初始化共享内存和信号十二:shmem中初始化SharedBackendStatus
- PostgreSQL启动过程中的那些事七:初始化共享内存和信号六:shmem中初始化twophase
- PostgreSQL启动过程中的那些事七:初始化共享内存和信号一:初始化shmemIndex和信号