MySQL AB
博客专区 > lee_ypp 的博客 > 博客详情
MySQL AB
lee_ypp 发表于3年前
MySQL AB
  • 发表于 3年前
  • 阅读 874
  • 收藏 63
  • 点赞 2
  • 评论 3

腾讯云 技术升级10大核心产品年终让利>>>   

摘要: MySQL AB复制

MySQL 支持单向、异步复制,复制过程中一个服务器充当主服务器,而一个或多个其它服务器充当从服务器。主服务器将更新写入二进制日志文件,并维护文件的一个索引以跟踪日志循环。这些日志可以记录发送到从服务器的更新。当一个从服务器连接主服务器时,它通知主服务器从服务器在日志中读取的最后一次成功更新的位置。从服务器接收从那时起发生的任何更新,然后封锁并等待主服务器通知新的更新。

请注意当你进行复制时,所有对复制中的表的更新必须在主服务器上进行。否则,你必须要小心,以避免用户对主服务器上的表进行的更新与对从服务器上的表所进行的更新之间的冲突。

单向复制有利于健壮性、速度和系统管理:

1. 主服务器/从服务器设置增加了健壮性。主服务器出现问题时,你可以切换到从服务器作为备份

2. 通过在主服务器和从服务器之间切分处理客户查询的负荷,可以得到更好的客户响应时间。SELECT 查询可以发送到从服务器以降低主服务器的查询处理负荷。但修改数据的语句仍然应发送到主服务器,以便主服务器和从服务器保持同步。如果非更新查询为主,该负载均衡策略很有效,但一般是更新查询。

3. 使用复制的另一个好处是可以使用一个从服务器执行备份,而不会干扰主服务器。在备份过程中主服务器可以继续处理更新。

MySQL 提供了数据库的同步功能,这对我们实现数据库的冗灾、备份、恢复、负载均衡等都是有极大帮助的。

实验环境:
RHEL 6.5 iptables and linux stop
master    192.168.0.11

slave1    192.168.0.12

slave2    192.168.0.13

mysql 的 AB 复制

注: mysql 数据库的版本,两个数据库版本要相同,或者 slave 比 master 版本高!

在 master slave 上安装 mysql 软件,mysql 软件可以在 http://www.mysql.com上下载,源码或是 rpm 包都可以,由于 RHEL6 自带mysql 软件包,直接 yum 安装。

# yum install mysql mysql-server -y

master server 配置

1)配置 /etc/my.cnf 配置文件

在[mysqld]下添加一下参数

log-bin=mysql-bin #启动二进制日志系统

binlog-do-db=westos #二进制需要同步的数据库名,如果需要同步多个库,例如要再同步 test库,再添加一行“binlog-do-db=test”,以此类推

server-id=1    #必须为 1 到 232–1 之间的一个正整数值

binlog-ignore-db=mysql #禁止同步 mysql 数据库

2 ) 启动 master

# service mysqld start

3)创建同步帐户,并给予权限

mysql> GRANT REPLICATION SLAVE,RELOAD,SUPER ON *.* TO westos@'192.168.0.12' IDENTIFIED BY 'westos';

mysql> Flush privileges;

Query OK, 0 rows affected (0.00 sec)

调试:

在 master 上用下面的命令查看

mysql> show master status;
+---------------------+-----------+----------------+--------------------+
| File    | Position     | Binlog_Do_DB     | Binlog_Ignore_DB |
+---------------------+-----------+----------------+--------------------+
| mysql-bin.000001| 106    | westos    | mysql    |
+---------------------+-----------+----------------+--------------------+
记录 File 和 Position 的值,下面会用到。    

slave1server 配置

1 )配置 /etc/ my.cnf 文件

在[mysqld]下添加一下参数

server-id=2

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

2 ) 启动 slave

# service mysqld start

查看是否授权成功

#mysql -uwestos -pwestos -h 192.168.0.11                     ##提示正确则可以进行一下操作。

3) 在 slave1 上执行一下命令

mysql> change master to master_host='192.168.0.11', master_user='westos',master_password='westos', master_log_file='mysql-bin.000001', master_log_pos=106;

Query OK, 0 rows affected (0.28 sec)

mysql> slave start;

Query OK, 0 rows affected (0.00 sec)

mysql> show slave status\G;
.....
Slave_IO_Running: Yes

Slave_SQL_Running: Yes
.....
如果都是 yes,表示从库的 I/O,Slave_SQL 线程都正确开启.表明数据库正在同步你也可以通过在 master server 上的 test 库中添加数据,看 slave server 是否同步,更多详细信息以及参数设置,请参考 MySQL Manual 手册.

注意:在同步之前确保 master 与 slave 上的数据一致性。

测试:在master上

mysql> create database westos;

Query OK, 1 row affected (0.00 sec)

mysql> use westos;

Database changed

mysql> create table linux ( username varchar(20) not null, password varchar(50) not null  );
Query OK, 0 rows affected (0.18 sec)

mysql> desc linux;
+----------+-------------+------+-----+---------+-------+
| Field    | Type        | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| username | varchar(20) | NO   |     | NULL    |       |
| password | varchar(50) | NO   |     | NULL    |       |
+----------+-------------+------+-----+---------+-------+
2 rows in set (0.00 sec)

mysql> insert into linux values ('user1','123');
Query OK, 1 row affected (0.00 sec)
mysql> insert into linux values ('user2','password(123)');
Query OK, 1 row affected (0.00 sec)
mysql> show tables;
+------------------+
| Tables_in_westos |
+------------------+
| linux            |
+------------------+
1 row in set (0.00 sec)
mysql> select * from linux;
+----------+---------------+
| username | password      |
+----------+---------------+
| user1    | 123           |
| user2    | password(123) |
+----------+---------------+

这是在slave1主机上查看是否同步。

mysql> select * from linux;
+----------+---------------+
| username | password      |
+----------+---------------+
| user1    | 123           |
| user2    | password(123) |
+----------+---------------+

相关文件作用:
1. mysql-bin.index:服务器一旦开启二进制日志,会产生一个与二日志文件同名,但是以.index 结尾的文件。它用于跟踪磁盘上存在哪些二进制日志文件。MySQL 用它来定位二进制日志文件。

2. mysqld-relay-bin.index:该文件的功能与 mysql-bin.index 类似,但是它是针对中继日志,而不是二进制日志。

3. master.info:保存 master 的相关信息。不要删除它,否则,slave 重启后不能连接 master。

4. relay-log.info:包含 slave 中当前二进制日志和中继日志的信息。

如果写操作较少,而读操作很多时,可以采取这种结构。你可以将读操作分布到其它的 slave,从而减小master 的压力。但是,当 slave 增加到一定数量时,slave 对 master 的负载以及网络带宽都会成为一个严重的问题。这种结构虽然简单,但是,它却非常灵活,足够满足大多数应用需求。

当设置 log_slave_updates 时,你可以让 slave 扮演其它 slave 的 master。此时,slave 把 SQL 线程执行的事件写进行自己的二进制日志(binary log),然后,其它的 slave 可以获取这些事件并执行它,从而有效缓解master 的压力。如下:

流水线结构

添加一个 slave2:

1. 由于 master 上已经有数据,而新加的 slave2 没有,必须在配置复制前同步数据。

在 master 上执行一下命令

mysqldump westos > bak

scp bak 192.168.0.13:

2. 在 slave1 上加入以下设置:
# vi /etc/my.cnf

....

server-id=2

log-bin=mysql-bin

binlog-ignore-db=mysql

binlog-do-db=westos

log-slave-updates

....

# /etc/init.d/mysqld restart

新建westos数据库,并将备份的数据导入到westos数据库中

#mysqladmin create westos

#mysql westos  < bak

3. 在 slave1 上创建同步帐户,并给予权限
mysql> GRANT REPLICATION SLAVE,RELOAD,SUPER ON *.* TO westos@'192.168.0.13'IDENTIFIED BY 'westos';
mysql>Flush privileges;
mysql> show master status;
+------------------+----------+--------------+------------------+
| File    | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000001 |217 | westos| mysql|
+------------------+----------+--------------+------------------+

1 row in set (0.00 sec)

4. 在 slave2 上添加配置:

# vi /etc/my.cnf

server-id=3

# /etc/init.d/mysqld start

5. 在 slave2 上执行一下命令

查看是否授权成功

#mysql -uwestos -pwestos -h 192.168.0.12                     ##提示正确则可以进行一下操作。
mysql> change master to master_host='192.168.0.12', master_user='westos',master_password='westos', master_log_file='mysql-bin.000001', master_log_pos=217;

mysql> slave start;

mysql> show slave status\G;

.....

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

.....


测试方法与第一种相似,此处不再累赘。

            __leeypp@gmail.com



















共有 人打赏支持
粉丝 65
博文 43
码字总数 58692
评论 (3)
都市网达
问一个问题,如果主服务器挂了之后,怎么恢复同步数据。
lee_ypp

引用来自“都市网达”的评论

问一个问题,如果主服务器挂了之后,怎么恢复同步数据。

可以做一个ha集群,做负载均衡的话应该没问题.还有mysql cluster集群也可以实现。 !@都市网达
老年基德
在什么情况下使用mysqlAB复制这种方案,什么情况下使用mysql集群这种这种解决方案,两种方案各有什么优缺点?
×
lee_ypp
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: