|
|
环境:windows 7 ,mysql-5.5.18-win32.msi 1 J& D; g* ^6 u' i2 q/ S) D9 S
主服务器地址:192.168.1.192& `+ K' F9 D% K8 x( p. E/ G
从数据库地址:192.168.1.193( f7 ]- D9 R; j% Z0 C
ps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1 同步帐号:slavetb, X' D1 o( | g% K) n1 h$ ^
, u; s2 G1 U+ m, }7 y5 k* x流程:
. ~; U1 S9 @ p% V! _' j: y. |主服务器
" t+ M9 S7 J4 f1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:
* v1 e6 Q$ O4 F6 hserver-id=1 #服务器 id
0 E* _5 ?, `" Q2 |. ~log-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin #二进制文件存放路径
& V" ` ?. ~' L2 [* z4 v& }binlog-do-db=test1 #待同步的数据库
" ]$ W9 K6 F) e1 h ]binlog-ignore-db=information_schema #忽略不同步的数据库,这个可以不用写* r$ Q8 g8 Q8 C5 |3 Y# v
binlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写
! z7 ?9 a' M6 ]+ _binlog-ignore-db=test #忽略不同步的数据库,这个可以不用写3 w$ M! T& K+ u5 V* s T6 O
expire_logs_days = 7 #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
. |9 {8 o3 @+ c: j0 g6 F. L1 A) M( E* z" ]
2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;3 q: l; _/ N6 W4 q- }
3 U6 Y2 y" s2 \! f$ K/ d
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 ( mysql -uroot -proot )
& X) T. @1 V' q8 E; L( @% R8 r( r9 b+ l3 q0 w
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即可)
: k3 y2 U3 f# \! S' Z, \$ E& G1 O' K+ c" m
5:输入命令 show master status\G # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。0 o, I w/ e* r* `
+ }6 E O0 E( S6 Q4 \1 @" I
6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。. r( s2 s4 l( n5 B7 J& l* Z$ _0 w$ O
1 W0 }& b( }( e$ t7 g) J3 Q' y其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:
& `, v$ G* q9 R; @ Y7 L7 j$ G$ U9 u( {- c$ k' z/ _8 K
1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:* T6 S1 `) y3 Q* L
server-id=2 #服务器 id ,不能和主服务器一致& V% y) H7 R+ @! c/ M& H3 h6 s8 g" B
replicate-do-db=test1 #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news4 R" _. @ ^0 T( P, {
binlog-ignore-db=information_schema #忽略不同步的数据库,这个可以不用写0 w$ ?, K- v% m1 r6 Y
binlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写
+ ^7 A! a$ h- Sbinlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写
$ M2 U: L @' k6 T- S+ ~binlog-ignore-db=test #忽略不同步的数据库,这个可以不用写. a! d: Y- I( u s
expire_logs_days = 7 #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
6 S! M" L' U* H+ ?6 A6 J& c E7 D0 r# A
2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;
, s& u7 g2 L) Q* F; `9 W. M. y% I ~' b0 y
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin! l( j1 m" x* t+ T
. W, a5 p4 }$ g( C" Y4 u6 _+ ?- R
4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;8 J0 H+ m9 I/ f1 ]0 O& E+ q3 v8 N, ^
. W1 `; M8 y# u. h5:修改对主数据库的连接的参数: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线程,然后再设置连接的参数;9 z6 r0 v. ]- X" I
O8 U- e+ e* t4 O2 `$ z. @
6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G (没有分号),查看Slave_IO_Running: Yes9 t4 P" Z* Z1 `
Slave_SQL_Running: Yes
8 K+ E* }% _+ k! L " p/ I# j1 g+ N0 u- [# D7 C
- n5 T+ ?' N% x7 Z- ~2 p) M7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下, 后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置; |
|