|
|
环境:windows 7 ,mysql-5.5.18-win32.msi ) v. z1 l% c7 `( q; `
主服务器地址:192.168.1.192
8 x& `. b$ b F6 c5 A从数据库地址:192.168.1.193
$ t1 J& g3 A" ^; E' qps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1 同步帐号:slavetb
0 J3 O2 H5 c( {. P7 s7 n P" {: r; e: i& g; Q& t0 y+ |
流程:
0 h6 D! l# Y+ G主服务器6 S/ F# u7 \" O9 v
1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:
4 y' g8 n7 i. U% D. _. Mserver-id=1 #服务器 id
. O0 \5 P) g2 `- S4 Tlog-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin #二进制文件存放路径
- A6 }# @6 o0 N- W' T6 A- a7 v4 Cbinlog-do-db=test1 #待同步的数据库( @! k- E( {8 K$ Y0 P" s3 ?7 c- A
binlog-ignore-db=information_schema #忽略不同步的数据库,这个可以不用写
7 `3 o( |/ {" f' c$ z/ Rbinlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写8 r5 H+ E& k6 Y. y5 ~ T% j
binlog-ignore-db=test #忽略不同步的数据库,这个可以不用写
: z4 r; _; v/ ~, O& sexpire_logs_days = 7 #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)" @3 N0 `/ h& }' n3 H
. m7 N3 A; i. a) M$ J2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;
3 Q8 E$ ^% l$ [- U& _8 r) M& a7 x7 U% T( [# @2 b
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 ( mysql -uroot -proot )
% q/ B5 ?# j( k8 ~6 K' O+ V, @1 j1 }4 g& G) ^4 ?8 r- c
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即可)
! R1 z2 }; W4 W+ w( D4 n/ j
9 G8 R0 F; D1 L/ K# T5:输入命令 show master status\G # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。
' F0 d4 X9 h3 U& r/ Y& [# v% _0 m8 W% k7 \: a/ r
6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。
- G! j5 ] |8 ` q5 O: j+ z- \7 n; g+ }3 n
其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:4 ~% V( |" ]) d6 x% ?- G1 u
# d( O8 I( W" o+ v C- Y( t
1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:
% J% p# D, m1 Pserver-id=2 #服务器 id ,不能和主服务器一致
) l& |1 m+ M1 M) lreplicate-do-db=test1 #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news
# W9 v0 h( |" K4 i+ g8 _binlog-ignore-db=information_schema #忽略不同步的数据库,这个可以不用写" |( O6 i, J, D. D
binlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写
0 }8 J$ T4 S/ }( bbinlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写) b- m0 Q/ }3 q
binlog-ignore-db=test #忽略不同步的数据库,这个可以不用写" P% y, `0 E4 u2 N2 U! |* {5 A
expire_logs_days = 7 #超过7天自动删除日志文件可以防止同步日志文件过大(可选项): O' N9 z/ s+ A4 L: ^
% J [8 X9 ]3 v4 r
2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;
& c. N4 I8 A7 d3 }- z
f' c( P" r; e3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin
* c7 B5 [8 e3 d# {$ s, \* y$ w. \& |7 E9 Q5 P4 B
4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;4 s& ?7 M3 X: _" C# ~
2 y9 A; W' k b! v9 _- I5:修改对主数据库的连接的参数: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线程,然后再设置连接的参数;
% f. q& g1 a+ x, g: \7 @0 u2 Q
% i J. x! G$ n' k, d& C6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G (没有分号),查看Slave_IO_Running: Yes! E! J9 V4 K6 d; f0 Y5 C
Slave_SQL_Running: Yes
9 C8 I3 H6 C! v+ k7 X 7 C3 z3 v4 j! l9 {9 ?
, {- w" ?4 \2 [0 c% q7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下, 后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置; |
|