Mysql—主从复制
创始人
2024-05-30 09:10:15
0

主从复制

创建mysql

基于docker创建2个mysql容器

1、拉取mysql镜像,这里拉取最新的8.0.20

docker pull mysql:latest

在这里插入图片描述

2、使用镜像运行两个mysql容器:mysql 和 mysql-2

docker run -itd --name mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root mysql
docker run -itd --name mysql-2 -p 33062:3306 -e MYSQL_ROOT_PASSWORD=root mysql

mysql 使用容器服务的3306端口,映射到主机的3306端口,密码root
mysql-2 使用容器服务的33062端口,映射到主机的3306端口,密码root

3、可以看到两个运行起来的mysql

docker ps

在这里插入图片描述
4、可以使用工具试着连接两个mysql
在这里插入图片描述

mysql主从配置

1、先在mysql上进行用户创建及授权,这样mysql-2可以通过该用户连接mysql

5.7版本的mysql授权命令为:

GRANT replication slave on *.* to 'repl'@'%' IDENTIFIED by 'root';

在这里插入图片描述

但是因为我们的mysql版本为8.0.20,用户创建和授权需要分开执行

# 创建用户
create user 'repl'@'%' IDENTIFIED by 'root';

在这里插入图片描述
创建好用户后,可以查询该用户默认的权限值

# 查询用户repl授权情况
show GRANTS FOR 'repl'@'%';

在这里插入图片描述
可以看到默认权限为USAGE ,该权限仅可连接数据库,无其他权限。
具体权限值可以看官网:mysql权限

给创建好的用户repl 授权

# 授权replication slave 给用户
grant replication slave on *.* to 'repl'@'%';# 刷新权限
FLUSH PRIVILEGES;

在这里插入图片描述
授权后查询权限,可以看到USAGE 变成了replication slave
replication slave 主要是用于建立复制时的用户权限。主数据库mysql 授权具有该权限的用户,从数据库mysql-2 才能通过该用户复制。

用到的命令:

# 5.7 授权
GRANT replication slave on *.* to 'repl'@'%' IDENTIFIED by 'root';# 创建用户
create user 'repl'@'%' IDENTIFIED by 'root';# 授权replication slave 给用户
grant replication slave on *.* to 'repl'@'%';# 回收授权
REVOKE replication slave on *.* from 'repl'@'%';# 删除用户
DROP user 'repl'@'%';# 查询用户repl授权情况
show GRANTS FOR 'repl'@'%';# 刷新权限
FLUSH PRIVILEGES;

授权方面可参考:mysql授权

2、授权完成后,需要配置mysql 和mysql-2 的my.cnf
docker 进入mysql配置
在这里插入图片描述
log-bin表示logbin的目录,该目录存放mysql执行的二进制文件,记录mysql除select外的操作记录,因为上面配置的repl用户可以连接msyql,也就是可以复制binlog文件,用于mysql-2 执行。
server-id 配置一个id标识
binlog-do-db 配置需要复制的是javaboy 数据库的binlog二进制文件

docker 进入mysql-2 配置
在这里插入图片描述
记得配置my.cnf 后都有执行mysql 容器的重启

docker restart mysql
docker restart mysql-2

了解mysql 主从复制的可以参考:mysql主从复制

3、授权完成,配置完my.cnf 后,还需要进入mysql-2 指定主master 为mysql

  • 首先查询出mysql 的master信息
show master status;

在这里插入图片描述

  • 进入mysql-2 容器,连接数据库,设置mysql-2 的master为上面的mysql
change master to master_host = '172.22.64.1' ,master_port=3306, master_user='repl', master_password='root',master_log_file='binlog.000472',master_log_pos=156;

master_port 为mysql的端口3306
master_user 为已经授权replication slave的repl 用户
master_log_file 为mysql 通过show master status 命令查出来的信息的file 值
master_log_pos 为mysql 通过show master status 命令查出来的信息的position 值

  • 开启slave及查询slave 状态
    在这里插入图片描述
    看到Slave_IO_Running 和 Slave_SQL_Running 为 Yes 。并且提示Wating for master to send event 。就是配置成功了。下一步可以测试看看效果。

  • 在mysql 中,新建数据库javaboy ,刷新mysql-2 看看是否同步
    在这里插入图片描述
    在这里插入图片描述
    可以看到已经同步数据库javaboy,在试着建表,插入数据看看效果
    mysql的javaboy 数据库建表user
    在这里插入图片描述
    查看mysql-2 数据库javaboy 也有user表和数据
    在这里插入图片描述
    这样就完成了mysql的主从配置

可以看看我的个人博客:
网站:https://www.fuzm.wang / https://liwangc.gitee.io
—————————————————————————

作为初学者,很多知识都没有掌握,见谅,如有错误请指出,以期进步,感谢!。后续有新的学习,继续补充上来。

相关内容

热门资讯

122.(leaflet篇)l... 听老人家说:多看美女会长寿 地图之家总目录(订阅之前建议先查看该博客) 文章末尾处提供保证可运行...
育碧GDC2018程序化大世界... 1.传统手动绘制森林的问题 采用手动绘制的方法的话,每次迭代地形都要手动再绘制森林。这...
育碧GDC2018程序化大世界... 1.传统手动绘制森林的问题 采用手动绘制的方法的话,每次迭代地形都要手动再绘制森林。这...
Vue使用pdf-lib为文件... 之前也写过两篇预览pdf的,但是没有加水印,这是链接:Vu...
PyQt5数据库开发1 4.1... 文章目录 前言 步骤/方法 1 使用windows身份登录 2 启用混合登录模式 3 允许远程连接服...
Android studio ... 解决 Android studio 出现“The emulator process for AVD ...
Linux基础命令大全(上) ♥️作者:小刘在C站 ♥️个人主页:小刘主页 ♥️每天分享云计算网络运维...
再谈解决“因为文件包含病毒或潜... 前面出了一篇博文专门来解决“因为文件包含病毒或潜在的垃圾软件”的问题,其中第二种方法有...
南京邮电大学通达学院2023c... 题目展示 一.问题描述 实验题目1 定义一个学生类,其中包括如下内容: (1)私有数据成员 ①年龄 ...
PageObject 六大原则 PageObject六大原则: 1.封装服务的方法 2.不要暴露页面的细节 3.通过r...
【Linux网络编程】01:S... Socket多进程 OVERVIEWSocket多进程1.Server2.Client3.bug&...
数据结构刷题(二十五):122... 1.122. 买卖股票的最佳时机 II思路:贪心。把利润分解为每天为单位的维度,然后收...
浏览器事件循环 事件循环 浏览器的进程模型 何为进程? 程序运行需要有它自己专属的内存空间࿰...
8个免费图片/照片压缩工具帮您... 继续查看一些最好的图像压缩工具,以提升用户体验和存储空间以及网站使用支持。 无数图像压...
计算机二级Python备考(2... 目录  一、选择题 1.在Python语言中: 2.知识点 二、基本操作题 1. j...
端电压 相电压 线电压 记得刚接触矢量控制的时候,拿到板子,就赶紧去测各种波形,结...
如何使用Python检测和识别... 车牌检测与识别技术用途广泛,可以用于道路系统、无票停车场、车辆门禁等。这项技术结合了计...
带环链表详解 目录 一、什么是环形链表 二、判断是否为环形链表 2.1 具体题目 2.2 具体思路 2.3 思路的...
【C语言进阶:刨根究底字符串函... 本节重点内容: 深入理解strcpy函数的使用学会strcpy函数的模拟实现⚡strc...
Django web开发(一)... 文章目录前端开发1.快速开发网站2.标签2.1 编码2.2 title2.3 标题2.4 div和s...