|
|
环境:windows 7 ,mysql-5.5.18-win32.msi
# r5 o$ x& T- X6 I6 s主服务器地址:192.168.1.192
6 D1 p% y7 c1 t- r+ M; b从数据库地址:192.168.1.193 [7 p. v# q+ g2 X3 p1 P* j! A6 g
ps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1 同步帐号:slavetb
8 n% B, t- w% I z: W2 D& R; }( @2 k8 K7 f
流程:: \" _9 {2 r. @7 b/ E4 f
主服务器
5 l# s& W0 `* F- o- u9 o1 A2 X1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:; G1 Z7 P4 P6 t0 I
server-id=1 #服务器 id
! \' Y5 J( @- t' P7 |4 I7 m5 qlog-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin #二进制文件存放路径8 c, j4 W8 P: A* u; S* C
binlog-do-db=test1 #待同步的数据库* {/ e) J- a# M5 Q+ y7 m6 X0 v- ^; Q
binlog-ignore-db=information_schema #忽略不同步的数据库,这个可以不用写
7 T) l% Q- N. j4 D! |' d3 nbinlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写5 D$ u0 w/ F+ J% f: Z
binlog-ignore-db=test #忽略不同步的数据库,这个可以不用写4 e. ?$ a$ r+ [6 W$ w
expire_logs_days = 7 #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
O) [0 d( k( G
1 a7 W/ _9 B: ^/ x* ?! e2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;
, G$ F, [( q1 K
1 B1 [& I: f% r6 _# w" T3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 ( mysql -uroot -proot )3 V9 F# a: b- `; T, n; {1 }
% x+ }/ O/ H/ h I T
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即可)6 S! m$ d3 ?8 C1 ?- G# F# k
7 V7 p* g4 x8 {8 Q
5:输入命令 show master status\G # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。
6 K& n( _( s r* k: h: ]/ V% Q. Q8 x( r$ n
6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。 G* N2 e2 V: A% r+ |* E$ f, G+ d# L
& v3 {' t3 k3 U2 _' o其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:% j9 g% O7 b$ P3 K$ f, V
2 a7 d3 P3 `' T) A |5 n$ K1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:
) b& r" F7 ]! f: I0 e ^server-id=2 #服务器 id ,不能和主服务器一致" g+ W' K$ V" D. @
replicate-do-db=test1 #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news3 A. s) h2 [! b4 |! B. U5 L! I
binlog-ignore-db=information_schema #忽略不同步的数据库,这个可以不用写
7 g7 V$ s3 m$ G/ G, \3 [, d+ dbinlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写' D/ M+ w0 b1 M6 M
binlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写
/ I2 Y v' Y rbinlog-ignore-db=test #忽略不同步的数据库,这个可以不用写; S( v5 L* F% M3 M% u# Q& X
expire_logs_days = 7 #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)( ^) z3 o- n {
6 Y0 H8 s ?: V8 K. o
2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;
; W) d2 i7 X- G2 E
) L0 K! G* p+ U5 v7 e% ]6 y+ [3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin
& N R. _: `- {5 f8 X/ @
t* J4 @! s8 S: c9 K. j3 \4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;6 d! C! l) E4 c( o0 g
1 m" ~0 e. b* m
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线程,然后再设置连接的参数;* {, p" P8 H( W
/ |/ K8 ~. N, _# N4 B" \5 A
6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G (没有分号),查看Slave_IO_Running: Yes. O E2 f- ~9 q# H) J
Slave_SQL_Running: Yes
( h2 m/ ? H/ f" m9 O$ @+ y 5 ?! L7 u$ @. E: z) x5 V
( @! r. M0 w2 x. s: t# B
7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下, 后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置; |
|