1、MySQL读取配置文件的顺序mysql
读取顺序:/etc/my.cnf > /etc/mysql/my.cnf > /usr/etc/my.cnf > ~/.my.cnfsql
命令验证:
[root@mysql ~]# mysql --verbose --help | grep my.cnf
order of preference, my.cnf, $MYSQL_TCP_PORT,
/etc/my.cnf /etc/mysql/my.cnf /usr/etc/my.cnf ~/.my.cnf函数
2、MySQL启动方式post
MySQL的启动方式一般分红三种:mysqld、mysqld_safe、mysqld_multi(主要用于多实例启动)server
三种方式的关系:
首先当咱们使用service mysqld start或者/etc/init.d/mysqld start这样的方式启动的时候,实际上是使用了mysql.server这个脚本,这个脚本默认会调用mysqld_safe来启动mysqld,因此一般咱们启动mysql以后查看进程的时候会发现有mysqld和mysqld_safe这两个进程存在。这两种一般都是单实例的启动方式,固然也可使用mysqld来启动多实例的。而mysqld_multi用来启动多实例,也是经过先调用mysqld_safe和mysqld来启动mysql的。blog
3、MySQL启动原理进程
默认的mysql的服务启动程序是mysql.server,mysql.server程序主要是会用到两个程序和一个函数,分别是my_print_defaults、myslqd_safe和parse_server_argumentsit
一、my_print_defaults:读取my.cnf配置文件,输出参数传递给parse_server_arguments,该程序只读my.cnf中[mysqld]中的参数。class
二、parse_server_arguments:该函数处理my_print_defaults传递过来的参数赋值给--basedir、--datadir、--pid-file、--server-startup-timeout原理
三、myslqd_safe:mysqld_safe程序调用mysqld程序来启动mysql服务,[mysqld_safe]会覆盖mysqld部分中的参数
四、mysqld_multi会读取配置文件中的[mysqld_muti],[mysqldN]下面的参数,N须要时一个整数,建议用端口号表示,该部分的配置会覆盖[mysqld]部分中的配置
五、在mysqld进程挂掉的时候,mysqld_safe进程会监测到并从新将mysqld启动起来。