- 浏览: 1315251 次
- 性别:
- 来自: 成都
文章分类
- 全部博客 (471)
- 原创文章 (4)
- Database (84)
- J2SE (63)
- Web (26)
- Javascript (30)
- Lucene (11)
- os (13)
- 算法 (8)
- Webservice (1)
- Open projects (18)
- Hibernate (18)
- Spring (15)
- Css (2)
- J2ee (2)
- 综合技术 (18)
- 安全管理 (13)
- PatternsInJava (27)
- NIO (5)
- Ibatis (2)
- 书籍收藏 (1)
- quartz (7)
- 并发编程 (15)
- oracle问题 (2)
- ios (60)
- coco2d-iphone (3)
- C++ (6)
- Zookeeper (2)
- golang (4)
- animation (2)
- android (1)
最新评论
-
dandingge123:
【引用】限制UITextField输入长度的方法 -
qja:
...
对List顺序,逆序,随机排列实例代码 -
安静听歌:
现在在搞这个,,,,,哎~头都大了,,,又freemarker ...
通用大型网站页面静态化解决方案(一) -
springdata-jpa:
java quartz定时任务demo教程源代码下载,地址:h ...
Quartz 配置参考 -
马清天:
[b][/b][list][*]引用[u][/u][/list ...
通用大型网站页面静态化解决方案(一)
mysql主从热备配置(含innodb)终极版
- 博客分类:
- Database
转自 http://blogread.cn/it/article/361?f=wb
mysql主从热备有2种配置方式,备份某些库或者忽略备份某些库,建议选择后者
master机器
以下是代码片段: vi my.cnf,添加下面的 log-bin server-id = 1 #sql-bin-update-same binlog-do-db=mysql //备份的数据库名,可以添加多个或者 |
slave机器
以下是代码片段: log-bin server-id = 2 #sql-bin-update-same master-host=192.168.8.201 master-user=backup master-password=123456 master-port=3306 master-connect-retry=10 replicate-do-db=mysql #log-slave-updates |
或者
master机器
以下是代码片段: server-id = 1 expire-logs-days = 7 binlog-ignore-db=test |
slave机器
以下是代码片段: server-id = 2 master-host=192.168.8.201 master-user=backup master-password=123456 master-port=3306 master-connect-retry=10 expire-logs-days = 7 replicate-ignore-db=test |
在master机器上面授权:
以下是代码片段: mysql>GRANT all ON *.* TO backup@192.168.8.202 IDENTIFIED BY "123456"; |
到此为止配置完成了(第一次配置需要重启mysql),剩下的工作就是再主从热备开始前保持主从的数据完全一致:
对于myisam的表,直接把master机器mysql/data目录下面的所有文件同步到slave机器对应的目录即可
对应innodb的表,不能直接同步文件,需要用mysqldump导出数据,然后在slave机器上面导入即可
注意在同步数据期间,master机器锁表成只读模式:
以下是代码片段: mysql>flush tables with read lock; |
这期间主从mysql都可以不停,数据同步完毕之后,再master机器上查看mysqlbinglog和偏移量,例如:
以下是代码片段: mysql> show master status; +---------------------+----------+--------------+------------------+ | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | +---------------------+----------+--------------+------------------+ | mysql-bin.000012 | 4117873 | | test | +---------------------+----------+--------------+------------------+ |
然后在slave机器上面修改成对应的日志文件和偏移量即可:
以下是代码片段: mysql>slave stop; mysql> CHANGE MASTER TO -> MASTER_LOG_FILE=’mysql-bin.000012’, -> MASTER_LOG_POS=4117873; mysql>slave start; |
最后master解锁:
以下是代码片段: mysql> unlock tables; |
至此mysql主从热备就可以正常工作了.
还有一种简单的方法,但是必须要停止mysql:
删除master机器下面的所有日志文件,删除slave机器的所有日志文件和relay-log.info及master.info
然后同步数据保持主从数据一致,最后先启动slave的mysql后启动master的mysql即可.
附录:
关于innodb的独享表空间存储(解决ibdata1超大的问题)
配置my.cnf
加入 innodb_file_per_table
以下是代码片段: [mysqld] innodb_file_per_table |
InnoDB管理数据库文件的方式比较独特,它使用 tablespace 来管理数据文件。当使用 Per-Table Tablespaces,也就是每个InnoDB表都使用单独的tablespace时,数据文件的管理方式和MyISAM类型的表差不多,在这种情况下,每个数据库表都对应到一个数据文件,当分表比较多时,数据库文件也会比较多;相反,当没有启用Per-Table Tablespaces,则所有的InnoDB表的数据存在同一个tablespace中,tablespace对应到一系列的数据文件,此时,我们必须指定数据库文件的路径和大小,仅有最后一个文件可以是自动扩展的,其它的必须是固定大小(比如2G)。由于InnoDB的数据文件只会增长不会收缩(即使删除数据或者drop表),所以当前面指定的固定大小的文件写满了之后,最后一个自动扩展的文件就会一直增长而导致一个超大的文件的出现,这对于有最大文件限制的系统上就会导致问题。
我同时了遇到磁盘分区写满和最后一个数据文件超大的问题,根据MySQL手册中对InnoDB数据文件维护的说明:
1. 对于最后一个文件超大的问题,可以计算出最后一个文件的大小(按M计算的大小取整,即字节数除以1024^2),然后修改配置,把最后一个文件大小设置为该值,然后在其后继续追加新的数据文件。
2. 对于磁盘写满的问题,可以把新的数据文件配置到其它分区,或者把以后的文件mv到其它分区,在配置文件中写数据文件的全路径
由于配置文件中指定的数据文件的大小和数据文件每次增长的大小都以M来指定,所以最后一个文件按M计算应该得到一个整数,一般不存在小数舍入取整的问题。
转移数据文件到其他分区应该用mv而不是cp,因为mv不会改变数据文件的创建时间,MySQL在启动时会比对log文件和数据文件的时间戳,如果两者不一致,则会启动失败。
相关配置选项
1. 使用Per-table tablespace
以下是代码片段: [mysqld] innodb_file_per_table |
2. 配置数据文件到不同分区
以下是代码片段: innodb_data_home_dir = / innodb_data_file_path = data1/ibdata1:10M;data2/ibdata2:10M:autoextend |
发表评论
-
sqlite3中的数据类型
2012-12-10 21:37 1267(转)http://www.cnblogs.com/kfqco ... -
Mac下MySql卸载方法
2012-09-10 23:57 1019Mac下MySql卸载方法 mac下mysql的D ... -
mac os x mysql数据库utf8配置
2012-09-10 23:29 2229进入mysql console: 输入 mysql& ... -
ON DUPLICATE KEY UPDATE
2012-08-07 01:47 1052(转自)http://blog.csdn.net/kesaih ... -
MySQL单列索引和组合索引的区别介绍
2012-08-07 01:31 1067(转自)http://blog.cs ... -
centos下MySQL主从同步配置
2012-08-03 13:14 1520(转自)http://apps.hi.baidu.com ... -
sql语句中left join、inner join中的on与where的区别
2012-06-13 13:24 1227table a(id, type): id t ... -
分组取前N记录
2012-05-31 16:24 1092(转)http://blog.csdn.net/ac ... -
如何一条sql语句取出分组数据中值最大的
2012-05-30 23:59 2320--按某一字段分组取最大(小)值所在行的数据(2007-10- ... -
存储过程与函数的区别
2011-09-28 19:35 1126... -
RMAN备份方案
2011-07-21 10:29 2026RMAN备份方案 RMAN也可以进行联机备份,而且备份与恢 ... -
oracle
2011-04-06 17:46 1018学习笔记 -
PLSQL Developer + Oracle客户端简易安装方法
2011-03-17 00:10 14330Oracle 10g绿色客户端 pl ... -
SELECT INTO FROM与INSERT INTO SELECT
2011-01-26 15:52 33731.INSERT INTO SELECT语句 ... -
浅谈unique列上插入重复值的MySQL解决方案
2011-01-25 11:33 1753本文的unique列上插入重复值解决方案,主要基于MySQL平 ... -
:Oracle 中对Merge语句的增强 和去重复新增
2011-01-25 11:11 2283在Oracle 10g之前,merge语句支持匹配更新和不匹配 ... -
单行函数(仅对单个表达式或一行进行处理)
2011-01-23 18:49 1233例如:select sum(qty) from sales ... -
oracle中的事务控制命令
2011-01-23 18:45 2017事务提交有显示提交:使用commit命令来提交所有未提交的更新 ... -
oracle全文检索
2011-01-23 18:18 61111.全文检索和普通检索的区别 不使用Oracle text功 ... -
Oracle快照原理及实现总结
2011-01-23 16:41 2436Oracle数据库的快照是一个表,它包含有对一个本地或远程数据 ...
相关推荐
mysql主从热备
Mysql双机热备配置教程,mysql主从双向,单向同步,教程清晰。
mysql热备及mysql主从配置、Mysql 双机备份
mysql数据库,实现主数据库增删改,从数据库也跟着变化
nginx主从热备.doc
nginx 的安装、keepalived 的安装资源,keepalived + nginx 主从热备的配置和必要的文件
nginx多种方式实现负载均衡与主从热备,反向代理,动静分离
MYSQL双机热备配置手册MYSQL双机热备配置手册MYSQL双机热备配置手册
26-搭建mysql主从服务器实战数据热备-笔记 26-搭建mysql主从服务器实战数据热备-笔记
MYSQL 双机热备配置手册
文档包含mysql下载链接,包含mysql安装配置,初学者可立即入门安装,包含主从配置和双击互呗配置,全手动安装过程分享
mysql搭建主从热备操作流程,平时整理分享给大家,希望大家少走弯路
mysql主主双机热备配置文档,系统是centos7,亲测可用.
MySQL 5.6 双机热备配置能够使用户在服务器宕机或者坏了的情况下,使用备用服务器MySQL数据库。
基于win2003的Mysql双机 主从热备详细配置
HeartBeat+PHP+MySQL双机热备自动切换配置HeartBeat+PHP+MySQL双机热备自动切换配置
还好mysql数据库提供了一种主从备份的机制,其实就是把主数据库的所有的数据同时写到备份数据库中。实现mysql数据库的热备份。 2。要想实现双机的热备首先要了解主从数据库服务器的版本的需求。要实现热备mysql的...
mysql双机热备同步,详细配置 成功案例 我的经验 已经正常运作半年 目前数据量600万
MySQL数据库配置主从服务器实现双机热备实例教程