|
|
环境:windows 7 ,mysql-5.5.18-win32.msi 0 d* T; P& i' f. }% @) T( H
主服务器地址:192.168.1.192
# h$ a" L: o2 f0 ^2 M从数据库地址:192.168.1.1931 ~8 P% k% {+ a
ps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1 同步帐号:slavetb
' m4 C' L' y# f8 m' j9 x9 m
& W4 \) R/ B0 g }( B0 ?流程:: s0 I1 X7 b z! U8 R3 V
主服务器
6 L6 ^+ ^( M9 z6 d4 ?$ N1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:! i; h. X" X8 ^
server-id=1 #服务器 id + i5 R" K! n# u/ i
log-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin #二进制文件存放路径5 z* I$ i/ _8 M+ t/ j* Y' l5 p
binlog-do-db=test1 #待同步的数据库2 i) C: f2 f: P$ o* r# K
binlog-ignore-db=information_schema #忽略不同步的数据库,这个可以不用写
& x. V' K: O/ t3 B- J4 i- Z, ebinlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写! }& l0 `* @' T! j; p. ~
binlog-ignore-db=test #忽略不同步的数据库,这个可以不用写1 j" B) |; [8 F$ S6 C4 I, S& t0 ?# x
expire_logs_days = 7 #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
3 ]9 q+ q5 w. A8 \" `1 e+ P8 C/ B$ ~* v
2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;% ^/ G! h: I& M0 z: c
7 J! ^2 l$ C" l
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 ( mysql -uroot -proot )
9 [4 O8 C/ k- i8 a0 K- p0 }- Y! ^
8 i. H, u) _4 h# i4:给要连接的从服务器设置权限: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即可)' y0 d7 X" @% }3 {
: ^' D* g3 i% V7 }5 Y' ^2 U0 A
5:输入命令 show master status\G # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。
! z6 V1 c/ C9 f8 _
- x+ m# d W$ y n- s% G6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。
" t8 G' X3 g0 f, _6 Q6 K6 `, S) [" r' m9 h+ ~
其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:: N, b/ E. E3 e! Z. Z" Y
5 F! V e5 C. W) G C9 s+ l: G
1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:- u u' |% p; ~# a4 w9 [7 ~
server-id=2 #服务器 id ,不能和主服务器一致+ h7 I2 a3 v0 O- ~0 g) w
replicate-do-db=test1 #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news: W9 p: q; k- }. u) T+ C
binlog-ignore-db=information_schema #忽略不同步的数据库,这个可以不用写
/ S2 c$ U' d8 O1 S" J9 abinlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写3 A$ }3 C% Q# S6 u- E1 W! M- m6 h
binlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写
6 f0 W) ^! e8 S1 V$ R9 ^binlog-ignore-db=test #忽略不同步的数据库,这个可以不用写
$ r* `, A [2 O1 w; bexpire_logs_days = 7 #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
! I0 x( V3 Z9 e; S
, }2 r! p, _4 n4 F. D* c4 k. M8 W2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;2 w! w5 e M" |2 \6 `4 C
1 R$ e! F: i P$ i- b3 e- U7 Z* v3 g; {
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin
' Z3 [. a& m5 C8 |) `2 q/ `5 `* I2 x+ ~7 q5 _4 J; d
4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;) ^9 y6 ^0 p. ?+ v2 C" e" A% h. ^
% Q0 R' k w5 D6 B! E- w6 E
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线程,然后再设置连接的参数;
5 |- n. x' @" I5 L0 O k4 W( w+ ~$ ?5 n. i
6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G (没有分号),查看Slave_IO_Running: Yes
; u% ^8 `" b$ S2 L4 b5 PSlave_SQL_Running: Yes+ f( n0 Y/ J7 G3 \4 @* B& b8 r

8 f* K8 J' n3 K$ I# c$ i0 K7 v0 J5 V M- H, {, d- A! G5 v5 N( a6 j7 p
7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下, 后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置; |
|