日期:2014-05-16  浏览次数:20947 次

MySQL Master Slave 数据同步,集群。


该文章为原创,作者:梁健,QQ:15141739,时间:2011年5月11日17:55:26 转载注明作者
最近学习了一下MySQL的集群,发现MySQL的集群有很多种方式,下面来介绍下学到的MySQL Master Slave配置
MySQL Master Slave 字面上理解,可以看出一个主和下属的关系,他们能做什么呢?我个人理解:当遇到高并发访问数据库的时候,可以让查询操作的SQL去访问Slave服务器,插入、修改、删除、可以在Master服务器来做,这样就可以减轻服务器的负担。
Slave 会根据Master 进行数据以二进制流的方式快速同步。
这两天在网上查了很多相关的配置,但都运行不了,最后结合多种配置加上自己的理解终于成功了,太开心了!
下面我来说说我是怎么配置的吧! 争取让你按我的配置一次成功!我尽量详细。

我的机器是XP系统,安装的MySQL5.1.32-community-log,我的虚拟机里是Ubuntu10.10,MySQL5.1.49-1ubuntu8.1-log

Master :192.169.105.203 (XP系统)
Slave: 192.168.2.133(Linux系统)

1、XP系统中操作:
找到MySQL的安装目录,我的是:
D:\Program Files\MySQL\MySQL Server 5.1
修改D:\Program Files\MySQL\MySQL Server 5.1\my.ini文件,找到[mysqld] 在下面写:

server-id?????????????? = 1
log_bin???????????????? = d:/mysql/mysql-test-bin.log
expire_logs_days??????? = 10
max_binlog_size???????? = 100M
binlog_format?????????? =mixed
binlog_do_db = test_db

注意:d:/mysql/mysql-test-bin.log 这个目录需要自己建立,log_bin的意思是 将数据库的内容以二进制方式写到文件里(Slave会根据这个文件进行同步数据);
通常Master服务器都配置 server-id=1 这个数字最好和IP最后一组数字一致,但要小于32,这里配置为1。
binlog_do_db准许Slave同步的数据库,我这里要让写的是test_db用于测试的数据库(Slave里也要有相同的数据库和表结构,否则无法同步),如果有多个数据库可以多写几个binlog_do_db=**数据库名。
重启MySQL服务,net stop mysql 然后net start mysql

连接数据库 mysql -uroot -p123456

mysql> show master status;
+-----------------------+----------+--------------+------------------+
| File????????????????? | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+-----------------------+----------+--------------+------------------+
| mysql-test-bin.000001 |????? 106 |????????????? |????????????????? |
+-----------------------+----------+--------------+------------------+
1 row in set (0.00 sec)
??????????
这个就是生成的二进制文件的信息,Slave会根据这个同步数据。

设定 Replication Slave 权限
我们必须要在 Master Server 上做设定,让 Slave 具有可以从 Master Server 上 Copy 数据的权限(正式的说法为 Replication Slave Priviledges)
mysql> GRANT REPLICATION SLAVE ON *.* TO 'test_dbuser'@'192.168.2.133' IDENTIFIED BY '1234';
语句中的SLAVE是权限名,*.*是可访问任何数据库,test_dbuser是用户名,192.168.2.133是准许这个IP访问,1234是密码。
mysql> FLUSH PRIVILEGES; (使之生效)

--------------------------
2、下面是在Ubuntu下的操作,配置Slave:
MySQL的安装我就不多说了,apt-get install mysql ……
先说明一下我的MySQL的路径:
/etc/init.d/mysql 下是启动和停止服务
/var/log/mysql/ 记录日志,相当于我在前面XP系统里建立的d:/mysql/mysql-test-bin.log位置
/var/lib/mysql/ 存放数据库。MySQL配置文件:/etc/mysql/my.cnf ,其中指定了数据文件存放路径,
datadir = /var/lib/mysql
如果你创建了一个名为 test 的数据库,那么这个数据库的数据会存放到 /var/lib/mysql/test 目录下。

Slave Server配置:
修改MySQL配置文件:/etc/mysql/my.cnf
找到[mysqld] 在下面加入:
server-id?????????????? = 2
replicate-do-db??=test_db
log_bin???????????????? =/var/log/mysql/mysql-bin.log
relay_log?????????????? =/var/log/mysql/mysql-relay-bin.log
master-connect-retry?=1
expire_logs_days??????? = 10
max_binlog_size???????? = 100M
#binlog_do_db?????????? = test
#binlog_ignore_db?????? = include_database_name
binlog_format?????????? = mixed

下面说明一下:
server-id=2就是个编号,如果有多个Slave服务器,就依次向后排,3、5、6……
replicate-do-db=test_db是配置我要到master服务器同步的数据库,我这里配置的是test_db数据库。
master-connect-retry=1 是1秒钟同步一次,这个数值可根据不同需要配置。

配置好后,重启MySQL服务。
进入Slave Server 的MySQL