|
|
环境:windows 7 ,mysql-5.5.18-win32.msi
' Z: Z4 X# V5 E. N1 ^, h! S" k: ^& n主服务器地址:192.168.1.192
) n" o- F7 w# X* N从数据库地址:192.168.1.193
1 z& c1 r* i5 i) bps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1 同步帐号:slavetb3 ~# e: q! a& n/ f5 l/ p" u z9 M
# A0 u" m# ^: y3 z( z+ V! l( I5 H% @' ^& k流程:
9 S0 y1 Y' E% r1 @3 s+ C主服务器
1 ^8 _6 E8 P( `! J9 T1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:9 l y7 x% o2 ~1 k8 _8 |; R: y# {
server-id=1 #服务器 id * G" x7 H$ l- [
log-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin #二进制文件存放路径
3 ^4 A: [* h" B- Kbinlog-do-db=test1 #待同步的数据库
7 h9 |+ W; k2 u% y) x! Bbinlog-ignore-db=information_schema #忽略不同步的数据库,这个可以不用写
" l& e( n# i1 X# p' a: e5 fbinlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写. Q2 L$ E: N8 k: t, C1 h6 P _
binlog-ignore-db=test #忽略不同步的数据库,这个可以不用写: d2 h8 r& W8 U, K* g/ d+ V
expire_logs_days = 7 #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)% V7 i0 i! k8 X( Z
" g- q9 {3 |4 C) v3 `! z
2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;
: f2 m0 P5 \$ c& }' u- L" m' D' L( |/ e$ l: P! p" \
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 ( mysql -uroot -proot ). ^' ]' j* W; x8 V
1 ?9 L" n" q: b( h- v+ s1 z T9 _
4:给要连接的从服务器设置权限: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即可)
/ {9 \( q! m, O% i& p
. I9 S- [/ k$ \5:输入命令 show master status\G # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。: z6 r7 n, a$ t3 k5 b1 H: z$ N# c% ?& h/ ]
7 q3 G" n& f( p) G6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。
% c- A) C4 ~7 e5 z- k) i3 g+ S# U+ k9 g
其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:6 a# v" E8 d) [" h6 Q6 N3 N3 c+ ~' o- \
" E6 v9 d# z a% j( u/ ^' }1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:
8 r2 y1 s9 F \$ _ l5 c3 lserver-id=2 #服务器 id ,不能和主服务器一致' ~. x2 i' S ?- _5 s& }
replicate-do-db=test1 #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news
1 B2 L6 G: a& b6 w C; Ebinlog-ignore-db=information_schema #忽略不同步的数据库,这个可以不用写
; ?, q- S) t. Q' }6 n q- H, w2 H& Gbinlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写2 D: l9 ?% l$ X
binlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写$ a! z* p# a: W" w# U) Y: Y
binlog-ignore-db=test #忽略不同步的数据库,这个可以不用写- ^9 t3 g2 R U( D/ t- ^
expire_logs_days = 7 #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
3 p# {8 d! X, Y7 f4 e
5 R, Y4 _( Q2 J2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;' q- A6 A: V: P
; k3 r# \ E/ J v Z4 v3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin
5 m4 c% p" e" g6 ^+ i: o
4 |) x- d' {7 d" d, K4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;' Q4 T$ `- B8 N7 c) X
, ~8 l* r k: S) E4 C$ [, {5 R# [) |
5:修改对主数据库的连接的参数: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线程,然后再设置连接的参数;
& U2 k! ?5 o! n; V( Q: O) K8 k6 K+ s/ _4 d" w9 s- \1 A
6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G (没有分号),查看Slave_IO_Running: Yes
3 W$ S w4 e9 m5 o ^2 t* cSlave_SQL_Running: Yes# I1 z" A' Q- _0 b1 e+ _

5 e7 b/ _) Y7 ]& k/ y7 o O4 u$ Q1 G2 }
7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下, 后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置; |
|