MySQL数据库没有增量备份的机制,但它提供了一种主从备份的机制,就是把主数据库的所有的数据同时写到备份数据库中。实现MySQL数据库的热备份。

下面是具体的主从热备份的步骤:
假设主服务器A(master)、从服务器为B(slave)
A:192.168.0.104
B:192.168.0.169
1.主服务器授权
授权副服务器可以连接主服务器并可以进行更新。这是在主服务器上进行的,创建一个username和password供副服务器访问时使用。也可以使用主服务器默认的帐号和密码。
2.数据复制
将master上已有的数据复制到slave上,以便主从数据库建立的时候两个数据库的数据保持一致。导出导入数据库就不详述了。
3.配置主服务器
修改master上mysql的根目录下的my.ini配置文件
在选项配置文件中赋予主服务器一个server-id,该id必须是1到2^23-1范围内的唯一值。主服务器和副服务器的server-id不能相同。另外,还需要配置主服务器,使之启用二进制日志,即在选项配置文件中添加log-bin启动选项。
注意:如果主服务器的二进制日志已经启用,关闭并重新启动之前应该对以前的二进制日志进行备份。重新启动后,应使用RESET MASTER语句清空以前的日志。
原因:master上对数据库cartrader的一切操作都记录在日志文件中,然后会把日志发给slave,slave接收到master传来的日志文 件之后就会执行相应的操作,使slave中的数据库做和master数据库相同的操作。所以为了保持数据的一致性,必须保证日志文件没有脏数据。
4.重启master
配置好以上选项后,重启MySQL服务,新选项将生效。现在,所有对数据库中信息的更新操作将被写进日志中。
5.配置slave
在副服务器上的MySQL选项配置文件中添加以下参数:

  1. [mysqld]
  2. #唯一,并与主服务器上的server-id不同。
  3. server-id=2
  4. #主服务器的主机名或者ip地址
  5. master-host=192.168.0.104
  6. #如果主服务器没有在默认的端口上监听,则需确定master-port选项
  7. master-port=3306
  8. #步骤2.1中创建的用户名和密码
  9. master-user=root
  10. master-password=123456
  11. #复制操作要针对的数据库(可选,默认为全部)
  12. replicate-do-db=cartrader
  13. #如果主副服务器间连接经常失败,需增加master-retry-count和master-connect-retry
  14. #master-retry-count连接重试的次数
  15. #master-connect-retry 连接失败后等待的秒数
  16. master-retry-count =999
  17. master-connect-retry=60
 

5.重启slave
副服务器上MySQL服务重启后,还在数据目录中创建一个master.info文件,其中包含
所有有关复制过程的信息(连接主服务器的相关信息及与主服务器交换数据的相关信息)。在初次启动以后,副服务器将检查这个master.info文件,以得到相关信息。
如果想修改复制选项,删除master.info并重启MySQL服务,在启动过程中使用选项配置文件中的新选项进行重新创建了master.info文件。
将主服务器上备份好的数据库脚本文件(cartrader.sql)导入到副服务器数据库中,以便保
证主-副服务器上进行复制操作的起点一样。
6.查看master的状态与设置的是否一致
7.查看slave
一般情况下重启了slave之后,自动就会开启复制功能,可以通过下面的语句查看
在slave上

  1. mysql>show slave status
 

如果显示waiting for master to send event 的话就表示已经启动了,反之就运行

  1. mysql>start slave
 

来启动slave

在SHOW SLAVE STATUS的命令输出后,应该包含Slave_IO_Running对应的值为YES,
Slave_SQL_Running对应的值为YES,只有这样才保证主从机能正常备份。

暂时停止主从热备份的命令是:

  1. mysql>stop slave
 

 

最新文章

  1. 基于腾讯手Q样式规范Frozen UI
  2. Design3:使用HierarchyID构建数据的分层结构
  3. xss跨站攻击测试代码
  4. [转]Java多线程干货系列—(一)Java多线程基础
  5. BZOJ 2661: [BeiJing wc2012]连连看 费用流
  6. 【转】Dr.com 5.20破解教程
  7. 常用免费的WebServices地址
  8. [leetcode] 401. Binary Watch
  9. [Angular 2] Handle Reactive Async opreations in Service
  10. 揪出“凶手”——实战WinDbg分析电脑蓝屏原因
  11. VS2008 快捷键大全--------<<转>>
  12. 转 如何使用V7包中ActionBar(Eclipse版)
  13. Qt 打开文件的默认路径 QFileDialog::getOpenFileName()
  14. Pivotal开源基于PostgreSQL的数据库Greenplum
  15. 模式识别笔记4-集成学习之AdaBoost
  16. 用H5上传文件
  17. 自定义flume的hbase sink 的序列化程序
  18. Mysql中Left Join Right Join Inner Join where条件的比较
  19. iOS开发-策略模式
  20. python之路----网络编程--黏包

热门文章

  1. POJ1325 Machine Schedule 【二分图最小顶点覆盖】
  2. CSS权威指南学习笔记 —— HTML元素分类
  3. memcached-session-manager的一些理解
  4. 浏览器检测JS代码(兼容目前各大主流浏览器)
  5. js对表单设置了readonly和disabled后的区别
  6. EC读书笔记系列之17:条款41、42、43、44、45、46
  7. Oracle学习之start with...connect by子句的用法
  8. markdown流程图
  9. SVN+post-commit 搭建自动同步版本库
  10. JavaWeb基础之tomcat部署