修改 docker 中安装的 MySQL 的配置参数
💡
原文中文,约1300字,阅读约需4分钟。
📝
内容提要
发现MySQL的binlog文件占用大量磁盘空间,重启后binlog_expire_logs_seconds参数失效。通过创建自定义配置文件并挂载到Docker中,成功解决了问题,节省了服务器空间。
🎯
关键要点
- 发现MySQL的binlog文件占用大量磁盘空间。
- 重启后binlog_expire_logs_seconds参数失效。
- 创建自定义配置文件并挂载到Docker中解决了问题。
- 使用配置文件的方式易于维护。
- 在宿主机创建mysql.cnf文件,设置binlog_expire_logs_seconds为259200秒(3天)。
- 在docker-compose.yml中挂载mysql.cnf文件。
- 确认docker中的/etc/mysql/conf.d/目录存在且包含配置文件。
- 通过docker compose up -d mysql使新配置生效。
- 重启后检查网站和配置是否正常,结果一切正常。
❓
延伸问答
如何解决MySQL的binlog文件占用大量磁盘空间的问题?
可以通过创建自定义配置文件并挂载到Docker中,设置binlog_expire_logs_seconds参数为259200秒(3天)来解决。
为什么重启后binlog_expire_logs_seconds参数会失效?
因为之前通过mysql console设置的参数在重启mysql docker容器后不会自动生效。
如何在Docker中挂载MySQL的配置文件?
在docker-compose.yml中使用volumes选项挂载配置文件,例如:- ./mysql.cnf:/etc/mysql/conf.d/mysql.cnf。
创建自定义配置文件的步骤是什么?
在宿主机创建mysql.cnf文件,内容为[mysqld] binlog_expire_logs_seconds=259200,然后在docker-compose.yml中挂载该文件。
如何确认Docker中的配置文件是否生效?
可以通过执行docker compose exec mysql bash进入容器,检查/etc/mysql/conf.d/目录下是否存在配置文件,并确认binlog_expire_logs_seconds的值。
使用配置文件的方式有什么优点?
使用配置文件的方式易于维护,便于管理和修改MySQL的配置参数。
➡️