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

mysql主从配置

【测试环境如下】

master端(ip为192.168.0.5):virtualbox下的ubuntu 10.0.4,mysql为5.5版本。

slave端(ip为192.168.0.3):xp系统,mysql为5.5版本。

?

【过程】

1.保证master端的防火墙对slave端ip开放3306端口(这一步可以最后做的):

#iptables -A INPUT -p tcp --dport 3306 -s 192.168.0.3 -j ACCEPT

在xp下,用mysql -u[用户名] -p[密码] -h[ip地址] ,可以试一下能不能连接。

?

2.修改master的$MYSQL_HOME$/etc/my.cnf 文件,添加内容:

server-id=1
log-bin=mysql-bin
?

3.进入mysql,给slave授予权限

mysql > GRANT REPLICATION SLAVE ON *.* TO 'slave001'@'192.168.0.3' IDENTIFIED BY '123456';

这样,slave端即可用slave001,123456来配置访问master端。

?

4.master端设置读锁,读取日志文件名和偏移量;备份要同步的数据库(此处备份test);然后解锁

mysql > flush tables with read lock;

mysql > show master status;? ? ? ?? //得到File为mysql-bin.000003, Position为1778

+------------------+----------+--------------+------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000003 |     1778 |              |                  |
+------------------+----------+--------------+------------------+
?

然后用mysqldump工具导出数据文件,

mysqldump -uroot -p test > test.sql

mysql > unlock tables;

?

5.修改slave的my.ini文件

server-id=2

?

6.进入slave端的mysql

导入刚才master端备份的test.sql

mysql > source d:\test.sql????? // 这里假定刚才master端导出的test.sql已经放置到了slave端的d:\test.sql

?

7.对slave端相应设置,进入slave端的mysql,

mysql >? change master to master_host='192.168.0.5';
mysql >? change master to master_user='slave001';
mysql >? change master to master_password='123456';
mysql >? change master to master_port=3306;
mysql >? change master to master_log_file='mysql-bin.000003';
mysql >? change master to master_log_pos=1778;

?

8.看一下slave端的状态是否正常。

mysql >? show slave status/G;

*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.0.5
                  Master_User: slave001
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000003
?

9.测试

?进入master命令行,执行一条建表语句
?【mysql>】use test;
?【mysql>】create table cxl(`id` int(11) primary key);
?进入slave查看test库中是否有cxl表
?【mysql>】use test;
?【mysql>】show tables;
?若列表中有cxl表,说明配置主从数据库成功。

?

ps:

上面的从机是windows xp环境,slave端配置貌似只能通过类似“change master to .......”的方式进行配置。

如果从机也是linux环境,slave端配置,可以修改my.cnf的内容进行配置(未进行试验),内容例如:

server-id?????????????? = 2
master-host???? =192.168.0.5
master-user???? =slave0001
master-pass???? =123456
master-port???? =3306
master-connect-retry=60 #如果从服务器发现主服务器断掉,重新连接的时间差(秒)
replicate-do-db =test #只复制某个库
replicate-ignore-db=mysql #不复制某个库