docker部署mysql多实例(Docker部署mysql一主一从的操作方法)
类别:服务器 浏览量:642
时间:2021-10-11 00:34:49 docker部署mysql多实例
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镜像怎么用(Docker和镜像的操作方法)
- docker 增大mysql连接数(docker中修改mysql最大连接数及配置文件的实现)
- docker如何访问nginx(基于docker启动nginxssl配置)
- 无法访问docker容器内的端口(docker端口映射及外部无法访问问题)
- docker的安装部署(Docker快速安装Zookeeper的详细教程)
- docker启动指定容器ip(Docker每次启动容器,IP及hosts指定的操作)
- 在docker中运行springboot(Linux Docker运行springboot项目的步骤详解)
- docker网络有哪些模式(Docker网络原理及自定义网络详细解析)
- postgresql docker 宿主机(本地Docker安装Postgres 12 + pgadmin的方法 支持Apple M1)
- docker 容器相关问题(docker空间爆满导致的进入容器失败的解决方案)
- zabbix启动教程(docker部署zabbix_agent的方法步骤)
- dockermysql实例(docker 连接宿主Mysql操作)
- docker的解剖(再见 Docker如何5分钟转型 containerd)
- docker虚拟化容器使用教程(Docker安装ClickHouse并初始化数据测试)
- docker怎么设置redis(docker安装redis并以配置文件方式启动详解)
- docker管理工具选择(Docker可视化管理工具DockerUI的使用)
- 红色代表什么(红色代表什么情感和含义)
- 高中数学题(高中数学题型总结及解题方法)
- 冰岛旅游攻略(冰岛旅游攻略及花费)
- 为什么现在年轻人越来越喜欢买衣服(为什么现在年轻人越来越喜欢买衣服穿)
- 怎么做好SEO(怎么做好seo内容优化)
- 冬季钓鱼子线用 长 还是 短(冬季钓鱼子线用)
热门推荐
- pgsql函数里有多个事务如何处理(关于SQL数据库 msdb.dbo.sp_send_dbmail 函数发送邮件的场景分析)
- php微信支付怎么做(ThinkPHP框架整合微信支付之Native 扫码支付模式一图文详解)
- 自建FTP服务器并远程外网访问,花生棒自带端口映射3步搞定(自建FTP服务器并远程外网访问,花生棒自带端口映射3步搞定)
- SQL Server作业
- amaze ui使用教程(Amaze UI 文件选择域的示例代码)
- react跳转页面并传参数(react 跳转后路由变了页面没刷新的解决方案)
- dede友情链接改为logo轮播教程(dedecms广告生成JS文件和JS调用-DEDE广告优化)
- dedecms新手建站教程网页设计(DEDECMS幻灯片中JavaScript实际应用举例)
- 一分钟看懂响应式编程(浅谈Rx响应式编程)
- JS中对象的属性
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9