|
环境:windows 7 ,mysql-5.5.18-win32.msi ( V- n5 E' x* ^+ h
主服务器地址:192.168.1.192
; O: u4 c X" C/ q/ J% n6 z5 l从数据库地址:192.168.1.193$ m, A% \2 \$ C9 ~7 F
ps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1 同步帐号:slavetb
. U! z# L' }2 z- x9 P' a. a: K% A3 g' n/ ^* Q: K7 q
流程:5 n5 b& n! f6 D# Z3 Q' v( M
主服务器
5 G9 i8 K6 P# N6 m j/ N9 y' E1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:$ K9 Y6 ]/ ]7 u* e8 z6 N
server-id=1 #服务器 id 1 ~4 F( ?/ ~2 n! K
log-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin #二进制文件存放路径
1 K/ P2 p8 j) Y& ~binlog-do-db=test1 #待同步的数据库
/ c* W# g0 S4 \& ^+ I; M5 ~2 g! Nbinlog-ignore-db=information_schema #忽略不同步的数据库,这个可以不用写, g$ ~5 t% Z# x$ D @
binlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写
, ?* K! @, b+ R3 nbinlog-ignore-db=test #忽略不同步的数据库,这个可以不用写8 T( D5 O: |, ]" o/ y/ g; F0 u* c( @
expire_logs_days = 7 #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
+ e" {7 q0 U9 `, {+ t& u2 w; Y* L1 _, ]
2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;
% ^* i+ e* u4 L, P% p' s+ {; M
! {. h. C" x# M/ T5 m3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 ( mysql -uroot -proot )
7 z3 Y: \. Q# q) @# F9 _' M
& z% a& |$ H5 V) \# p" Y4:给要连接的从服务器设置权限: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即可)
2 x8 T" k1 m* n d4 A
$ ~ f8 O" v' s8 {4 a4 `$ x/ s+ R6 [5:输入命令 show master status\G # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。' d3 U/ { N8 h; F
. h$ w9 P' g6 D8 k; c
6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。9 K$ ]! J( i$ B8 d
( }5 Y& [: Z8 R/ o; z
其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:
: m" J4 H$ G! b0 U) T
. k" k6 F) j( m1 v6 a4 O* O1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:
6 K6 f: c! ?/ N8 ~- K aserver-id=2 #服务器 id ,不能和主服务器一致; Q8 G* F/ W0 P0 U
replicate-do-db=test1 #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news
: C( ^4 I# x# z$ ^binlog-ignore-db=information_schema #忽略不同步的数据库,这个可以不用写% U# H/ H9 i! |1 q, c
binlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写 B- A$ ^& `# I6 ], ]
binlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写
- Z" _& t9 Y+ N/ ~, d; n, Jbinlog-ignore-db=test #忽略不同步的数据库,这个可以不用写
8 p6 b# T( B1 g2 Oexpire_logs_days = 7 #超过7天自动删除日志文件可以防止同步日志文件过大(可选项): O7 X- w& X4 b S5 b
% r0 F3 J9 a: ?( E
2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;' y) v* l* r; a
$ K: a8 ^4 t8 w
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin. E3 B4 M* n# p8 F
) C# K' @" v; P; }6 D! k+ f4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;
) b1 _" R! C3 z' j0 j! I! O _# p; |7 `) f) p2 q! d
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线程,然后再设置连接的参数;
$ X% I& {! m/ x. ^. H8 J/ E+ G
8 `1 N5 ^' [/ N/ o/ q6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G (没有分号),查看Slave_IO_Running: Yes9 q; e. M" o2 y. B9 f& @4 }6 g
Slave_SQL_Running: Yes- } a$ L; w2 m

) C( O. K* c- O2 l2 n7 ~0 n5 l6 Q4 ^' v% M6 v! r; U, Y
7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下, 后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置; |
|