Docker部署mysql一主一从的操作方法

 更新时间:2021年05月11日 14:24:07   作者:运维老司机  
这篇文章主要介绍了Docker部署mysql一主一从,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

下载镜像

选择MySQL镜像

docker search mysql

在这里插入图片描述

下载MySQL5.7镜像

docker pull mysql:5.7

查看mysql镜像

docker images

在这里插入图片描述

搭建MySQL主从

master

docker run --name mysql-master -p 3307:3306 -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7

slave

docker run --name mysql-slave -p 3308:3306 -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7

Master对外映射的端口号是3307,Slave对外映射的端口号是3308

查看容器

docker ps

在这里插入图片描述

连接测试

在这里插入图片描述
在这里插入图片描述

配置Master

进入容器 以下两种进入方式都可以

docker exec -it 1b166e12ad6b /bin/bash   #1b166e12ad6b是容器id
docker exec -it mysql-master /bin/bash     #mysql-master是容器名称 

修改/etc/mysql/my.cnf 配置文件

vim /etc/mysql/my.cnf

在这里插入图片描述

vim命令没有找到 docker内部安装vim工具 输入下面两条命令安装 vim

apt-get update
apt-get install vim

安装完成之后 修改my.cnf 配置文件

vim /etc/mysql/my.cnf

[mysqld]
## 同一局域网内注意要唯一
server-id=100  
## 开启二进制日志功能,可以随便取(关键)
log-bin=master-bin
binlog-format=ROW     // 二进制日志格式,有三种 row,statement,mixed

配置完重启MySQL

service mysql restart

重启会导致docker容器停止,使用如下命令重新启动容器

docker ps -a

在这里插入图片描述

docker start mysql-master

创建数据库同步账户

进入mysql-master容器里面

docker exec -it 1b166e12ad6b /bin/bash

登录到mysql中给slave主机授权同步账号

mysql -uroot -p123456

CREATE USER 'slave'@'%' IDENTIFIED BY '123456';
GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave'@'%';

在这里插入图片描述

到这master配置完成

Slave

与master相似 使用命令进入到容器

docker exec -it mysql-slave /bin/bash

修改my.cnf配置文件 记得安装vim命令

vim /etc/mysql/my.cnf

[mysqld]
## 设置server_id,注意要唯一
server-id=101  
## 开启二进制日志功能,以备Slave作为其它Slave的Master时使用
log-bin=mysql-slave-bin   
## relay_log配置中继日志
relay_log=mysql-relay-bin  
read_only=1  ## 设置为只读,该项如果不设置,表示slave可读可写

重启MySQL

service mysql restart

启动容器

docker start mysql-slave

开启Master-Slave主从复制

首先打开两个终端分别进入master和slave容器 并进入MySQL

mysql-master操作

mysql -uroot -p123456
show master status;

在这里插入图片描述

mysql-slave操作

注:记得把master_log_file='', master_log_pos= 改成自己在master机器上面查看的结果

mysql -uroot -p123456

change master to master_host='10.0.3.2', master_user='slave', master_password='123456', master_port=3307, master_log_file='master-bin.000001', master_log_pos=617;

start slave;

show slave status \G;

在这里插入图片描述

测试是否成功

mysql-master操作

create database dockertest;

在这里插入图片描述

mysql-slave操作

在这里插入图片描述

slave上面出现在master上面创建的数据库证明成功。

文章参考连接

详细介绍可参考

到此这篇关于Docker部署mysql一主一从的操作方法的文章就介绍到这了,更多相关Docker部署mysql内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 如何使用docker配置wordpress

    如何使用docker配置wordpress

    本文详细介绍了如何使用Docker安装并配置WordPress,包括配置Yum源下载Docker,检查安装成功,并设置开机启动,还涉及了如何配置MySQL密码,以及设置php.ini来增加WordPress的文件上传大小限制,最后,通过访问指定IP完成WordPress的配置
    2024-10-10
  • docker查看日志命令的实现步骤

    docker查看日志命令的实现步骤

    Docker可以使用 docker logs 命令来查看容器的日志,本文主要介绍了docker查看日志命令的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-08-08
  • 如何隔离docker容器中的用户的方法

    如何隔离docker容器中的用户的方法

    这篇文章主要介绍了如何隔离docker容器中的用户的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-09-09
  • Docker实现同Ip网段联通的实现

    Docker实现同Ip网段联通的实现

    这篇文章主要介绍了Docker实现同Ip网段联通的实现,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-12-12
  • 详解ASP.NET Core 网站在Docker中运行

    详解ASP.NET Core 网站在Docker中运行

    本篇文章主要介绍了详解ASP.NET Core 网站在Docker中运行,非常具有实用价值,需要的朋友可以参考下
    2017-05-05
  • Spring Boot Docker打包工具小结

    Spring Boot Docker打包工具小结

    本文对几种常见的Spring Boot Docker打包工具进行了简单总结,感兴趣的朋友跟随小编一起看看吧
    2021-05-05
  • 详解Docker挂载本地目录

    详解Docker挂载本地目录

    这篇文章主要介绍了详解Docker挂载本地目录,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • docker配置静态ip的实现示例

    docker配置静态ip的实现示例

    如果不配置会docker会自动分配ip地址给容器,但是每次重启后ip地址会改变,本文主要介绍了docker配置静态ip的实现示例,具有一定的参考价值,感兴趣的可以了解一下
    2023-12-12
  • docker mysql关于配置文件、连接客户端、/docker-entrypoint-initdb.d/目录的使用

    docker mysql关于配置文件、连接客户端、/docker-entrypoint-initdb.d/目录的使用

    这篇文章主要介绍了docker mysql关于配置文件、连接客户端、/docker-entrypoint-initdb.d/目录的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-05-05
  • docker中的python代码打印失效的解决

    docker中的python代码打印失效的解决

    这篇文章主要介绍了docker中的python代码打印失效的解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-07-07

最新评论