您的位置:首页 > 数据库 > MySQL

MySQL Master Slave 数据同步,集群。

2011-06-10 15:58 609 查看
该文章为原创,作者:梁健,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:
mysql -uroot -pliangjian
查看一下master服务器状态:
mysql> show master status/G;
*************************** 1. row ***************************
File: mysql-bin.000003
Position: 234
Binlog_Do_DB:
Binlog_Ignore_DB:
1 row in set (0.00 sec)

ERROR:
No query specified

启动
mysql>start slave;
然后查看一下状态:
mysql> show slave status/G;
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 192.168.105.203
Master_User: test_dbuser
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: mysql-test-bin.000004
Read_Master_Log_Pos: 8272
Relay_Log_File: mysql-relay-bin.000004
Relay_Log_Pos: 1399
Relay_Master_Log_File: mysql-test-bin.000004
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Replicate_Do_DB: test_db,admob
Replicate_Ignore_DB:
Replicate_Do_Table:
Replicate_Ignore_Table:
Replicate_Wild_Do_Table:
Replicate_Wild_Ignore_Table:
Last_Errno: 0
Last_Error:
Skip_Counter: 0
Exec_Master_Log_Pos: 8272
Relay_Log_Space: 8727
Until_Condition: None
Until_Log_File:
Until_Log_Pos: 0
Master_SSL_Allowed: No
Master_SSL_CA_File:
Master_SSL_CA_Path:
Master_SSL_Cert:
Master_SSL_Cipher:
Master_SSL_Key:
Seconds_Behind_Master: 0
Master_SSL_Verify_Server_Cert: No
Last_IO_Errno: 0
Last_IO_Error:
Last_SQL_Errno: 0
Last_SQL_Error:
1 row in set (0.00 sec)

这里主要看的是:
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
如果是NO,可能是连接问题导致。

下面手动执行一下同步:
同步前需要先STOP Slave一下。再执行:

mysql> change master to master_host='192.168.105.203',master_user='test_dbuser',master_password='1234', master_log_file='mysql-test-bin.000001',master_log_pos=106;

这里的 master_log_file='mysql-test-bin.000001',master_log_pos=106; 000001和106这两个数值如果不知道输入多少,可以先:
mysql> show master status/G; 看一下。
配置好后在 START Slave一下。这时候你可以再 mysql> show slave status/G; 看看情况。
用show processlist; 看一下连接情况。

我这里test_db数据库里有一个表t01,里面没有数据。Ubuntu里的Slave服务已经配置完毕。不要关机哦!
切忌 Slave Server和Master Server 里的test_db库的表结构都要一样。否则数据没法同步。
---------------
3、回到XP系统
登入Mysql在test_db数据库的t01表里插入一条数据:
mysql> insert into t01 (id,name,bz) values (3,'liangjian3','heihei3');
我这里已经有了几条:
mysql> select * from t01;
+------+------------+---------+
| id | name | bz |
+------+------------+---------+
| 1 | liangjian | heihei |
| 2 | liangjian2 | heihei2 |
| 3 | liangjian3 | heihei3 |
+------+------------+---------+
3 rows in set (0.00 sec)
这个时候在去Ubuntu里看test_db里的t01表是是不是已经把数据同步过去了。

---------------------------------
以上这些操作 你可能会遇到如下问题:
在XP里执行完:
mysql> GRANT REPLICATION SLAVE ON *.* TO 'test_dbuser'@'192.168.2.133' IDENTIFIED BY '1234';
在Ubuntu里:
root@MyUbnutu:/var/lib/mysql# mysql -h 192.168.2.133 -utest_dbuser -p1234
会有登陆不上的情况,给出如下提示:
ERROR 1045 (28000): Access denied for user 'test_dbuser'@'liangjian' (using password: YES)
这个时候你可以在XP里:
GRANT REPLICATION SLAVE ON *.* TO 'test_dbuser'@'liangjian' IDENTIFIED BY '1234';
或者:
GRANT REPLICATION SLAVE ON *.* TO 'test_dbuser'@'%' IDENTIFIED BY '1234';(用%号表示准许所以外部访问)
我不知道为何用IP不好使,这个问题也困扰了我好长时间,最后用Ubuntu里的用户名连上的。这一步很关键。

在执行:

mysql> change master to master_host='192.168.105.203',master_user='test_dbuser',master_password='1234', master_log_file='mysql-test-bin.000001',master_log_pos=106;
最后先查看一下master的状态,如果不对,则需要去Mysql安装目录下删除master.info文件,和log下的日志文件,然后重启Mysql服务,否则master始终是第一次配置的那个。

---------------------------------

参考以下文章,结合自己的需求终于配置成功了:

http://www.cnblogs.com/xiazh/archive/2011/04/22/1971182.html

http://hi.baidu.com/ismayday/blog/item/5c52aec3431d1751b319a8f1.html

第一次写教程,没网上查的资料写的好,但自己想要提高总要走出这一步,加油吧!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: