修改 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设置的binlog_expire_logs_seconds参数会失效,因此需要通过配置文件来持久化该设置。

如何在Docker中挂载自定义的MySQL配置文件?

在docker-compose.yml中,可以通过volumes选项挂载自定义的mysql.cnf文件,例如:- ./mysql.cnf:/etc/mysql/conf.d/mysql.cnf。

创建自定义配置文件时需要注意什么?

需要确保在宿主机创建的mysql.cnf文件中包含正确的配置,并确认Docker中的/etc/mysql/conf.d/目录存在且可以读取该文件。

如何确认Docker中的配置文件是否生效?

可以通过执行docker compose up -d mysql命令重启容器,并检查网站和配置是否正常,以确认新配置是否生效。

使用配置文件管理MySQL参数有什么优势?

使用配置文件管理MySQL参数的方式易于维护,能够避免在每次重启后手动设置参数,节省重复劳动。

➡️

继续阅读