mysql的主从复制

mysql的主从复制

1 mysql主从复制概述
复制解决的基本问题是让一台服务器的数据和另外的服务器保持同步。
一台主服务器可以连接多台从服务器,并且从服务器也可以反过来作主服务器。
主服务器和从服务器可以位于不同的网络拓扑中,还能对整台服务器、特定的数据库,甚至特定的表进行复制。
主从服务器的版本必须一致。
主服务器版本可以低一些的,从服务器版本要高一些。
2 复制解决的问题
MySQL复制技术有以下一些特点:
(1) 数据分布 (Data distribution )。
(2) 负载平衡(load balancing)。
(3) 备份(Backups)
(4) 高可用性和故障转移 High availability and failover 。
3 复制如何工作
如图所示:在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
整体上来说,复制有 3 个步骤:
(1)master 将改变记录到二进制日志(binary log)中(这些记录叫做二进制日志事件,binary logevents);
(2)slave 将 master 的 binary log events 拷贝到它的中继日志(relay log);
(3)slave 重做中继日志中的事件,修改 salve 上的数据。在这里插入图片描述
在这里插入图片描述
mysql 从复制中:
第一步:master 记录二进制日志。在每个事务更新数据完成之前,master 在二日志记录这些改变。
MySQL 将事务写入二进制日志,即使事务中的语句都是交叉执行的。在事件写入二进制日志完成后,master 通知存储引擎提交事务。
第二步:slave将master的binary log拷贝到它自己的中继日志。首先,slave开始一个工作线程I/O 线程。I/O 线程在master上打开一个普通的连接,然后开始binlog dump process。Binlog
dump process 从master的二进制日志中读取事件,如果已经执行完master产生的所有文件,它会睡眠并等待master产生新的事件。I/O 线程将这些事件写入中继日志。
第三步:SQL slave thread(SQL 线程)处理该过程的最后一步。SQL线程从中继日志读取事件,并重新执行其中的事件而更新 slave 的数据,使其与 master 中的数据一致。
模式: C/S 模式
\端口:3306
4 实战mysql主从配备
1.下载mysql的repo源的命令如下:

wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm 

2.安装mysql-community-release-el7-5.noarch.rpm包的命令如下:

rpm -ivh mysql-community-release-el7-5.noarch.rpm

3.安装mysql的服务命令如下:

yum install mysql-server -y

4.启动mysql的服务命令如下:

service mysqld start

5.进入mysql的界面的命令如下:

mysql

7.设置mysql密码的命令如下:

set password for root@localhost = password('123456');

8.退出,并重新进行MySQL界面并且修改root远程访问权限的命令如下:

exit
mysql -uroot -p
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY'123456';
FLUSH PRIVILEGES;

9.创建数据库和表结构的命令如下:

CREATE DATABASE test;     -- 创建test数据库
USE test;     -- 使用test数据库
-- 创建表
CREATE TABLE test1 (id int);  -- 字段名 数据类型
SHOW TABLES;   -- 查看表

在128上创建数据库以及表结构如图所示:在这里插入图片描述
10.停止mysql主服务的命令如下:

service mysqld stop

如图所示:说明停止成功!在这里插入图片描述
11.配置 mysql 主要同步的数据库名字并开启对应的二进制日志的命令如下:

vim /etc/my.cnf #my.cnf是mysql主配置文件

进入如图所示的界面:在这里插入图片描述
修改的代码如下:

#开启binlog日志
log_bin=mysqllog
#唯一服务标识
server_id=1
binlog-do-db=test

修改之后,如图所示:在这里插入图片描述
12.重新启动mysql的命令如下:

service mysqld restart

如图所示:说明启动成功!在这里插入图片描述
13.授权的命令如下:

CREATE USER slave;  #创建slave
#授权
GRANT replication slave ON *.* TO 'slave'@'192.168.171.129' identified by '123456';
#刷新
FLUSH PRIVILEGES;

如图所示:说明授权成功!在这里插入图片描述
14.在从节点测试登录:

mysql -h 192.168.157.128 -u slave -p123456

如图所示,说明登录成功!在这里插入图片描述
15.复制前保证主从两个数据库数据一致:
把主的原始数据传给从的命令如下:

mysqldump -u root -p -A > all1.sql

如图所示:导出所有数据库成功!在这里插入图片描述
16.数据库复制到129上。命令如下:

scp all1.sql 192.168.157.129:/root

如图所示:说明要输入129的密码。在这里插入图片描述
在129查看如图所示:说明复制成功!在这里插入图片描述
17.导入数据库,和主服务器保持一致的命令如下:

mysql -u root -p < all1.sql

如图所示:说明导入成功!在这里插入图片描述
18.修改从服务器配置文件的命令如下:

vim /etc/my.cnf

进入如图所示的界面:在这里插入图片描述
修改的代码如下:

server-id=2 #从服务器 ID 号,不要和主 ID 相同 ,如果设置多个从服务器,每个从服务器必须有一个
唯一的 server-id 值,必须与主服务器的以及其它从服务器的不相同。可以认为 server-id 值类似于 IP 地
址:这些 ID 值能唯一识别复制服务器群集中的每个服务器实例。
relay_log-index=relay_log.index
relay_log=relay_log

修改之后,如图所示:在这里插入图片描述
19.重启MySQL的服务命令如下:

service mysqld restart

如图所示:说明重启成功!在这里插入图片描述
在129上创建主库连接,master_log_file和master_log_pos的值需要show MASTER status查询的命令如下:

CHANGE MASTER TO 
master_host='192.168.157.128',
master_port=3306,
master_user='slave',
master_password='123456',
master_log_file='mysqllog.000003',
master_log_pos=570;

如图所示:在这里插入图片描述
20.测试:
主服务器上查看的命令如下:

show master status;

如图所示:说明主服务器是正常状态!在这里插入图片描述
从服务器上查看的命令如下:

show slave status \G

如图所示:说明正常!在这里插入图片描述
21.测试:数据同步
21.1 在128写数据,如图所示:在这里插入图片描述
21.2 在129上读数据,如图所示:在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

学无止路

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值