mysql主从复制

复制的基本原理

slave会从master读取binlog来进行数据同步

三步骤+原理图

在这里插入图片描述

MySQL复制过程分成三步:

  1. master将改变记录到二进制日志(binary log) 。这些记录过程叫做二进制日志事件,binary log events;
  2. slave将master的binary log events拷贝到它的中继日志(relay log) ;
  3. slave重做中继日志中的事件,将改变应用到自己的数据库中。MySQL复制是异步的且串行化的;

复制的基本原则

  1. 每个slave只有一个master;
  2. 每个slave只能有一个唯一的服务器ID;
  3. 每个master可以有多个slave;

复制的最大问题

一主一从常见配置

mysql版本一致且后台以服务运行

验证网络是否互通

# 查看ip地址,192.168.75.100(主)192.168.75.101(从)
ifconfig

在这里插入图片描述

# 验证
ping 192.168.75.101
Ctrl+C退出

在这里插入图片描述

主机修改my.cnf配置文件(linux)

主从都配置在[mysqld]结点下,都是小写;

# 主服务器唯一ID【必须】
server-id=1
# 允许任何端口访问【必须】
bind-address = 0.0.0.0
# 启用二进制日志【必须】
log-bin=/mysqlbin
# 启用错误日志【可选】
log-err=/mysqlerr
# 根目录【可选】
basedir=/
# 临时目录【可选】
tmpdir=/
# 数据目录【可选】
datadir=/
# 主机,读写都可以
read-only=0
# 设置不要复制的数据库【可选】
db-ignore-binlog=数据库名
# 设置需要复制的数据库【可选】
binlog-do-db=数据库名
# 重启服务【必须】
systemctl start mysqld

从机修改my.cnf配置文件(linux)

# 主服务器唯一ID【必须】
server_id=2
# 允许任何端口访问【必须】
bind-address = 0.0.0.0
# 启用二进制日志【可选】
log-bin=/mysqlbin
# 重启服务【必须】
systemctl start mysqld
# 查看server_id
show variables like '%server_id%';

主机从机都关闭防火墙

关闭虚拟机linux|防火墙:service iptables stop 或 systemctl disable firewalld;没安装就算了!

主机上建立帐户并授权slave

#GRANT REPLICATION SLAVE ON *.* TO '用户名'@'从机器数据库IP' IDENTIFIED BY '密码';
GRANT REPLICATION SLAVE ON *.* TO 'GodHLinux'@'192.168.75.101' IDENTIFIED BY 'GodH233593@';
#刷新
FLUSH PRIVILEGES;
#查看mysql用户表
SELECT `user`,`host` FROM `user`;

查询master的状态

#查看主机状态
SHOW MASTER STATUS;

在这里插入图片描述

记录下File和Position的值
mysql-bin.000042,879
执行完此步骤后不要再操作主服务器MYSQL,防止主服务器状态值变化;

在Linux从机上配置需要复制的主机

#停止服务复制(3021错误)
STOP SLAVE;
#CHANGE MASTER TO MASTER_HOST='主机IP',MASTER_USER='zhangsan',MASTER_PASSWORD='123456',MASTER_LOG_FILE='File名字',MASTER_LOG_POS=Position数字;
CHANGE MASTER TO MASTER_HOST='192.168.75.100',MASTER_USER='GodHLinux',MASTER_PASSWORD='GodH233593@',MASTER_LOG_FILE='mysql-bin.000042',MASTER_LOG_POS=879;
#启动从服务器复制功能
START SLAVE;
#查看是否配置成功
SHOW SLAVE STATUS;

在这里插入图片描述

两个参数都是Yes,则说明主从配置成功!
Slave_IO_Running:Yes;;
Slave_SQL_Running:Yes;

测试

#主
create database mydb58;
use mydb58;
insert into dog values(1,'ww1');
select * from dog;

在这里插入图片描述

#从
use mydb58;
select * from dog;

在这里插入图片描述

如何停止从服务复制功能

#停止服务复制(3021错误)
STOP SLAVE;
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL主从复制MySQL内建的复制功能,用于构建基于MySQL的大规模、高性能应用。它的主要目的是实现高性能、高可用性、可扩展性、灾难恢复、备份以及数据仓库等功能。主从复制的常见用途包括以下几种: 1. 数据备份和灾难恢复:通过将主服务器上的数据复制到一个或多个从服务器上,可以实现数据的备份和灾难恢复。当主服务器发生故障时,可以快速切换到从服务器来保证系统的可用性。 2. 负载均衡:通过将读操作分发到多个从服务器上,可以减轻主服务器的负载,提高系统的性能和可扩展性。 3. 数据分析和报表生成:通过将主服务器上的数据复制到一个或多个从服务器上,可以在从服务器上进行数据分析和报表生成,而不会影响主服务器的性能。 4. 数据分发:通过将主服务器上的数据复制到多个从服务器上,可以将数据分发到不同的地理位置或不同的应用程序中,以满足不同的需求。 在MySQL主从复制中,可以使用一些工具来简化配置和管理,比如MySQL-Proxy。MySQL-Proxy是MySQL官方开源项目,通过其自带的lua脚本进行SQL判断,但MySQL官方并不建议将MySQL-Proxy用于生产环境。此外,还需要在主服务器和从服务器上进行一些配置,如设置server-id、开启二进制日志、允许从服务器更新二进制日志等。还需要为从服务器授权复制权限,并通过show master status命令查看主服务器的状态信息。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* [MySQL主从复制详细介绍](https://blog.csdn.net/qq_44590469/article/details/126340217)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [MySQL主从复制](https://blog.csdn.net/m0_62473957/article/details/124140928)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值