首页 > 代码库 > MySQL 5.5主从同步设置教程

MySQL 5.5主从同步设置教程

先修改Master(10.1.123.197)的 my.cnf 配置在 [mysqld] 中新增以下内容log-bin=mysql-binlog-bin-index=mysql-bin.indexserver-id = 1sync_binlog=1binlog_format=mixed然后指定要做同步的数据库,并忽略掉不需要做同步的数据库binlog-do-db = testdbbinlog-ignore-db = mysqlbinlog-ignore-db = performance_schemabinlog-ignore-db = information_schema在 [mysqldump] 中修改内容为              max_allowed_packet = 32M注意:确保 max_allowed_packet 有比较大的值,比如 max_allowed_packet = 100M重启 mysqlservice mysql restart在Master上创建一个复制用户CREATE USER funsion;GRANT REPLICATION SLAVE ON *.* TO funsion IDENTIFIED BY ifunsion.com;# 测试环境密码是  xyzzy+ ---------------------------------------------------------- +再修改 Slave(10.1.123.160)的配置,修改 my.cnf在 [mysqld] 中新增以下内容server-id=2log-bin = mysql-binrelay-log-index = slave-relay-bin.indexrelay-log = slave-relay-binsync_master_info = 1sync_relay_log = 1sync_relay_log_info = 1# 以上三行话只使用于MySQL 5.5输入 mysql -u root -p进入mysql命令行,输入CHANGE MASTER TO MASTER_HOST = 10.1.123.233, MASTER_USER = funsion, MASTER_PORT = 3306, MASTER_PASSWORD = ifunsion.com;CHANGE MASTER TO MASTER_CONNECT_RETRY=30;在输入 START SLAVE;+ ----------------------- 如果发生错误无法启动 ------------------- +进入Master 的数据库输入 show master status\G记录下当前使用的 log-bin文件,以及position (比如现在日志是 mysql-bin.000001 ,位置是 107)然后进入Slave 的数据库输入 stop slave;change master to master_log_file=mysql-bin.000001,master_log_pos=107;最后输入  start slave;最后在服务器上执行yum -y install ntpdatentpdate cn.pool.ntp.orgclock -w把几台服务器的时间同步+ ---------------------------- 一些可能用到的命令 ------------------------- +执行锁表:flush tables with read lock;这一步的目的是使我们在制作主从的过程中,主库中不会有新的数据,否则会给我们的同步设置带来麻烦主库执行解锁:unlock tables;reset master    命令删除了所有的二进制日志文件并清空了二进制日志索引文件。reset slave        命令删除了Slave复制所用的所有文件,重新开始。+ ----------------------- 其它参考文档(未验证)-------------------------- +库业务不能停的情况下为从库制作镜像:案例:服务器1号:主服务器2号:从现在由于负载问题需要上架服务器3号同样为1号的从服务器。但是1号库不能停,2号也不能停,主从同步进程也不能停(要求苛刻)。可以这样做:在主:mysqldump -uroot -pxxxx -h127.0.0.1 --databases db1 db2 db3 --master-data=http://www.mamicode.com/1 > bak.sql3号服务器slave stop;之后将bak.sql导入3号从服务器slave start;3号服务器会自动从导出的那一刻的节点更新。因为--master-data=http://www.mamicode.com/1 这个参数在导出sql文件后会在最下方加上change语句。如果--master-data=0,则不会带有。非常的方便,但仅适合库不是太大的情况,该案例导出的库一共6G。

 

MySQL 5.5主从同步设置教程