AI编程助手
AI免费问答

使用MySQL的镜像功能进行数据同步

  2016-06-07 17:28   1802浏览 原创

数据库版本:5.1.24。 4.x版本的数据库请自己去找相应文档。 英文版文档的原文地址:http://dev.mysql.com/doc/refman/5.1/en/re

数据库版本:5.1.24。
 
4.x版本的数据库请自己去找相应文档。
 
英文版文档的原文地址:
 
1 在主服务器(master)正常运行的情况下,创建一个专门用来同步数据的用户。
 
create user ‘用户名’@'从服务器ip’ identified by ‘密码’;
 
grant replication slave on *.* to ‘用户名’@'从服务器ip’;
 
这个用户名和密码(明文)以后会自动保存到从服务器上的master.info里面。
 
2 修改主服务器上面的my.cnf
 
[mysqld]
 
log-bin=mysql-bin
 
server-id=1
 
这个镜像系统中的每一台mysql主机都需要一个不同的server-id (1~2的32次方-1)
 
ps:如果使用了innodb, 还需要加上:
 
innodb_flush_log_at_trx_commit=1
 
sync_binlog=1
 
ps again:  主服务配置文件里面一定不能有 skip-networking
 
ps3: 主服务器防火墙开放3306端口给从服务器。
 
然后重新启动主服务器的mysqld,,使配置生效。
 
3 获取主服务器状态信息并复制数据。
 
3.1 获取主服务器二进制日志的座标
 
在主服务器上运行一个mysql客户端,
 
mysql> flush tables with read lock;
 
这会flush所有的数据表,并且阻塞所有的写入操作。
 
对于innodb类型的表,commit 语句也会阻塞。
 
不要退出这个mysql客户端,否则这个read lock会失效。
 
在主服务器上重新打开一个mysql客户端,
 
mysql > show master status;
 
+—————+———-+————–+——————+
 
| file          | position | binlog_do_db | binlog_ignore_db |
 
+—————+———-+————–+——————+
 
| mysql-bin.003 | 73      | test        | manual,mysql    |
 
+—————+———-+————–+——————+
 
file 字段显示的是二进制日志的文件名
 
position 显示的是此文件中的偏移量。 抄下来这二个数据。
 
they represent the replication coordinates at which the slave should begin processing new updates from the master.

linux

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。