这篇文章将为大家详细讲解有关Docker如何部署mysql一主一从,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。下载镜像选择Mysql镜像docker search mysql下载My
这篇文章将为大家详细讲解有关Docker如何部署mysql一主一从,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
选择Mysql镜像
docker search mysql
下载Mysql5.7镜像
docker pull mysql:5.7
查看mysql镜像
docker images
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
连接测试
进入容器 以下两种进入方式都可以
docker exec -it 1b166e12ad6b /bin/bash #1b166e12ad6b是容器iddocker exec -it mysql-master /bin/bash #mysql-master是容器名称
修改/etc/mysql/my.cnf 配置文件
vim /etc/mysql/my.cnf
vim命令没有找到 docker内部安装vim工具 输入下面两条命令安装 vim
apt-get updateapt-get install vim
安装完成之后 修改my.cnf 配置文件
vim /etc/mysql/my.cnf[mysqld]## 同一局域网内注意要唯一server-id=100 ## 开启二进制日志功能,可以随便取(关键)log-bin=master-binbinlog-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 -p123456CREATE 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容器 并进入MySQL
mysql-master操作
mysql -uroot -p123456show master status;
mysql-slave操作
注:记得把master_log_file='', master_log_pos= 改成自己在master机器上面查看的结果
mysql -uroot -p123456change 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一主一从”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
--结束END--
本文标题: Docker如何部署mysql一主一从
本文链接: https://lsjlt.com/news/276369.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-10-23
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0