概述

本文简单梳理了mysql配置文件和启动参数的读取和解析过程

相关处理源码

load_defaults函数:

这个函数在mysqld_main函数开始的地方调用,注意load_default_groups参数:mysqld、server、mysql5.7,表示该函数只处理配置文件中这些group的内容。

init_default_directories:设置配置文件的初始化目录。后续可能会根据这个目录读取配置文件内容。

my_search_option_files(conf_file, argc, argv, &args_used, handle_default_option, (void *) &ctx, dirs):该函数参数ctx->group存储了要检索配置文件中哪些group的信息。并读取配置文件的信息到ctx->m_args中,m_args每一项的内容格式:--mysql=use

新分配ptr指针数组:1. ptr[0]为进程名

2.ptr之后的内容是ctx->m_args的内容,即读取的配置文件内容

3.ptr之后的内容是分隔项:----args-separator----

4.ptr最后的内容是原命令行的配置信息: argv的数组信息添加到结尾

更新argc和argv的内容,argv=ptr

handle_early_options

处理argv配置项中flag为parse_early的配置项。系统的option在初始化的时候分为两种类型:PARSE_EARLY和PARSE_NORMAL两部分。在sys_var.cc文件中具体看sys_var成员m_parse_flag的值。eg:Sys_var_integer的定义

Sys_var_integer(const char *name_arg,

const char *comment, int flag_args, ptrdiff_t off, size_t size,

CMD_LINE getopt,

T min_val, T max_val, T def_val, uint block_size, PolyLock *lock=0,

enum binlog_status_enum binlog_status_arg=VARIABLE_NOT_IN_BINLOG,

on_check_function on_check_func=0,

on_update_function on_update_func=0,

const char *substitute=0,

int parse_flag= PARSE_NORMAL)

sys_var_add_options:将parse_early的系统变量存入all_early_options。系统变量的来源是all_sys_vars,每个系统变量初始化的时候加入到all_sys_vars中,具体代码见sys_var 的构造函数结尾一部分。

将my_long_early_options的成员加入all_early_options成员。

handle_options(&remaining_argc, &remaining_argv, &all_early_options[0], mysqld_get_one_option):该函数检查命令行参数中是否有对应的配置,并将对应的值设置到all_early_option中option->value。

init_common_variables

get_options(&remaining_argc, &remaining_argv)

sys_var_add_options(&all_options, sys_var::PARSE_NORMAL):加载PARSE_NORMAL的系统变量

handle_options(argc_ptr, argv_ptr, &all_options[0], mysqld_get_one_option)):将命令中的参数值设置到all_options中

init_default_directories

注意获取的缺省目录的先后顺序,后面的配置会覆盖前面配置文件的内容。该函数设置的先后顺序如下:

File Name

Purpose

/etc/my.cnf

Global options

/etc/mysql/my.cnf

Global options

SYSCONFDIR/my.cnf

Global options

$MYSQL_HOME/my.cnf

Server-specific options (server only)

defaults-extra-file

The file specified with --defaults-extra-file, if any

~/.my.cnf

User-specific options

my_search_option_files(conf_file, argc, argv, &args_used, handle_default_option, (void *) &ctx, dirs)

函数功能:读取配置文件的内容到ctx->m_args中。具体处理流程如下:

第一次调用:读取--defaults-file、--defaults-extra-file、--defaults-group-suffix、--login-path这几个配置项的内容,这几个配置项会影响读取配置文件的行为,这几个配置项的含义参考官方文档:https://dev.mysql.com/doc/refman/5.7/en/option-file-options.html  。读取之后根据defaults-group-suffix的内容扩展ctx- >group的内容。eg:如果该配置项内容为_test,即要检索grup为mysqld_test的内容

如果是第二次调用:向ctx->group中添加两项内容:m_login_path和m_login_path + defaults-group-suffix

如果处理的配置文件是绝对路径,读取指定的配置文件内容存

如果设置了参数defaults-file但是未设置no-defaults参数,读取defaults-file配置文件的内容

否则:根据配置文件的初始化目录依次读取配置文件的内容

search_default_file_with_ext函数

该函数读取配置文件的内容。search_default_file函数是根据配置文件匹配后缀后调用search_default_file_with_ext,linux下该处匹配为.cnf 。具体处理流程如下:

根据文件夹、文件名 后缀获取完整文件名

检查文件是否有读权限

读取每行记录:

跳过#、:和空行

对于!开头的行,检查是否包含子配置文件

找到[]中的组信息,赋值给curr_gr,调用handle_default_option处理

删除本行结尾#的注释

如果没有参数,将--配置项添加到ctx中

对value的去掉前后空格,去掉开头和结尾的‘  “

对option前面添加--,放在--option=value放入ctx中

handle_options函数

init_variables(longopts, init_one_value):将系统变量的值设置为初始值,对每个成员u_max赋值为max,value赋值为def _value.

init_one_value:为单个变量设置初始值。eg:调用getopt_ll_limit_value函数为int类型赋初值。在复制过程中会检测先关的条件:max_value\min_value\block_size的整数倍

for (pos= *argv, pos_end=pos+ *argc; pos != pos_end ; pos++) :遍历每个命令行配置项

if (!is_cmdline_arg && (my_getopt_is_args_separator(cur_arg))):跳过分隔行

解析命令行中的值字段

opt_str= check_struct_option(cur_arg, key_name);

optend= strcend(opt_str, '=');

length= (uint) (optend - opt_str);

if (!(opt_found= findopt(opt_str, length, &optp))) :查找该参数匹配的系统变量,如果匹配不到,进行前缀匹配

argument= optend;通过value保存该变量对应的值

setval(optp, optp->value, argument, set_maximum_value) // 赋值操作:将argument的值放入opttp->value中

get_one_option && get_one_option(optp->id, optp, argument):对一些特殊类型的变量做特殊处理,用于解析变量的类型并设置特殊的变量值