|
|
环境:windows 7 ,mysql-5.5.18-win32.msi
7 {: y- V$ X/ Z- g+ N3 I! r主服务器地址:192.168.1.192* q& \9 ?" _6 o" f( H# E, F9 v
从数据库地址:192.168.1.1935 x. B3 W9 d6 f6 C" y
ps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1 同步帐号:slavetb
; L4 ]6 w$ z" @0 Q* \0 ~% e+ R
, A) z* [2 L+ ?# @: V; k3 c流程:
* G* H+ F7 \, X* c1 f; |主服务器4 Z! f) Z9 b% W8 s9 I( t" y
1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:
7 l$ ]3 Z. s, k3 H' D6 h* O z L/ ?server-id=1 #服务器 id 0 i* l: @7 v) T8 n! e
log-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin #二进制文件存放路径( C! d1 R8 H9 }
binlog-do-db=test1 #待同步的数据库3 d! {1 u ]; N- A/ N
binlog-ignore-db=information_schema #忽略不同步的数据库,这个可以不用写! P2 a$ U% b3 F! Q l- D
binlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写- B. e$ d9 e' [$ D0 j
binlog-ignore-db=test #忽略不同步的数据库,这个可以不用写: d* a) m8 X5 p! N! @! ^0 o5 c, v
expire_logs_days = 7 #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)4 P) j' S) `9 A7 J+ k% p1 X
% o% l/ p/ p& f2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;
' ~6 t! F3 f7 c0 X1 O5 Z. d. w/ W2 w) [
) w7 a% K$ V7 K9 ~: s' W3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 ( mysql -uroot -proot )/ u3 @, p/ _) \ l4 k7 f
1 n$ V: U& X% e6 v' k# Q* S4:给要连接的从服务器设置权限: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即可)
+ a7 H0 M. A5 I/ |: O( F' W& P5 P
5:输入命令 show master status\G # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。
` `" b6 U# E" ^$ v$ B' K
) C1 h" L5 r# G8 R0 C3 `* R1 j6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。9 a) o6 |3 j0 N
8 C- {3 K" v- K$ L- j4 X k/ d
其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:
+ i) [" E# L Q7 m& K# n) ~3 w- e8 s! r# h1 \/ h/ H+ t# J
1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:# J2 b z! R. v6 k- I% x% r! A
server-id=2 #服务器 id ,不能和主服务器一致5 v6 r' \* j, i# q1 a
replicate-do-db=test1 #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news
0 G1 y! G& r* O7 ?binlog-ignore-db=information_schema #忽略不同步的数据库,这个可以不用写
$ ?* t1 a) ]; `7 S/ E( |binlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写
) ]4 H* i4 v1 V w3 pbinlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写, j) s! N- B: `9 V7 Q+ I$ a
binlog-ignore-db=test #忽略不同步的数据库,这个可以不用写
c5 l. U/ H" zexpire_logs_days = 7 #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)$ g1 [) U7 r9 H* k3 Z v# C4 }! \ Z
0 t f/ W1 t/ r, b2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;, V) K/ e$ P2 v2 |$ X1 E: e( {
- |" A0 u2 G9 i
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin( {/ N6 P' u: |
, I5 a1 @4 O7 u0 Q Z: ^! V. w4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库; @# x, T' a0 q' E9 x
5 A, r5 m* ?( E, h3 e/ s& O5:修改对主数据库的连接的参数: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线程,然后再设置连接的参数;
V2 [& H# k' a+ c, U& F6 C
" S0 C, \% z1 |6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G (没有分号),查看Slave_IO_Running: Yes
. [0 r4 ?/ V! ^) P* y a" W, KSlave_SQL_Running: Yes7 [! L* p& f) t2 ]

' g" Y; f7 J- C. G* ^* y# C' d# @) F5 R" l
7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下, 后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置; |
|