|
环境:windows 7 ,mysql-5.5.18-win32.msi
- m/ [! v- ^6 k1 m主服务器地址:192.168.1.1921 c" L% O1 p* ]( ?- A
从数据库地址:192.168.1.1939 l ]5 V3 ^. Q
ps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1 同步帐号:slavetb, R! ]. D0 m' P5 U5 n2 k
" C2 v: ^# L3 r! K0 b% {4 V
流程:( W5 b3 R7 u* A: q( J& `
主服务器
, u$ S9 D( ?. h- H: |1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:
* c* N# b( s0 S$ P4 Z$ Q# _8 Kserver-id=1 #服务器 id
, [9 ~4 w. l/ _6 ^log-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin #二进制文件存放路径
" i, G- r0 x2 o7 ~9 F" M8 obinlog-do-db=test1 #待同步的数据库% R8 Z9 Q0 `4 |% x+ e5 C
binlog-ignore-db=information_schema #忽略不同步的数据库,这个可以不用写
! k U/ p2 u/ Q# J( Obinlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写
6 O7 ]8 n5 W9 k! M( Gbinlog-ignore-db=test #忽略不同步的数据库,这个可以不用写* { B# p7 K, Z8 i3 }
expire_logs_days = 7 #超过7天自动删除日志文件可以防止同步日志文件过大(可选项) p1 i# M: G3 d3 A
* d/ o4 \, g* n$ U
2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;' ]9 l' |9 T1 v
?. u6 b* Y( r. L
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 ( mysql -uroot -proot ): x$ B0 E: J2 r- D1 Z! n0 k5 N: @1 V
: I7 a" U- h% L; s' y3 d" E
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即可)1 ^$ I6 T0 ?/ K
4 Y5 w! v. b! k: r
5:输入命令 show master status\G # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。# a! v: w! j7 t* {8 `; ~
! A6 u" Y, ^7 m* J/ U3 r* ^: Q6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。 A, N0 u/ S3 C5 n, s C
$ B# V# Q* e7 I# g% v( Y其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:2 v. J7 L: {" ?* x/ _* E% u! N* N
5 r# W* C6 a8 e1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:" X6 d2 h% {. J; h# ~
server-id=2 #服务器 id ,不能和主服务器一致* t) B& z9 \8 @" W; K
replicate-do-db=test1 #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news
# p3 U/ S9 q0 ^' S$ }7 `binlog-ignore-db=information_schema #忽略不同步的数据库,这个可以不用写3 E4 x: y |- B
binlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写
! P O) e7 x# o7 ]* n jbinlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写% k) P. L" ~3 J" l* |8 |) \3 f7 Z
binlog-ignore-db=test #忽略不同步的数据库,这个可以不用写 f3 Q' l$ _+ F% O6 E" ^$ x4 X
expire_logs_days = 7 #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)1 v2 w0 X- @2 @7 E1 Y* r$ z) e+ R
) n$ l1 E3 }* F8 U$ N8 w% `
2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;2 R x* C6 c7 ?! W2 l; V! l
; ^% N9 B6 b1 O+ {+ d3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin
+ c/ Z: m' G5 u. E0 r4 A/ Y2 \. f- \( T
4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;
. i# q# Z( R/ c3 t' u$ s+ f5 M! r9 c, ~) Q, v; t
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 C: f; D3 W, j' y, O% {: I
^/ B' S% |) z) D6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G (没有分号),查看Slave_IO_Running: Yes( ^1 {- E- ]- L; O8 c( y
Slave_SQL_Running: Yes) I& v0 ~0 @5 n4 e0 ~3 M+ K) `- _
# z$ b8 v( s1 f5 Z
1 k- {9 q' J% t5 l4 I7 ?7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下, 后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置; |
|