找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 16348|回复: 1

mysql5.5主从同步备份设置

[复制链接]
发表于 2013-3-26 21:05:24 | 显示全部楼层 |阅读模式
环境:windows 7 ,mysql-5.5.18-win32.msi & |! a3 \. R, G! R/ e
主服务器地址:192.168.1.192+ U) o( V; w3 ]
从数据库地址:192.168.1.193! V' }' z5 I2 O) F' A4 M
ps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1   同步帐号:slavetb
& a2 a8 o; @/ e
1 A7 w1 e7 z% N: [; \5 J* G: S流程:
" r/ r3 U: s+ D3 N" O$ ]7 A0 K
主服务器
& S1 h! {. @/ {* ]1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:

; V2 e6 p, F, `- l2 x$ Eserver-id=1    #服务器 id
% ^. x, I  h0 X0 L+ Alog-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin    #二进制文件存放路径/ {7 v5 x* O4 j7 m" W
binlog-do-db=test1    #待同步的数据库
3 N' g; y8 T( I- C/ bbinlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写
8 W5 q0 h" `5 q5 P" |" t+ W& ^1 m6 ]$ @binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写# V7 G6 S1 i: d5 T4 W
binlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写
' G1 R/ B# ~, Q# b6 j# E! r
expire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
) c6 X: i3 ^" Z, n2 n4 a
& A; T$ u4 K  z( o* G5 f3 ~, p2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;
! T2 u6 I' A4 e0 F! A1 j& ]/ L/ }) W4 L2 k
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 (    mysql -uroot -proot   )
) b: T$ F* ~$ [! b
, K  j. c, v9 q4 ~: M4:给要连接的从服务器设置权限: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即可)
- t  v5 r' N' K. w$ q
7 Y2 n: T- n5 X) [! q7 F5:输入命令 show master status\G       # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。
! e- \/ T' [4 V0 E, z! y3 s6 O# @; M& D
6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。

- A" G: t4 N$ g5 I+ O2 C$ B, j4 x# N; z, C3 @9 W8 K
其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:
/ c: j1 h+ v& j: O2 Z9 f
: k& B# z3 ]9 x, |+ u2 f. J1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:

4 ~$ c. Y4 k" p" q! k$ hserver-id=2    #服务器 id ,不能和主服务器一致
. x# @, m0 V1 U8 w, y$ l/ w5 T5 ureplicate-do-db=test1    #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news& Y* d1 }) s( u; f
binlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写
5 B' |+ n- u, e% {- W7 gbinlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写6 g6 ^8 L2 i  s2 J
binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写  J/ z3 y" j6 C' D
binlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写

1 M  i! g! q3 V6 C5 P% fexpire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项), V4 t" G; L" m) s! Q( \; E9 }

2 Y, P- q& o" j) q& Z2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;! i$ b  U1 f* ]

" W+ x1 \+ w6 ?# w- u5 V; u+ F7 \& g3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin
% r. j5 E4 X& B% ]: Q$ V) F
( |+ L7 O; G1 {7 S: e2 B4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;6 B9 D" z& B4 G5 k, c* w/ `2 K) a

; D# L9 H( F! u) l! b/ b5:修改对主数据库的连接的参数: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线程,然后再设置连接的参数;
7 a3 t+ }4 N3 M: u7 s2 T: ?
) w8 }. ~  F+ [; y+ e% h6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G   (没有分号),查看Slave_IO_Running: Yes5 r; g1 Y8 K$ R3 M' c5 O
Slave_SQL_Running: Yes
5 k' |' w! N% a  ^' n6 k; |
# {: X0 `3 H- v4 x, z

+ u: k) r3 J. M2 x; x0 ?7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下,  后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置;
发表于 2013-4-1 01:05:39 | 显示全部楼层
讲解的很仔细,设置成功了!

点评

的确  发表于 2013-4-1 01:07
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|第一站论坛 ( 蜀ICP备06004864号-6 )

GMT+8, 2026-5-10 21:23 , Processed in 0.080198 second(s), 25 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表