|
|
环境:windows 7 ,mysql-5.5.18-win32.msi # H$ [4 `& a0 V0 b* i+ K5 x8 M. q
主服务器地址:192.168.1.192
$ C0 r9 ~$ e6 l% n( b' W$ F5 E从数据库地址:192.168.1.193
5 t8 d# k% ^* e/ o4 b) Hps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1 同步帐号:slavetb1 p Z+ E" J) m+ e
2 ?1 x) T8 v/ K; v' |流程:8 {" d8 S5 I* K& E i; B2 V$ X+ R
主服务器
; x& F* ?/ T; V! W/ d1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:
' x' i0 @) Q/ |: _! i# j+ Fserver-id=1 #服务器 id 3 q b' H n/ Y6 G7 D0 K
log-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin #二进制文件存放路径. p4 U4 J! L1 D1 C
binlog-do-db=test1 #待同步的数据库5 X3 w9 i7 T- t0 M7 C" R
binlog-ignore-db=information_schema #忽略不同步的数据库,这个可以不用写! X, M+ r( _6 |% Z+ U
binlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写& g% d: |, e* L' S
binlog-ignore-db=test #忽略不同步的数据库,这个可以不用写; A& m- g, `5 @1 D$ t% B7 ~
expire_logs_days = 7 #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
# p, F7 O9 g1 h% ^) P0 f5 v9 T
4 B& T1 h) }0 b+ s8 G+ i' z2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;
! q& X, T* T+ R/ R) Y9 v, L. `' A2 [: q1 W5 P; m; t( L
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 ( mysql -uroot -proot )
% i$ B% @* N5 g; e) u' D% t
2 I: d; B- x: @% n& v4:给要连接的从服务器设置权限: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即可)& d7 C# W! h: @' L& x& v; Q- y( H
, f( g' U( o2 Z, N" d2 _ m" Y5 ?9 r$ N5:输入命令 show master status\G # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。8 K* b0 {, L& A
' j2 i8 h: M2 h. `: a2 a) \6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。
1 h! P4 O" ?6 H# K- |* y' p6 O1 ?/ e
3 Z4 c3 M. a/ l其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:
2 U& g0 |2 y1 g7 i B" t- X; Y; b3 {. C
1 n/ N# J& K* T1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:3 S" M4 ^+ n/ `$ U0 [
server-id=2 #服务器 id ,不能和主服务器一致2 o1 ~- L2 e% d2 Q! M5 y$ `9 ^( C( M2 v
replicate-do-db=test1 #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news/ L2 @1 B$ f8 r% O
binlog-ignore-db=information_schema #忽略不同步的数据库,这个可以不用写
( Q3 w# C6 n- Fbinlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写: J$ }6 q# \ v) W& N3 D" O! S4 C, @
binlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写
- B3 {4 \( ?6 l" j: Kbinlog-ignore-db=test #忽略不同步的数据库,这个可以不用写 E- f6 \: q$ j; b9 a9 ?) K
expire_logs_days = 7 #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
3 p8 m' }( B2 |" v" X3 J8 U" ?8 H( d' f/ a
2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;
3 F- _- N$ M9 H4 K
6 W o6 y* D$ ^3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin. M% Y L- A$ n2 U* q
# {1 e, x: {) {# L4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;
# @' K5 a) q0 v( v6 S! s5 u- ?1 H7 v! T5 E6 ^5 v$ y7 y
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线程,然后再设置连接的参数;; |! o) O: a$ S- ]; ?% C
+ |* b E4 r9 s* `7 _6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G (没有分号),查看Slave_IO_Running: Yes
7 [: x* K# c1 h" v7 G+ k# FSlave_SQL_Running: Yes/ }. d. _) k1 `* n

/ q* y3 ]7 F3 r: ^7 k. q$ Z# p/ L' T, o
7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下, 后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置; |
|