修改 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的配置参数。

➡️

继续阅读