项目场景:

在需要开启MySQL binlog功能的时候,在my.cnf加了相关配置后,发现一直无法开启

[client]
default_character_set=utf8
[mysqld]
server-id=1
collation_server=utf8_general_ci
character_set_server=utf8
log-bin=mysql-bin
binlog_format=row
expire_logs_days=30

问题描述:

我这里为Docker环境,进入Docker容器后,本地连接的时候看到警告

mysql: [Warning] World-writable config file '/etc/mysql/conf.d/my.cnf' is ignored.

mysql: [Warning] World-writable config file ‘/etc/mysql/conf.d/my.cnf‘ is ignored._Docker


原因分析:

这个警告出现的原因是 MySQL 发现挂载的配置文件 /etc/mysql/conf.d/my.cnf 具有全局可写权限,因此忽略了该文件。MySQL 引擎非常注重安全性和数据完整性。如果配置文件具有全局可写权限,任何用户都可以修改该文件,包括恶意用户。这可能导致潜在的安全风险和数据损坏。为了提高安全性,当 MySQL 检测到挂载的配置文件具有全局可写权限时,它会发出警告并忽略该文件。这样做是为了确保只有授权的用户能够修改配置文件并对 MySQL 进行更改。


mysql: [Warning] World-writable config file ‘/etc/mysql/conf.d/my.cnf‘ is ignored._MySQL_02

解决方案:

需要修改my.cnf的文件权限

chmod 644 my.inf

这样MySQL会成功读取该文件,如果不是在Docker环境中的小伙伴,到这里就已经解决问题了!在Docker环境中的小伙伴可以接着往下看。

在Docker中,重启Docker 容器,权限是会还原的,所以针对不同的操作系统,需要不同的解决办法

假设我在Windows环境,我的启动命令为

docker run -d -p 3306:3306 --privileged=true -v D:/Dev/mysql5.7.38/log:/var/log/mysql -v D:/Dev/mysql5.7.38/data:/var/lib/mysql -v D:/Dev/mysql5.7.38/conf:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=123456 --name mysql mysql:5.7.38

Windows的权限和Linux不能完全等同,只需要稍微限制一下就可以了,右键my.inf文件,直接勾选只读即可,这样就会正确读取到mysql配置文件,连接的时候也不会有刚才的警告了

mysql: [Warning] World-writable config file ‘/etc/mysql/conf.d/my.cnf‘ is ignored._MySQL_03

docker restart mysql
docker exec -it mysql bin/bash
ls -l /etc/mysql/conf.d/my.cnf
mysql -uroot -p
SHOW VARIABLES LIKE 'log_bin';

可以看到警告消失,binlog成功开启

mysql: [Warning] World-writable config file ‘/etc/mysql/conf.d/my.cnf‘ is ignored._Docker_04

如果为Linux系统,直接将上面步骤的勾选只读文件,改为修改Docker宿主机的my.cnf权限为644即可