找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 15866|回复: 1

mysql5.5主从同步备份设置

[复制链接]
发表于 2013-3-26 21:05:24 | 显示全部楼层 |阅读模式
环境:windows 7 ,mysql-5.5.18-win32.msi
* h! E) C  W- M: J- `, W主服务器地址:192.168.1.192
* W" `) X, z3 Q0 p( a从数据库地址:192.168.1.193
! S/ b' Y( p8 B3 V5 a5 h: V& ?1 lps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1   同步帐号:slavetb% b3 \7 \+ _3 }6 k
! D. N3 {. r' Y; `9 H0 N
流程:
: w( K+ [/ o$ f, z6 P% a5 f) j
主服务器- _, B* y* e, l8 Y
1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:

* u7 ?& O' e, _  n  d* H. l  `: `server-id=1    #服务器 id 5 K$ g1 h6 c4 o! s8 ?* Z
log-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin    #二进制文件存放路径
% T+ R) @2 V6 Hbinlog-do-db=test1    #待同步的数据库' ?/ ], u- F4 D: `/ C  [$ d
binlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写
$ ~( x. R- i: M" ?8 J, bbinlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写9 v# g! u2 m9 @0 m! s' o5 F) H3 P
binlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写
5 g) a. k  o+ z4 b9 S
expire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
4 i2 F$ b6 e  m
* F, M1 T% }# a% s! A2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;9 B, C; Y. ]+ K* r4 S7 g+ z

3 N1 I% j' t1 E, i1 z% W3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 (    mysql -uroot -proot   )
; c+ E8 p! j0 S9 o# P- w
5 j8 d; Z8 Y# I8 V4:给要连接的从服务器设置权限:grant replication slave,reload,super on *.* to slavetb@192.168.1.193 identified by '123456';     ps: 给主机192.168.1.193添加权限,用户名:slavetb,密码:123456;注意不要少了;号(只需输入一次就可以了,向数据库中插入一个具有同步权限的帐号,可在phpmyadmin中设置,全局权限管理项选中RELOAD, SUPER, REPLICATION SLAVE即可)
2 y8 L: k" @% |+ l- d6 T$ E
( l2 ~; O2 H0 k% |; R. ?5:输入命令 show master status\G       # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。
" R1 `  R$ z; H# l4 [) p
% Z; n9 |9 z" C% N1 ]6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。

5 d+ ]; y2 b3 G+ p0 O5 G1 k. n2 ^8 l2 d( ~
其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:
5 F5 e% M, U( y" {/ Z$ e' a
9 `' P+ @% Z2 \& [" D1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:

# o- r! l; R- f+ y, Y! X! B2 o" _server-id=2    #服务器 id ,不能和主服务器一致
0 G2 E- M  `' E, Oreplicate-do-db=test1    #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news
4 C! I/ b# l$ W1 Qbinlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写
9 K8 A  K0 O( _: g; M7 z/ pbinlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
3 S; H# U* v7 n, _binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
/ m& L" r& _6 M' u4 c( Hbinlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写

& \' N+ V; x( \7 Yexpire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
" C5 J9 Q) N) |% R5 r2 `$ L8 U$ w3 G! C$ q/ {8 r
2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;
* `1 n. R+ i, |+ y% O5 W: J
6 K: D: O: Y# o0 \4 \" m3 j6 Y3 M3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin; q# r$ s; E4 Z! D6 b- p
0 O" v% a; @) R5 K3 H
4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;
3 s! B/ k5 ^  k+ ]: }3 R  R
0 g6 P) i( ?/ T' H6 g5:修改对主数据库的连接的参数:mysql>change master to master_host='192.168.1.193',master_user='slavetb',master_password='1234562', master_log_file='mysql-bin.000001',master_log_pos=107;  ps:最后两个中
mysql-bin.000001与107为主服务器配置中第5步记录下来的值。可能会报一个错误,大概的意思是说slave线程正在运行,不能设置,这样的话,执行mysql>stop slave; 停止slave线程,然后再设置连接的参数;2 [+ s( B& b+ w: b1 b

# g7 d' |6 B3 G) Y$ |/ E1 @6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G   (没有分号),查看Slave_IO_Running: Yes" s$ S" c7 y$ r& X
Slave_SQL_Running: Yes

1 S! ~) ?  ?* |: h& G1 L8 U: I4 }
. Q5 K  }! J, h3 ^
5 \5 c5 L4 @+ N; J: r7 X, p7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下,  后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置;
发表于 2013-4-1 01:05:39 | 显示全部楼层
讲解的很仔细,设置成功了!

点评

的确  发表于 2013-4-1 01:07
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|第一站论坛 ( 蜀ICP备06004864号-6 )

GMT+8, 2026-3-26 07:39 , Processed in 0.078475 second(s), 25 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表