文档章节

MySQL AB

lee_ypp
 lee_ypp
发布于 2014/07/09 20:40
字数 1826
阅读 882
收藏 63

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



















© 著作权归作者所有

共有 人打赏支持
上一篇: MySQL常见错误
下一篇: MySQL Cluster
lee_ypp
粉丝 64
博文 45
码字总数 58692
作品 0
程序员
私信 提问
加载中

评论(3)

老年基德
老年基德
在什么情况下使用mysqlAB复制这种方案,什么情况下使用mysql集群这种这种解决方案,两种方案各有什么优缺点?
lee_ypp
lee_ypp

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

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

可以做一个ha集群,做负载均衡的话应该没问题.还有mysql cluster集群也可以实现。 !@都市网达
都市网达
都市网达
问一个问题,如果主服务器挂了之后,怎么恢复同步数据。
MySQL与MariaDB概述 (二)

第一部分 学习MySQL和MariaDB的前途 MySQL 和 MariaDB 都兼容 SQL,它是一种有大约 30 年历史的编程语言.学习 MySQL 或 MariaDB,对你的数据库开发和管理生涯有百利而无一害。 第二部分 Mari...

博为峰教研组
2016/12/16
95
0
MySQL与MariaDB概述 (一)

MySQL 是当今最流行的开源数据库,高效且稳定,备受公众网站的青睐。 1995 年,MySQL 由 Michael“Monty”Widenius 和 David Axmark 创造,并使用 GNU 通用 公共授权。2008 年 1 月, 它被 ...

博为峰教研组
2016/12/16
157
0
探索MySQL高可用架构之MHA(4)

探索MySQL高可用架构之MHA(4) -----构建mysql高可用系列(共9篇) 上一篇文章介绍了本次架构中的Mysql源码安装。本篇文章主要介绍本次架构中的ABBB复制。 首先我们先介绍什么是MySql AB复制???...

顺境其生
2015/07/22
0
0
设定mysql的默认字符集

mysql> show global variables like '%charac%'; --查看当前mysql采用的字符集 mysql>show global variables like '%server%'; --查看当前服务端全局字符集 +----------------------+------......

笔下生辉
2017/03/31
0
0
Apache基础教程

Apache是世界使用排名第一的Web服务器软件。它可以运行在几乎所有广泛使用的计算机平台上,由于其跨平台和安全性被广泛使用,是最流行的Web服务器端软件之一。它快速、可靠并且可通过简单的A...

harries
2016/03/23
29
0

没有更多内容

加载失败,请刷新页面

加载更多

CentOS 安装PHP5和PHP7

安装PHP5 下载解压二进制包 [root@test-a src]# cd /usr/local/src/[root@test-a src]# wget http://cn2.php.net/distributions/php-5.6.32.tar.bz2[root@test-a src]# tar jxvf php-5.6......

野雪球
今天
4
0
windows上类似dnsmasq的软件Dual DHCP DNS Server

官网地址:http://dhcp-dns-server.sourceforge.net/官网定向的下载地址:https://sourceforge.net/projects/dhcp-dns-server/files/ 设置参考地址:http://blog.51cto.com/zhukeqiang/18264......

xueyuse0012
今天
3
0
LinkedHashMap源码解析

前言 HashMap中的元素时无序的,也就是说遍历HashMap的时候,顺序和放入的顺序是不一样的。 如果需要有序的Map,就可以采用LinkedHashMap. LinkedHashMap通过维护一个包含所有元素的双向链表,...

grace_233
今天
3
0
初识flask

文档 0.10.1版本 http://www.pythondoc.com/flask/index.html 1.0.2版本 https://dormousehole.readthedocs.io/en/latest/ 安装flask $ pip3 install flaskCollecting flask Downloading......

yimingkeji
昨天
5
0
Akka系统《sixteen》译

Actor是一个封装状态(state)和行为(behavior)的对象,它们只通过交换消息通信(放入收件人邮箱的邮件)。从某种意义上说,Actor是最严格的面向对象编程形式,但它更适合将他们视为人:在与Act...

woshixin
昨天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部