Mysql—主从复制
创始人
2024-05-30 09:44:48
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
—————————————————————————

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

相关内容

热门资讯

天虹股份6月13日获融资买入1... 6月13日,天虹股份跌2.05%,成交额1.07亿元。两融数据显示,当日天虹股份获融资买入额1699...
达实智能6月13日获融资买入1... 6月13日,达实智能跌2.13%,成交额1.20亿元。两融数据显示,当日达实智能获融资买入额1075...
红塔证券6月13日获融资买入2... 6月13日,红塔证券跌1.81%,成交额2.60亿元。两融数据显示,当日红塔证券获融资买入额2818...
誉衡药业6月13日获融资买入4... 6月13日,誉衡药业跌3.24%,成交额5.77亿元。两融数据显示,当日誉衡药业获融资买入额4432...
永冠新材6月13日获融资买入3... 6月13日,永冠新材跌7.91%,成交额2.71亿元。两融数据显示,当日永冠新材获融资买入额3273...
“静宁苹果”库存销售助农增收成... “三链协同”激活助农增收强引擎“静宁苹果”库存销售助农增收成效显著每日甘肃网6月16日讯 据平凉日报...
摩恩电气6月13日获融资买入5... 6月13日,摩恩电气跌1.93%,成交额4520.54万元。两融数据显示,当日摩恩电气获融资买入额5...
关于同意中信建投证券股份有限公... 上证公告(基金)【2025】865号    为促进汇添富上证科创板新材料交易型开放式指数证券投资基金...
巨星科技6月13日获融资买入2... 6月13日,巨星科技跌1.78%,成交额3.72亿元。两融数据显示,当日巨星科技获融资买入额2439...
康龙化成6月13日获融资买入1... 6月13日,康龙化成跌2.47%,成交额13.17亿元。两融数据显示,当日康龙化成获融资买入额1.2...
天味食品6月13日获融资买入3... 6月13日,天味食品跌3.14%,成交额7802.10万元。两融数据显示,当日天味食品获融资买入额3...
鸿远电子6月13日获融资买入2... 6月13日,鸿远电子跌0.44%,成交额2.33亿元。两融数据显示,当日鸿远电子获融资买入额2269...
泾川:项目建设“加速跑” 泾川:项目建设“加速跑”  □平凉日报记者 赵珍珍 赵啸林  今年以来,泾川县牢固树立项目为王理念,...
易成新能6月13日获融资买入4... 6月13日,易成新能跌0.52%,成交额5226.37万元。两融数据显示,当日易成新能获融资买入额4...
6月13日生物医药ETF(15... 6月13日,生物医药ETF(159859)跌2.09%,成交额8948.46万元。当日份额减少144...
6月13日港股创新药ETF(1... 6月13日,港股创新药ETF(159567)跌2.82%,成交额36.13亿元。当日份额增加2.07...
6月13日信创ETF(5625... 6月13日,信创ETF(562570)跌1.71%,成交额1.68亿元。当日份额减少6300.00万...
6月13日新能源龙头ETF(1... 6月13日,新能源龙头ETF(159752)跌0.90%,成交额276.72万元。当日份额减少200...
6月13日食品ETF(1598... 6月13日,食品ETF(159862)跌2.23%,成交额234.90万元。当日份额减少300.00...
6月13日沪深300ETF基金... 6月13日,沪深300ETF基金(159330)跌0.68%,成交额2168.46万元。当日份额减少...