|
环境:windows 7 ,mysql-5.5.18-win32.msi " q# L6 E! J; R4 t# ]
主服务器地址:192.168.1.192! s+ v7 a" r4 {
从数据库地址:192.168.1.193
, J9 K* r6 J' e( o- M: Wps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1 同步帐号:slavetb% }& B+ _- x4 j$ P7 l6 q# S; A
; f3 ~ M; m5 N2 ~) c% D1 D
流程:
( I( J9 X, A9 f主服务器6 L7 W2 d. U5 N
1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:
! R! |3 m6 g: a6 r" \server-id=1 #服务器 id 4 V; m @9 Y) W% {! L- i6 k
log-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin #二进制文件存放路径: j6 w/ o0 q% G3 d
binlog-do-db=test1 #待同步的数据库
; D' z9 |6 G) x5 t8 `) M1 N" kbinlog-ignore-db=information_schema #忽略不同步的数据库,这个可以不用写
2 t; A6 A7 I5 }8 Qbinlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写! s4 i' T6 t/ n6 I; f d5 m
binlog-ignore-db=test #忽略不同步的数据库,这个可以不用写: U4 e7 b9 F3 ~% t1 X# z) Z! T
expire_logs_days = 7 #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)2 \( A, ~8 l2 s- F+ I" b) Z$ U* L3 \
' [" S- u! N) J' c4 o2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;
; S- h. i4 Z! P" _' {- ^
2 x* Z9 m6 V0 H) ~: Z3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 ( mysql -uroot -proot )# G; C! P. W& T" o0 R/ h* ]2 ?; T
: X; w7 r( Y# e, F9 J3 t4:给要连接的从服务器设置权限: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即可)
# k' d% u4 S% |! n4 ^' J' P: E/ [" `
5:输入命令 show master status\G # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。
1 Q+ g$ F. a! l! a0 R" a. F, `/ g" S* P# o# h" u9 i0 {2 V# A
6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。
. |; @) C3 s- i; O; G7 R7 t# N5 i4 x- J2 D6 w
其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:: s# ^. C( T% c4 q& u3 I- I$ R
! @6 e! _/ p4 n3 N: l1 W
1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:
8 H% }" u2 @' X: x% l2 E% vserver-id=2 #服务器 id ,不能和主服务器一致+ S; @) z- ^/ b- S% c* O
replicate-do-db=test1 #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news
% n1 i, q3 a" ] J$ Nbinlog-ignore-db=information_schema #忽略不同步的数据库,这个可以不用写
. C1 z, z. z6 Vbinlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写" a; V0 I' B+ x
binlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写
- Y7 z( |4 a+ G2 x! Kbinlog-ignore-db=test #忽略不同步的数据库,这个可以不用写# w, ?* \3 e: ~" Z( W
expire_logs_days = 7 #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
* W( s0 ^2 ~* R. G* b1 Y7 }5 P, M1 L/ |$ |
2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;
# d$ r* [/ [4 j! V& B/ y+ S3 P$ B; _& p2 E6 R8 t( I
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin2 L. u3 y ]% c9 R6 Z
8 D5 k8 h4 \2 K$ \
4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;
( |# m0 L: A' y) r$ {8 c
$ N0 f* F$ o6 r# Y9 g5 k5:修改对主数据库的连接的参数: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线程,然后再设置连接的参数;6 R$ ~/ S1 T+ f9 J7 s% G0 b1 n
8 Z3 Q. t+ E# D' F* C# d+ k6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G (没有分号),查看Slave_IO_Running: Yes& _* U" K1 X% x7 }4 ~1 n
Slave_SQL_Running: Yes& X8 M# [9 W1 i0 z6 n' ^
9 B1 D$ T8 Q1 s5 u1 a2 k
2 B" W, C# N5 K' B0 ]7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下, 后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置; |
|