- 浏览: 1336012 次
- 性别:
- 来自: 成都
文章分类
- 全部博客 (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 1349(转)http://www.cnblogs.com/kfqco ... -
Mac下MySql卸载方法
2012-09-10 23:57 1063Mac下MySql卸载方法 mac下mysql的D ... -
mac os x mysql数据库utf8配置
2012-09-10 23:29 2291进入mysql console: 输入 mysql& ... -
ON DUPLICATE KEY UPDATE
2012-08-07 01:47 1098(转自)http://blog.csdn.net/kesaih ... -
MySQL单列索引和组合索引的区别介绍
2012-08-07 01:31 1112(转自)http://blog.cs ... -
centos下MySQL主从同步配置
2012-08-03 13:14 1565(转自)http://apps.hi.baidu.com ... -
sql语句中left join、inner join中的on与where的区别
2012-06-13 13:24 1267table a(id, type): id t ... -
分组取前N记录
2012-05-31 16:24 1133(转)http://blog.csdn.net/ac ... -
如何一条sql语句取出分组数据中值最大的
2012-05-30 23:59 2374--按某一字段分组取最大(小)值所在行的数据(2007-10- ... -
存储过程与函数的区别
2011-09-28 19:35 1166... -
RMAN备份方案
2011-07-21 10:29 2067RMAN备份方案 RMAN也可以进行联机备份,而且备份与恢 ... -
oracle
2011-04-06 17:46 1054学习笔记 -
PLSQL Developer + Oracle客户端简易安装方法
2011-03-17 00:10 14394Oracle 10g绿色客户端 pl ... -
SELECT INTO FROM与INSERT INTO SELECT
2011-01-26 15:52 34141.INSERT INTO SELECT语句 ... -
浅谈unique列上插入重复值的MySQL解决方案
2011-01-25 11:33 1784本文的unique列上插入重复值解决方案,主要基于MySQL平 ... -
:Oracle 中对Merge语句的增强 和去重复新增
2011-01-25 11:11 2332在Oracle 10g之前,merge语句支持匹配更新和不匹配 ... -
单行函数(仅对单个表达式或一行进行处理)
2011-01-23 18:49 1278例如:select sum(qty) from sales ... -
oracle中的事务控制命令
2011-01-23 18:45 2128事务提交有显示提交:使用commit命令来提交所有未提交的更新 ... -
oracle全文检索
2011-01-23 18:18 61641.全文检索和普通检索的区别 不使用Oracle text功 ... -
Oracle快照原理及实现总结
2011-01-23 16:41 2476Oracle数据库的快照是一个表,它包含有对一个本地或远程数据 ...
相关推荐
**MySQL双机热备**是一种通过配置使得两台MySQL服务器之间能够实时同步数据的技术方案,从而实现高可用性和故障转移的能力。该技术可以确保在一台服务器发生故障时,另一台服务器能够立即接管服务,以减少数据丢失和...
在完成了单个MySQL服务器的安装配置之后,接下来需要实现双机热备的配置。这通常涉及以下几个关键步骤: 1. **选择合适的双机热备方案:** - 常见的双机热备方案包括基于MySQL原生的主从复制、Galera集群等。 - ...
在服务器层面,合理配置缓冲池大小(InnoDB缓冲池和MyISAM键缓存)、查询缓存大小等参数,可以有效提高数据库的处理能力。 #### 系统安全与故障排除 在配置双机热备的过程中,系统安全和故障排除同样重要。确保...
08-不停主库一键批量配置MySQL主从复制方案.avi 09-MySQL主从复制3个线程状态信息讲解.avi 10-MySQL主从复制读写分离授权多种方案案例详解.avi 11-忽略MySQL主从复制主库授权表同步实战.avi 12-MySQL主从复制指定...
7. MySQL主从同步的原理 MySQL的主从同步是基于二进制日志实现的,主服务器执行的任何更改(DML和DDL语句)都会被记录到二进制日志中。从服务器连接到主服务器,并请求二进制日志的更新。主服务器将二进制日志发送给...
3. **选择配置文件**:根据服务器内存大小选择合适的MySQL配置文件,如`my-small.cnf`适合于内存小于64M的服务器,而`my-innodb-heavy-4G.cnf`则适用于内存超过4G的服务器。将选中的配置文件复制到`/etc/my.cnf`,以...
11. 单主从冗余环境搭建:设置主库,配置binlog,复制到从库,监控主从同步状态。 12. 主从同步延迟问题解决:优化网络、调整复制延迟策略、使用半同步复制、监控并分析延迟原因。 13. 数据库代理服务器功能:负载...
4. 能方便地创建MySQL主从复制。 5. 备份过程不会增加服务器负载。 xtrabackup备份过程分为两个阶段:备份InnoDB数据,然后备份MyISAM数据,并记录备份信息。对于InnoDB备份,其核心原理是利用InnoDB的事务特性和表...
8. **扩展性**:随着业务增长,可能需要将双机备份扩展到多机集群,如MySQL Cluster或InnoDB Cluster,以支持更大规模的并发和更高的可用性。 9. **故障恢复**:当主服务器恢复后,需要进行故障恢复操作,如重新...
- 高可用架构:主主复制,主从热备,群集,负载均衡。 - 故障切换:自动和手动故障切换,监控和恢复策略。 7. **安全性**: - 用户权限管理:GRANT和REVOKE命令,用户认证,权限分离。 - 加密与审计:数据加密...
#### 三、MySQL服务器配置与优化 - **性能调优**:通过对`my.cnf`配置文件的调整来优化服务器性能。 - **内存配置**:合理设置缓冲池(`innodb_buffer_pool_size`)等内存参数。 - **日志管理**:开启慢查询日志(`...
网盘文件永久链接 目录 ...第13课、Innodb在线热备原理及操作-0215.avi 第14课、基于Binlog的恢复操作-0220.avi 第15课、高可用开篇-0222.avi 第16课、Keepalived原理及双主中的坑-0227.avi ...................
- MySQL支持多种存储引擎,如InnoDB、MyISAM、MEMORY等,每种引擎都有其特定的适用场景。例如,InnoDB支持事务处理和外键约束,适用于需要高一致性和安全性的应用场景;而MyISAM则更适合于读多写少的场景,因其查询...
《高性能MySQL》(第三版) 是一本经典的数据库技术书籍,主要涵盖了MySQL的性能优化、高可用性、可扩展性和安全性等方面的知识。以下是对该书学习笔记和摘要的详细解析: 一、性能优化 1. 查询优化:理解SQL执行的...
- **架构原理**:通过MHA(MySQL High Availability)实现故障自动转移,通常配置一个主数据库和两个从数据库。 - **应用场景**:适用于大型电商平台等需要高可用性的环境。 **Keepalived+双主(主从)架构**: - ...
了解如何配置主从复制,处理复制延迟和故障切换是高可用架构中的重要环节。 9. **性能监控与调优**:使用工具如SHOW STATUS、SHOW VARIABLES、pt-query-digest等进行性能监控,调整参数如innodb_buffer_pool_size、...
MySQL是世界上最受欢迎的关系型数据库管理系统(RDBMS)之一,尤其在Java开发中,MySQL由于其性能高效、易用性和开源特性,被广泛应用于各种规模的项目。以下是一些关于MySQL的重要知识点,这些内容可能会在面试中...
2. **存储引擎**:MySQL支持多种存储引擎,如InnoDB、MyISAM、Memory等。重点是InnoDB,它是默认引擎,支持事务处理和行级锁定。了解它们各自的优缺点和适用场景。 3. **事务处理**:理解ACID(原子性、一致性、...