MySQL客户端对配置文件的读取顺序
一、户端场景现象

在本地做测试时,对配读发现一个奇怪的置文现象,当我使用 socket 打算登录数据库,顺序发现不指定用户时,户端默认并不是对配读用的 root 用户登录,而是置文被修改为了 zhenxing 用户。
复制[root@10-186-61-162 ~]# mysql -S /data/mysql/3306/data/mysqld.sock -pEnter password:
ERROR 1045 (28000): Access denied for user zhenxing@127.0.0.1 (using password: NO)1.2.3.通过观测当前 mysql 客户端的顺序默认参数行为,可以看到与报错一致,户端默认用户确实是对配读变为了 zhenxing。
复制[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.1port 3306user zhenxing1.2.3.4.5.6.7.在这里作为 DBA ,我们的顺序第一反应是肯定是查看 /etc/my.cnf 文件中是否对默认用户做了配置,于是户端查看该配置文件的客户端配置参数,如下
复制[client]
host = 127.0.0.1user = rootport = 3306[mysql]
host = 127.0.0.1user = rootport = 3306prompt = \U[\d]> 1.2.3.4.5.6.7.8.9.10.发现配置文件中的对配读反而配置值是 root 用户,并没有对 zhenxing 用户做配置,置文看来读取的还不是这个配置文件,那是不是香港云服务器读取了其他配置文件呢,继续排查其他的配置文件。
二、排查思路
1、获取配置文件读取顺序我们先打印出所有可能读取的配置文件及其读取的顺序做逐个排查。
复制## 查看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.cnf1.2.3.4. 2、排查 /etc/my.cnf/etc/my.cnf 在前面已经确认没有做相关配置,这里直接跳过。
3、排查 /etc/mysql/my.cnf查看 /etc/mysql/my.cnf 配置,发现不存在相关配置,排除。
复制[root@10-186-61-162 ~]# cat /etc/mysql/my.cnfcat: /etc/mysql/my.cnf: 没有那个文件或目录1.2. 4、排查 /usr/local/mysql/etc/my.cnf查看 /usr/local/mysql/etc/my.cnf 配置,发现不存在相关配置,排除。
复制[root@10-186-61-162 ~]# cat /usr/local/mysql/etc/my.cnfcat: /usr/local/mysql/etc/my.cnf: 没有那个文件或目录1.2. 5、排查 /data/mysql/3306/base/my.cnf查看 /data/mysql/3306/base/my.cnf 配置,发现不存在相关配置,排除。
复制[root@10-186-61-162 ~]# cat /data/mysql/3306/base/my.cnfcat: /data/mysql/3306/base/my.cnf: 没有那个文件或目录1.2. 6、排查 ~/.my.cnf查看 ~/.my.cnf 依旧不存在相关配置,排除。
复制[root@10-186-61-162 ~]# cat ~/.my.cnfcat: /root/.my.cnf: 没有那个文件或目录1.2.至此按照 mysql --verbose --help|grep my.cnf 获取的配置文件读取路径都被排除,都未对用户zhenxing做配置。
7、使用no-defaults排除配置文件干扰尝试用 --no-defaults 不读取任何配置文件排除配置文件的干扰,看是否会恢复正常。
复制[root@10-186-61-162 ~]# mysql --help|grep no-defaults--no-defaults Dont 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.1port 3306user zhenxing## 查看读取的所有客户端配置文件参数设置[root@10-186-61-162 ~]# mysql --print-defaultsmysql 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=33061.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.从上面输出的结果来看,我们可以得到以下2个基本现象:
即使指定--no-defaults不读取任何配置文件,这个 user 的服务器租用默认值依旧是 zhenxing 用户当输出--print-defaults获取实际运行值时,可以看到 /etc/my.cnf 下的[client] ,和 [mysql] 标签下的属性配置从上到下被正确获取除了 /etc/my.cnf 外,在最后还有--user=zhenxing --password=***** --host=127.0.0.1 --port=3306这4个参数被额外添加到了命令最后ps:mysql 客户端和服务端读取配置的原则都是文件读取从上到下,后面相同参数配置覆盖前面的参数经过一系列的排除,依旧没找到这个默认值被修改的源头
8、打印 mysql 客户端的系统调用使用 strace 直接观测 mysql 客户端在执行时到底调用了哪些配置,以下是调用 my.cnf 相关配置的片段(对结果做了精简输出) 复制1. stat("/etc/my.cnf", {st_mode=S_IFREG|0644, st_size=195, ...}) = 0 = 32. stat("/etc/mysql/my.cnf", 0x7ffd56813180) = -1 ENOENT (No such file or directory)
3. stat("/usr/local/mysql/etc/my.cnf", 0x7ffd56813180) = -1 ENOENT (No such file or directory)
4. stat("/data/mysql/3306/base/my.cnf", 0x7ffd56813180) = -1 ENOENT (No such file or directory)
5. stat("/root/.my.cnf", 0x7ffd56813180) = -1 ENOENT (No such file or directory)
6. stat("/root/.mylogin.cnf", {st_mode=S_IFREG|0600, st_size=336, ...}) = 01.2.3.4.5.6.通过以上调用顺序可以可到以下结论:
1-5行的调用顺序与我们验证的逻辑基本一致2-5行显示为 No such file or directory 与我们的验证结果一致第6行输出,增加了一个对 /root/.mylogin.cnf 的读取操作,并且可以知道当前这个文件是确实存在的9、排查 /root/.mylogin.cnf看到这个文件我们一般都知道,这个是 mysql_config_editor 工具用来配置 login-path 的生成的文件,我们可以用以下方式查看当前的配置信息。网站模板
复制[root@10-186-61-162 ~]# mysql_config_editor print --all[client]
user = "zhenxing"password = *****host = "127.0.0.1"port = 33061.2.3.4.5.6.这里可以看到配置中有一个 client 标签的连接参数配置,配置的内容正好是我们文章开头显示的异常默认值,到这我们基本定位了造成这个奇怪现象的原因,出现这个故障场景的原因也是刚好这台是测试环境曾经做过一些 mysql_config_editor 用法的测试,导致了该现象的发生
三、场景总结
1、mysql客户端除了会按照命令 mysql --verbose --help|grep my.cnf输出的常规的顺序读取配置外,在最后还会额外的读取 .mylogin.cnf 文件中配置。
2、即使指定了 --no-defaults ,依旧会去读取 .mylogin.cnf 中的 [client] ,[mysql] 标签的配置值。
其中官方文档也在以下链接中给到了明确的说明(以下是关键描述片段)。
https://dev.mysql.com/doc/refman/8.0/en/option-file-options.html 复制The mysql client reads [client] and [mysql] from other option files, and [client], [mysql], and [mypath] from the login path file.
Client programs read the login path file even when the --no-defaults option is used. This permits passwords to be specified in a safer way than on the command line even if --no-defaults is present.1.2.3. 个人猜测当时这么设计的目的是考虑如备份脚本等需要连接数据库时,为了防止非必要的参数文件的干扰,在指定了 --no-defaults参数后依旧能使用到 .mylogin.cnf 文件中配置的加密密码,提升安全性。相关文章
一体机系统重装教程(简明易懂的一体机系统重装步骤,帮你重拾流畅体验)
摘要:当一体机的操作系统出现严重崩溃或运行缓慢的情况时,重新安装系统是一种常见的解决方法。然而,对于不了解如何进行一体机系统重装的用户来说,这可能会是一个相当困难的任务。本文将向您详细介...2025-11-05
想了解更多内容,请访问:和华为官方合作共建的鸿蒙技术社区https://harmonyos.51cto.com一、介绍小的时候就看过一个节目,就报菜名,一直印象很深刻,“蒸羊羔、蒸熊掌、蒸鹿尾儿、烧花2025-11-05
之前在交流群有人问过这样一个问题:当时我介绍了一个名为 Tiler 的 GitHub 开源库。这个 Python 项目很骚气!一秒生成可爱像素风图片!今天小五就给大家实战演示一下,如何将一个普通表情包2025-11-05
手把手教你用Scrapy爬虫框架爬取食品论坛数据并存入数据库
大家好,我是杯酒先生,这是我第一次写这种分享项目的文章,可能很水,很不全面,而且肯定存在说错的地方,希望大家可以评论里加以指点,不胜感激!一、前言网络爬虫(又称为网页蜘蛛,网络机器人),是一种按照一定2025-11-05页面设置方法与文章布局技巧(提高文章可读性的关键步骤和注意事项)
摘要:在撰写一篇文章时,除了内容的质量外,页面的设置和布局也是至关重要的因素之一。通过合理的页面设置和布局,可以提高文章的可读性和吸引力,使读者更容易理解和接受文章的内容。本文将介绍一些...2025-11-05
你只会用 split?试试 StringTokenizer,性能可以快 4 倍!!
我们都知道,分割字符串要使用 String 的 split() 方法,split 方法虽然深入人心,使用也简单,但效率太低!其实在 JDK 中,还有一个性能很强的纯字符串分割工具类:StringTok2025-11-05

最新评论