找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 16780|回复: 1

mysql5.5主从同步备份设置

[复制链接]
发表于 2013-3-26 21:05:24 | 显示全部楼层 |阅读模式
环境:windows 7 ,mysql-5.5.18-win32.msi
  L) ^  h$ u7 U9 h; A% a" H主服务器地址:192.168.1.192  ^6 b* C- p7 A9 B" j  g! m
从数据库地址:192.168.1.193
3 W" s8 }6 l+ U" ~ps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1   同步帐号:slavetb& m  h! \, C" [4 z! p4 g( v# v
. u/ Y5 ]6 X. ^5 H" j; b* i
流程:

+ ^1 `7 o. {% f主服务器
- ?" \2 Q$ [, v* h8 ~1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:

2 w. O8 d( P' |, ]$ Mserver-id=1    #服务器 id 5 V: L2 C# Q5 J9 _! X3 T
log-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin    #二进制文件存放路径
5 E* ?' `, I$ E, X$ Q9 i8 dbinlog-do-db=test1    #待同步的数据库
, k$ \% ~. c! B) g, g& v6 ^' Ibinlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写
( g7 L3 D* t0 s3 D4 j, Hbinlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
9 h3 q% B8 e# Q! c0 @binlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写

( i: |: m* {. s7 @; qexpire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
5 X5 V' u8 I. I2 ~! x# [9 K$ g7 ?9 X  ~% ~3 H
2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;! W9 G& g: O% Z2 D' z+ ~( P% I: n
3 q9 @# M- S6 U1 A
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 (    mysql -uroot -proot   )
! t+ x/ L8 N, U  b' M" k& n$ q/ u2 q* u$ L* h
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即可)
' k$ x! j8 F" h' r$ ?" t2 D
7 `& D! f# t& h. C2 y5:输入命令 show master status\G       # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。; a3 \% z, d' O

, R0 B, c; \3 `" ?  W6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。
. _0 m% r# o2 A) a  Z

9 M# @. }2 G7 s' y$ t+ t& r其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:# a2 k3 {8 a- J; C

$ b+ A6 a! ~  F' v+ u5 b8 |1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:
, e' `2 S& L) K5 Y
server-id=2    #服务器 id ,不能和主服务器一致
* n# Z+ I! `2 Lreplicate-do-db=test1    #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news
7 ?- p8 a$ M. [binlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写
& L" d; L8 P& V6 [$ S7 fbinlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
9 U( k& D/ A: N! f' P$ Abinlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写9 J2 z/ x' f6 X8 H' g! I
binlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写

$ N( }$ z* k; v% @* {) B8 Nexpire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
) f( |6 N( n( Y* T
; c0 I/ r1 p' k! v- I2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;
( C* ~( M" L1 _' g) u( x) _2 C" ?7 W% I7 ^$ n
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin; M! K( I+ J) Y  E: @& O

1 ?+ R' p+ X2 a% d3 W+ ]+ q/ Q4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;
/ {+ B* K/ v& i& `. P5 n
6 h5 ]4 T- _* c- e/ j( e6 p5:修改对主数据库的连接的参数: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线程,然后再设置连接的参数;1 E/ t5 j, G3 s% }* S! N- B; J

* t- h: a! A7 Y* A  m" S6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G   (没有分号),查看Slave_IO_Running: Yes5 x+ R% K. J% X0 ]+ i  U  w& B; o
Slave_SQL_Running: Yes

2 W8 F. \6 N) }9 V- g7 s9 A( H  Y2 N, h& a& G7 q
9 L  v6 b* P, d$ B! Q
7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下,  后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置;
发表于 2013-4-1 01:05:39 | 显示全部楼层
讲解的很仔细,设置成功了!

点评

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-6-25 11:13 , Processed in 0.050302 second(s), 24 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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