|
|
环境:windows 7 ,mysql-5.5.18-win32.msi ! @( Z; m/ X0 K& m w
主服务器地址:192.168.1.1926 z) G6 I( T( l! O5 P$ `9 \- q9 u
从数据库地址:192.168.1.193+ J( ?4 l O) J, v2 a
ps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1 同步帐号:slavetb
2 \4 ]5 O$ h* J
0 |# A6 r' n. e. |3 X: ]4 {流程:2 T; C, `4 q$ P; D
主服务器
" }' P7 D8 R0 n1 k( G0 l3 G1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:0 G( b/ J, m' b9 ~
server-id=1 #服务器 id
. ?) {0 z" @5 I4 z% {! c: hlog-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin #二进制文件存放路径
9 }! C; d8 X X' k/ \* X+ ?' Mbinlog-do-db=test1 #待同步的数据库( F( a* ~" M3 e! R4 [. B5 A; P7 `
binlog-ignore-db=information_schema #忽略不同步的数据库,这个可以不用写% E& N( u }" |& E4 _
binlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写7 C) N! X- S% z* y8 G& H
binlog-ignore-db=test #忽略不同步的数据库,这个可以不用写* K% T& o0 ]* K0 V
expire_logs_days = 7 #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)# I( \2 B4 N. l" w1 ?
; b0 {/ R3 M7 B) F V$ m" R1 J
2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;2 R0 j# B# K9 @& R9 N! f- W/ r! T
+ q* m ~. D% o" w7 [4 D$ G
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 ( mysql -uroot -proot )8 D: j! H' @; T( v6 n
) A+ D) a) Z- A% k% M
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即可)- o4 C5 ^3 h- ~7 {! T$ G
* O, j* C% m7 L- u( L5:输入命令 show master status\G # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。
( W( z3 n0 b" k! F# Y( V7 y& G/ g/ v" \7 _& I* T) [% p- K
6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。
" u! f+ g7 t4 `8 q6 y, e
! y) Q+ j. n4 g9 S6 l& `; E+ Q+ D其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:
% i ]$ C0 S. J" x" c# G: r7 M. {: U7 _8 `, ]/ M& d
1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:! r2 M) ~8 N$ n
server-id=2 #服务器 id ,不能和主服务器一致' T7 v) R4 g* q
replicate-do-db=test1 #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news: j* w& W; n. H8 p; X! {) D4 n7 Q
binlog-ignore-db=information_schema #忽略不同步的数据库,这个可以不用写
J& N. H' t: s) U7 Lbinlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写) N1 D8 b: Q/ M; @( }
binlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写7 `; V/ T1 F; w8 L9 C# G, o
binlog-ignore-db=test #忽略不同步的数据库,这个可以不用写' e0 m) o4 @. f5 c
expire_logs_days = 7 #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
5 S; ?: L8 K8 c8 _2 r" p9 c! Q; O5 X- y/ U. E
2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;$ c. g( d: }" v0 }4 E& s5 c
6 G: ^2 d8 u; w* r6 o; Z
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin
! X1 I% W% `7 k4 `6 u
j" ?8 R" H9 C8 ~4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;4 M2 o) p2 Q. u5 r
7 z4 ^" t9 H8 H6 i) I/ k7 H& L
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线程,然后再设置连接的参数;0 J& e, @ e+ K6 D1 [7 I' N
8 ^7 S; n! E6 F% j5 [! [& n6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G (没有分号),查看Slave_IO_Running: Yes w/ R# G K* ^, C
Slave_SQL_Running: Yes k* r1 o& n% t
( D! E( G T; h5 u: t
* h" m4 l1 U3 `/ Y7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下, 后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置; |
|