免费注册 查看新帖 |

Chinaunix

广告
  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1426 | 回复: 0
打印 上一主题 下一主题

MySQL复制配置步骤文档(主从备份机制) [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-06-01 22:51 |只看该作者 |倒序浏览
MySQL复制配置步骤文档
From CEWIKI
MySQL复制配置步骤
本文档主要对一个主服务器,一个从服务器(简称一主一从)的复制配置步骤进行说明,一主多从的配置方法其实也是一模一样的,只不过需要增加更多的从服务器,增加的从服务器的设置方法跟第一个从服务器完全一样。
目录
•        1 第一次配置主从服务器方法
•        2 配置说明
•        3 主从复制配置方法
•        4 创建复制帐号
•        5 在主服务器的MySQL配置文件中添加选项,打开二进制日志记录功能
•        6 在从服务器的MySQL配置文件中添加相关复制选项
•        7 重启服务器
•        8 察看运行状态
•        9 从已有主服务器配置一台新的从服务器
•        10 配置说明
•        11 主从配置方法
•        12 打开主服务器二进制日志功能
•        13 创建复制帐号
•        14 备份主服务器的数据文件
•        15 备份主服务器的数据文件
•        16 记录复制启动断点
•        17 打包备份主服务器数据文件
•        18 主服务器表解锁
•        19 在从服务器上恢复主备份文件
•        20 启动从服务器,设置复制断点
•        21 察看复制状态
第一次配置主从服务器方法
配置说明
这里所说的"第一次配置主从服务器"指的是,已经安装好了MySQL数据库,第一次配置主从复制功能,主数据库中还没有历史数据,因此,如果 MySQL的数据目录下(如果是用RPM包安装数据目录缺省是/var/lib/mysql)已经有多余的文件,比如二进制日志文件mysql- bin.*,master.info,relay-bin.*,relay-log.*,请先删除。以下是一主一从结构的简单拓扑图:
  
主从复制配置方法
创建复制帐号
在主服务器上创建复制帐号,授予相应的权限。注意,复制帐号的口令最好不要超过6位,而且不要带"#"等特殊字符。创建命令如下:
GRANT REPLICATION SLAVE ON *.* TO ‘帐号名称’@’%’ IDENTIFIED BY ‘口令’
比如:
    GRANT REPLICATION SLAVE ON *.* TO ‘repuser’@’%’ IDENTIFIED BY ‘111111’
在主服务器的MySQL配置文件中添加选项,打开二进制日志记录功能
server-id = 16204
log-bin=mysql-bin
binlog-ignore-db=mysql
binlog-ignore-db=information_schema
 各个配置选项的说明如下:
server-id = 16204
服务器ID号,整数值,保证唯一标识一台服务器就可以
log-bin=mysql-bin
打开二进制日志
binlog-ignore-db=mysql
忽略mysql数据库复制
binlog-ignore-db=information_schema
忽略information_schema数据库复制
在从服务器的MySQL配置文件中添加相关复制选项
server-id =16214
master-host=172.20.16.204
master-user= repuser
master-password=111111
relay-log=relay-bin
relay-log-index=relay-bin
replicate-ignore-db=mysql
replicate-ignore-db=information_schema
各个配置选项的说明如下:
server-id =16214
  服务器ID号,整数值,保证唯一标识一台服务器比如:16214
master-host=172.20.16.204
主服务器IP地址,比如:172.20.16.204
master-user= repuser
 主服务器上创建的复制用户帐号名称,比如以上创建的:repuser
master-password=111111
  主服务器上创建的复制用户帐号密码,比如以上创建的:111111
relay-log=relay-bin
  中继日志名称
relay-log-index=relay-bin
  中继索引文件名称
replicate-ignore-db=mysql
忽略mysql数据库复制
replicate-ignore-db=information_schema
  忽略information_schema数据库复制
重启服务器
先重启主服务器,起来后再重启从服务器
察看运行状态
在从服务器上执行命令:show slave status\G
  
 如果复制状态Slave_IO_Running,Slave_SQL_Running都为Yes,说明复制已经配置正确
     Slave_IO_Running: Yes
     Slave_SQL_Running: Yes
从已有主服务器配置一台新的从服务器
配置说明
这里所说的"从已有主服务器配置一台新的从服务器"指的是,主从服务器都已经安装好了MySQL数据库,主服务器已经在运行,需要增加一个新的从服 务器,已经有很多历史数据需要复制到从服务器上。征对这样的应用场景,请按下列方法配置复制。以下是一主一从结构的简单拓扑图:
  
主从配置方法
打开主服务器二进制日志功能
如果主服务器的二进制日志记录功能没有打开,在MySQL配置参数文件(比如/etc/my.cnf)中添加选项,重启MySQL服务,打开二进制日志功能。
   server-id = 16204
log-bin=mysql-bin
binlog-ignore-db=mysql
binlog-ignore-db=information_schema
 各个配置选项的说明如下:
server-id = 16204
服务器ID号,整数值,保证唯一标识一台服务器就可以
log-bin=mysql-bin
打开二进制日志
binlog-ignore-db=mysql
忽略mysql数据库复制
binlog-ignore-db=information_schema
忽略information_schema数据库复制
创建复制帐号
在主服务器上创建复制帐号,授予相应的权限。注意,复制帐号的口令最好不要超过6位,而且不要带"#"等特殊字符。创建命令如下:
GRANT REPLICATION SLAVE ON *.* TO ‘帐号名称’@’%’ IDENTIFIED BY ‘口令’
比如:
    GRANT REPLICATION SLAVE ON *.* TO ‘repuser’@’%’ IDENTIFIED BY ‘111111’
备份主服务器的数据文件
备份主服务器的数据文件
执行以下命令,给主服务器所有表加锁,禁止继续写入数据:
    FLUSH TABLES WITH READ LOCK;
记录复制启动断点
执行以下命令,记录从服务器开始启动复制的断点,包括日志名和偏移量。
  mysql>SHOW MASTER STATUS;
比如:
  mysql> show master status\G
     File: mysql-bin.000025
     Position: 13729
     Binlog_Do_DB:
Binlog_Ignore_DB: mysql,information_schema,mysql,information_schema
日志文件名是:mysql-bin.000025
偏移量是:13729
      注意,从服务器将从这个位置开始复制。
打包备份主服务器数据文件
打包需要复制的数据库文件,如果数据库文件安装在/var/lib/mysql目录下,可以执行命令:
tar zcf /tmp/backup.tar.gz /var/lib/mysql
该命令将把/var/lib/mysql目录下所有的文件都打包,也包括MySQL的系统表,而系统表一般都是不需要同步到从服务器上的, 所以最好选择你需要复制的数据库目录,进行打包就可以了,如需要复制两个数据库(PRIVATE_DB1 ,PRIVATE_DB2)到从服务器上,只要把这两个目录打包:
tar czf /tmp/backup.tar.gz PRIVATE_DB1 PRIVATE_DB2
主服务器表解锁
执行以下命令,解开主服务器的读锁,主服务器可以继续更新数据:
mysql> UNLOCK TABLES;
在从服务器上恢复主备份文件
在从服务器相应的数据库目录(比如:/var/lib/mysql)上恢复主服务器上备份的数据库文件,恢复时需要关闭从服务器的MySQL服务,比如:
Cd /var/lib/mysql
Tar xzf backup.tar.gz
启动从服务器,设置复制断点
在MySQL中执行以下命令,设置复制开始断点:
change master to master_user=‘repuser’,
     master_password=‘654321’ , master_host=‘172.20.16.204’,
     master_log_file=‘ mysql-bin.000025’,master_log_pos=13729;
  表示从日志文件mysql-bin.000090,位置98开始复制
察看复制状态
在从服务器上执行命令:show slave status\G
  
 如果复制状态Slave_IO_Running,Slave_SQL_Running都为Yes,说明复制已经配置正确
     Slave_IO_Running: Yes
     Slave_SQL_Running: Yes


本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u/25969/showart_723396.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP