MySQL客户端对配置文件的读取顺序
使用 mysql 客户端去访问 MySQL 数据库时,会以一定的顺序去读取不同位置的配置文件。
一、场景现象
在本地做测试时,发现一个奇怪的现象,当我使用 socket 打算登录数据库,发现不指定用户时,默认并不是用的 root 用户登录,而是被修改为了 zhenxing 用户
1 2 3 | [root@10-186-61-162 ~]# mysql -S /data/mysql/3306/data/mysqld.sock -p Enter password: ERROR 1045 (28000): Access denied for user 'zhenxing'@'127.0.0.1' (using password: NO) |
通过观测当前 mysql 客户端的默认参数行为,可以看到与报错一致,默认用户确实是变为了 zhenxing
1 2 3 4 5 6 7 | [root@10-186-61-162 ~]# mysql --help|egrep "user|host|port" -h, --host=name Connect to host. -P, --port=# Port number to use for connection or 0 for default to, in -u, --user=name User for login if not current user. host 127.0.0.1 port 3306 user zhenxing |
在这里作为 DBA ,我们的第一反应是肯定是查看 /etc/my.cnf 文件中是否对默认用户做了配置,于是查看该配置文件的客户端配置参数,如下
1 2 3 4 5 6 7 8 9 10 | [client] host = 127.0.0.1 user = root port = 3306 [mysql] host = 127.0.0.1 user = root port = 3306 prompt = '\U[\d]> ' |
发现配置文件中的反而配置值是 root 用户,并没有对 zhenxing 用户做配置,看来读取的还不是这个配置文件,那是不是读取了其他配置文件呢,继续排查其他的配置文件
二、排查思路
1、获取配置文件读取顺序
我们先打印出所有可能读取的配置文件及其读取的顺序做逐个排查
1 2 3 4 | ## 查看mysql客户端读取配置文件的顺序 [root@10-186-61-162 ~]# mysql --verbose --help|grep my.cnf order of preference, my.cnf, $MYSQL_TCP_PORT, /etc/my.cnf /etc/mysql/my.cnf /usr/local/mysql/etc/my.cnf /data/mysql/3306/base/my.cnf ~/.my.cnf |
2、排查 /etc/my.cnf
/etc/my.cnf 在前面已经确认没有做相关配置,这里直接跳过
3、排查 /etc/mysql/my.cnf
查看 /etc/mysql/my.cnf 配置,发现不存在相关配置,排除
1 2 | [root@10-186-61-162 ~]# cat /etc/mysql/my.cnf cat: /etc/mysql/my.cnf: 没有那个文件或目录 |
4、排查 /usr/local/mysql/etc/my.cnf
查看
/usr/local/mysql/etc/my.cnf
配置,发现不存在相关配置,排除
1 2 | [root@10-186-61-162 ~]# cat /usr/local/mysql/etc/my.cnf cat: /usr/local/mysql/etc/my.cnf: 没有那个文件或目录 |
5、排查 /data/mysql/3306/base/my.cnf
查看
/data/mysql/3306/base/my.cnf
配置,发现不存在相关配置,排除
1 2 | [root@10-186-61-162 ~]# cat /data/mysql/3306/base/my.cnf cat: /data/mysql/3306/base/my.cnf: 没有那个文件或目录 |
6、排查 ~/.my.cnf
查看
~/.my.cnf
依旧不存在相关配置,排除
1 2 | [root@10-186-61-162 ~]# cat ~/.my.cnf cat: /root/.my.cnf: 没有那个文件或目录 |
至此按照 mysql --verbose --help|grep my.cnf
获取的配置文件读取路径都被排除,都未对用户zhenxing做配置
7、使用no-defaults排除配置文件干扰
- 尝试用 --no-defaults 不读取任何配置文件排除配置文件的干扰,看是否会恢复正常
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | [root@10-186-61-162 ~]# mysql --help|grep no-defaults --no-defaults Don't read default options from any option file ## 查看不读取配置文件时,客户端的默认值 [root@10-186-61-162 ~]# mysql --no-defaults --help|egrep "user|host|port" -h, --host=name Connect to host. -P, --port=# Port number to use for connection or 0 for default to, in -u, --user=name User for login if not current user. host 127.0.0.1 port 3306 user zhenxing ## 查看读取的所有客户端配置文件参数设置 [root@10-186-61-162 ~]# mysql --print-defaults mysql would have been started with the following arguments: --host=127.0.0.1 --user=root --port=3306 --host=127.0.0.1 --user=root --port=3306 --prompt=\U[\d]> --user=zhenxing --password=***** --host=127.0.0.1 --port=3306 |