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

  
  
  • 1

备注:需提前在宿主机目录下创建一个文件用于保存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的日志已经生成了
        在这里插入图片描述

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

        结语

        本篇的初衷是为了快速搭建mysql并能想办法检测到bin_log的日志达到后续使用bin_log检测表数据变化的目的,因此使用docker安装贺启动mysql是比较方便的,但由于是初次尝试,在网上参考相关的资料时发现基大多数博客的内容基本上没有经过验证,或者说很难实施出效果,最终总结出上面可执行的流程,提供后续的参考和使用!友情提示,网上的资料请慎重参考!最后感谢观看!

        Docker中的MySQL要通过binlog文件恢复数据,通常涉及以下几个步骤: 1. **停止并备份容器**: 首先需要停止MySQL容器,并确保记录下容器ID,以便后续操作。 ```sh docker stop mysql_container_id ``` 2. **获取binlog日志**: 登录到运行MySQL的主机(通常是宿主机),找到MySQL的数据卷目录,一般是在`/var/lib/mysql`路径下。然后找到对应的数据库(如`mysql`)的binlog文件。 ```sh cd /var/lib/mysql/your_database_name ls binlogs | head -n 1 # 查看最近的binlog文件名 ``` 3. **下载binlog**: 使用`rsync`或其他工具将binlog文件复制到本地或者其他服务器。 ```sh rsync -avh mysql_host:/var/lib/mysql/your_database_name/binlogs/* /path/to/local/binlogs/ ``` 4. **恢复数据**: 可以使用`mysqldump`命令结合binlog文件来恢复数据,例如: ```sh # 创建临时数据库接收恢复数据 mysql -p < create_temp_db.sql # 运行mysqlbinlog来恢复数据 mysqlbinlog /path/to/local/binlogs/file_name > recovery.sql # 将恢复脚本导入新创建的临时数据库 mysql -u root -p temporary_db_name < recovery.sql 5. **切换为主数据库**: 数据恢复完成后,可以将临时数据库提升为主数据库。 ```sql RENAME DATABASE temporary_db_name TO your_database_name; ``` 6. **清理资源**: 删除临时数据库及相关日志文件。 注意:这个过程涉及到对生产环境数据的操作,务必谨慎操作并在测试环境中验证。如果直接在生产环境中尝试可能会导致不可逆的数据丢失。
        评论
        添加红包

        请填写红包祝福语或标题

        红包个数最小为10个

        红包金额最低5元

        当前余额3.43前往充值 >
        需支付:10.00
        成就一亿技术人!
        领取后你会自动成为博主和红包主的粉丝 规则
        hope_wisdom
        发出的红包
        实付
        使用余额支付
        点击重新获取
        扫码支付
        钱包余额 0

        抵扣说明:

        1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
        2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

        余额充值