如何使用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

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

    而/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的日志已经生成了

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



    使用Docker可以快速构建MySQL环境,但是在使用数据卷时,可能会遇到数据丢失或者数据不同步的问题。这时我们可以使用MySQL的binlog日志来解决。
    一、为什么需要使用binlog日志?
    二、如何开启MySQL的binlog日志?
    三、如何备份binlog日志?
    四、如何恢复binlog日志?
    五、如何监控binlog日志?
    六、如何将binlog日志同步到其他MySQL实例?
    七、如何对binlog日志进行管理?
    使用binlog日志可以解决MySQL数据不同步或者丢失的问题,同时也可以实现MySQL数据同步。在使用binlog日志时,需要注意备份和恢复的方式,以及日志监控和管理。如果您也遇到了Docker数据卷的问题,那么可以尝试使用binlog日志来解决。