Maison > base de données > tutoriel mysql > 使用MySQL的镜像功能进行数据同步

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

WBOY
Libérer: 2016-06-07 17:28:11
original
1713 Les gens l'ont consulté

数据库版本: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

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal