当前位置:   article > 正文

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

mysqld waring world-writable config file is ignored

项目场景:

在需要开启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
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

问题描述:

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

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

在这里插入图片描述


原因分析:

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


在这里插入图片描述

解决方案:

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

chmod 644 my.inf
  • 1

这样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
  • 1

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

在这里插入图片描述

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';
  • 1
  • 2
  • 3
  • 4
  • 5

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

在这里插入图片描述

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

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/从前慢现在也慢/article/detail/1011325
推荐阅读
相关标签
  

闽ICP备14008679号