|
|
环境:windows 7 ,mysql-5.5.18-win32.msi
1 [) _6 p R5 W7 b- i: S Z# |主服务器地址:192.168.1.192
% W1 ^% S" y4 x从数据库地址:192.168.1.193
8 |5 |: r0 Y: Yps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1 同步帐号:slavetb
2 G! k8 ?( Z5 m$ g8 h$ Q
: J; _) }4 {$ c% S' e流程:
& t! [* y6 O' W/ q z" d主服务器. V) }6 P4 P9 r, b+ P* G- R
1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:! w: {& V: g6 R
server-id=1 #服务器 id
) D1 {# ~3 C' }log-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin #二进制文件存放路径7 s# x m' E! [" `0 s
binlog-do-db=test1 #待同步的数据库# C$ M$ f m) S% i
binlog-ignore-db=information_schema #忽略不同步的数据库,这个可以不用写
: S: t! J4 {7 F( N1 @. ^binlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写5 P% Y' n5 ?/ U$ r9 @" x5 t
binlog-ignore-db=test #忽略不同步的数据库,这个可以不用写
/ Z1 T' ?, [) t Y' O6 V' Qexpire_logs_days = 7 #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)1 p6 v M0 m1 m, S! `
0 o. z: Z) O" H& T e2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;& \1 _+ Q% d" H$ X9 F
# _( X( d5 W% }8 {6 \1 ^8 y6 L
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 ( mysql -uroot -proot )# k, J) n* ^- g% }% b- y" K& E0 s6 A8 g
: z: y, ]; U) D* {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即可)
( \2 U" B! g, i8 C* ^! i) [+ u2 `2 k
5:输入命令 show master status\G # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。
7 o" x3 \0 V& X6 Q; S
# g# l0 S2 g5 h J* H5 w) V6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。
4 s2 V4 Q- Q% P; `8 R6 H% {+ O2 C/ j6 Q6 s
其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:
- X# Q( j, p# M1 `! V6 c+ }6 T, \1 i/ H
1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:
- z/ h8 b& X% y0 r4 m, Q7 x1 w4 [server-id=2 #服务器 id ,不能和主服务器一致
2 e [, N0 \" _) A' Ereplicate-do-db=test1 #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news
5 T/ C" W1 Z9 \& B" Q9 D3 Rbinlog-ignore-db=information_schema #忽略不同步的数据库,这个可以不用写
# S* D9 O7 b6 q# C& }binlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写% U3 N) k" Y% B+ O
binlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写
v0 S. v5 X* n3 Q; `binlog-ignore-db=test #忽略不同步的数据库,这个可以不用写
) `, F+ E6 V0 m! dexpire_logs_days = 7 #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
3 ^+ ]% Q- @5 d$ E2 s7 \2 j1 E4 T/ f; i( b& n, l7 ?+ Q. G
2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;
* {! \* i) _$ k) a2 e
, [. s8 p, g/ {: K2 l7 O2 y6 o3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin
/ D/ O% O0 X" x' f; }8 }. ~$ }8 N7 H) A3 g4 ~8 C) L$ E, u1 G
4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;4 D. L6 p' J0 N6 l# B6 p
2 c6 \4 o8 E$ V! ^4 ?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线程,然后再设置连接的参数;; Z1 F* B0 p/ B+ g0 m7 ]/ m% A* k
3 B! r/ b* C( t& Q, G+ C# Z6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G (没有分号),查看Slave_IO_Running: Yes
7 v) v- J4 [# T" r- ZSlave_SQL_Running: Yes
g5 [( m( X" e f) W; W! R' I ( S' b2 _8 y3 \
# |7 p% i8 @/ `) ~; q
7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下, 后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置; |
|