设为首页 加入收藏

TOP

PostgreSQL启动过程中的那些事三:加载GUC参数(三)
2014-11-23 20:12:34 来源: 作者: 【 】 浏览:45
Tags:PostgreSQL 启动 过程 那些 加载 GUC 参数
sourceline; /* line in source file */

};

然后,定义一个config_generic **类型的静态变量数组guc_variables,再计算参数总数,所有参数以config_generic*类型计算所需内存空间,冗余25%内存后malloc分配内存空间。把guc_variables每一个元素指向ConfigureNamesBool、ConfigureNamesInt、ConfigureNamesReal、ConfigureNamesString、ConfigureNamesEnum这五个数组的config_generic类型成员gen的地址,然后按照参数名称把所有元素做了快速排序。这个过程中还设置了一些GUC参数的默认值。

static struct config_generic **guc_variables;

后面查询GUC参数都是在guc_variables这个已排序的数组里找。这样GUC参数的数据结构就搭建完成了,下面看看GUC参数相关的数据结构图吧。

先把涉及到的结构的图分别列出,再画个这些结构的组织关系示意图。


\


\


\

3加载postgresql.conf参数配置文件里的参数设置

从main->PostmasterMain->SelectConfigFiles->ProcessConfigFile开始处理参数配置文件postgresql.conf,读取postgresql.conf配置文件的调用过程是ProcessConfigFile -> ParseConfigFile -> AllocateFile->fopen,最后用fopen打开文件,其中ProcessConfigFile、ParseConfigFile在文件src\backend\utils\misc\guc-file.l中,AllocateFile在文件src\backend\storage\file\fd.c中。

pg使用 flex 去处理 conf 文件。在ParseConfigFile中把配置文件中的配置项组织成一个链表,调用set_config_option检查这些值是否有效,若可以设置就调用set_config_option设置这些值。

这里以"max_connections"做例子,从配置文件读取"max_connections",然后从guc_variables数组中找元素" max_connections ",比较参数结构的GucContext (枚举类参数能被设置的时机。定义见下面)枚举类型成员context和当前时间,看是否可以此刻修改。接着比较参数结构的GucSource(枚举了当前GUC参数设置的来源。除非参数新值的来源等级不小于原参数的来源等级时,新设置才能生效。例如,修改配置文件不能覆盖postmaster command line的设置。定义见下面)枚举类型成员source和新参数值的来源,看是否可以修改。如果可以,把config_generic结构类型的元素" max_connections "类型转换为config_int类型,修改variable成员为新值,修改该参数的来源source为当前来源PGC_S_FILE,如果元素" max_connections "的reset_source <= source,修改reset_val成员为新值,修改该参数的reset_source为当前来源PGC_S_FILE。

typedef enum

{

PGC_INTERNAL,

PGC_POSTMASTER,

PGC_SIGHUP,

PGC_BACKEND,

PGC_SUSET,

PGC_USERSET

} GucContext;

typedef enum

{

PGC_S_DEFAULT, /*wired-in default */

PGC_S_ENV_VAR, /*postmaster environment variable */

PGC_S_FILE, /*postgresql.conf */

PGC_S_ARGV, /*postmaster command line */

PGC_S_DATABASE, /*per-database setting */

PGC_S_USER, /*per-user setting */

PGC_S_CLIENT, /* fromclient connection request */

PGC_S_OVERRIDE, /*special case to forcibly set default */

PGC_S_INTERACTIVE, /* dividingline for error reporting */

PGC_S_TEST, /*test per-database or per-user setting */

PGC_S_SESSION /* SETcommand */

} GucSource

首页 上一页 1 2 3 下一页 尾页 3/3/3
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇MySQL复制(一) --- 二进制日志.. 下一篇用mysql存储二进制数据流

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: