如何使用docker开启mysql的binlog日志解决数据卷问题

网友投稿 1107 2023-07-07

如何使用docker开启mysql的binlog日志解决数据卷问题

如何使用docker开启mysql的binlog日志解决数据卷问题

前言

在开发中,需要通过监听mysql的binlog日志文件做到对数据表的监控,由于mysql是部署在docker容器中,还需要解决数据卷的问题

1、通过数据卷的方式开启一个mysql镜像

docker run -p 3307:3306 --name myMysql -v /usr/docker/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7.25登录后复制

备注:需提前在宿主机目录下创建一个文件用于保存mysql的数据集,我这里创建的目录是 /usr/docker/mysql/data

而/var/lib/mysql是mysql镜像开启后的固定目录,一般是不需要我们手动去干扰的,保持默认的就可以

2、连接mysql并进行测试

使用客户端连接工具连接上mysql,尝试着观察一下mysql_binlog的开启情况

可以看到此时并没有开启日志功能,同时我们也可以去到宿主机的挂载目录下观察一下,

3、开启bin_log

依次执行下面的命令

docker exec myMysql bash -c "echo 'log-bin=/var/lib/mysql/mysql-bin' >> /etc/mysql/mysql.conf.d/mysqld.cnf"登录后复制

docker exec myMysql bash -c "echo 'server-id=123454' >> /etc/mysql/mysql.conf.d/mysqld.cnf"登录后复制

4、重启mysql镜像

docker restart myMysql登录后复制

5、创建一个数据库并在里面创建一个表加一条数据

这时我们再观察一下bin_log的变化,说明这时候bin_log的日志已经生成了

也可以进入到宿主机目录下进行观察,这时在宿主机下已经产生了日志文件

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:mysql怎么设置字符集
下一篇:docker官方mysql镜像自定义配置的方法
相关文章