`

mysql主从热备配置(含innodb)终极版

 
阅读更多

转自 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 
分享到:
评论

相关推荐

    MySQL双机热备

    **MySQL双机热备**是一种通过配置使得两台MySQL服务器之间能够实时同步数据的技术方案,从而实现高可用性和故障转移的能力。该技术可以确保在一台服务器发生故障时,另一台服务器能够立即接管服务,以减少数据丢失和...

    mysql双机热备

    在完成了单个MySQL服务器的安装配置之后,接下来需要实现双机热备的配置。这通常涉及以下几个关键步骤: 1. **选择合适的双机热备方案:** - 常见的双机热备方案包括基于MySQL原生的主从复制、Galera集群等。 - ...

    nginx+php+mysql+heartbeat配置双机热备文档.pdf

    在服务器层面,合理配置缓冲池大小(InnoDB缓冲池和MyISAM键缓存)、查询缓存大小等参数,可以有效提高数据库的处理能力。 #### 系统安全与故障排除 在配置双机热备的过程中,系统安全和故障排除同样重要。确保...

    2017最新老男孩MySQL高级专业DBA实战课程全套【清晰不加密】,看完教程月入40万没毛病

    08-不停主库一键批量配置MySQL主从复制方案.avi 09-MySQL主从复制3个线程状态信息讲解.avi 10-MySQL主从复制读写分离授权多种方案案例详解.avi 11-忽略MySQL主从复制主库授权表同步实战.avi 12-MySQL主从复制指定...

    MySQL技能测试题目

    7. MySQL主从同步的原理 MySQL的主从同步是基于二进制日志实现的,主服务器执行的任何更改(DML和DDL语句)都会被记录到二进制日志中。从服务器连接到主服务器,并请求二进制日志的更新。主服务器将二进制日志发送给...

    linux双机热备

    3. **选择配置文件**:根据服务器内存大小选择合适的MySQL配置文件,如`my-small.cnf`适合于内存小于64M的服务器,而`my-innodb-heavy-4G.cnf`则适用于内存超过4G的服务器。将选中的配置文件复制到`/etc/my.cnf`,以...

    mysql笔试题1

    11. 单主从冗余环境搭建:设置主库,配置binlog,复制到从库,监控主从同步状态。 12. 主从同步延迟问题解决:优化网络、调整复制延迟策略、使用半同步复制、监控并分析延迟原因。 13. 数据库代理服务器功能:负载...

    MySQL数据库的备份与恢复之xtrabackup工具的使用1

    4. 能方便地创建MySQL主从复制。 5. 备份过程不会增加服务器负载。 xtrabackup备份过程分为两个阶段:备份InnoDB数据,然后备份MyISAM数据,并记录备份信息。对于InnoDB备份,其核心原理是利用InnoDB的事务特性和表...

    mysql.rar_MYSQL

    8. **扩展性**:随着业务增长,可能需要将双机备份扩展到多机集群,如MySQL Cluster或InnoDB Cluster,以支持更大规模的并发和更高的可用性。 9. **故障恢复**:当主服务器恢复后,需要进行故障恢复操作,如重新...

    从运维角度浅谈MySQL数据库优化 数据库运维.pdf

    为了提高可用性,可以采用MySQL主从复制配合Keepalived实现双机热备,以保障服务的连续性。常用的集群软件包括Keepalived和Heartbeat。 数据库性能优化是运维工程师的重要任务。未经优化的MySQL在普通X86服务器上...

    mysql面试专题.zip

    - 高可用架构:主主复制,主从热备,群集,负载均衡。 - 故障切换:自动和手动故障切换,监控和恢复策略。 7. **安全性**: - 用户权限管理:GRANT和REVOKE命令,用户认证,权限分离。 - 加密与审计:数据加密...

    业界最具影响力MySQL精品文章荟萃(300篇)

    #### 三、MySQL服务器配置与优化 - **性能调优**:通过对`my.cnf`配置文件的调整来优化服务器性能。 - **内存配置**:合理设置缓冲池(`innodb_buffer_pool_size`)等内存参数。 - **日志管理**:开启慢查询日志(`...

    MySQL实战班视频.zip

    网盘文件永久链接 目录 ...第13课、Innodb在线热备原理及操作-0215.avi 第14课、基于Binlog的恢复操作-0220.avi 第15课、高可用开篇-0222.avi 第16课、Keepalived原理及双主中的坑-0227.avi ...................

    mysql性能调优和架构设计--阿里软件的实战

    - MySQL支持多种存储引擎,如InnoDB、MyISAM、MEMORY等,每种引擎都有其特定的适用场景。例如,InnoDB支持事务处理和外键约束,适用于需要高一致性和安全性的应用场景;而MyISAM则更适合于读多写少的场景,因其查询...

    《高性能Mysql》(第三版) 学习笔记、摘要.zip

    《高性能MySQL》(第三版) 是一本经典的数据库技术书籍,主要涵盖了MySQL的性能优化、高可用性、可扩展性和安全性等方面的知识。以下是对该书学习笔记和摘要的详细解析: 一、性能优化 1. 查询优化:理解SQL执行的...

    MySQL主要技术原理和常见高可用架构

    - **架构原理**:通过MHA(MySQL High Availability)实现故障自动转移,通常配置一个主数据库和两个从数据库。 - **应用场景**:适用于大型电商平台等需要高可用性的环境。 **Keepalived+双主(主从)架构**: - ...

    mysql相关资料 有文档

    了解如何配置主从复制,处理复制延迟和故障切换是高可用架构中的重要环节。 9. **性能监控与调优**:使用工具如SHOW STATUS、SHOW VARIABLES、pt-query-digest等进行性能监控,调整参数如innodb_buffer_pool_size、...

    mysql面试题.zip

    MySQL是世界上最受欢迎的关系型数据库管理系统(RDBMS)之一,尤其在Java开发中,MySQL由于其性能高效、易用性和开源特性,被广泛应用于各种规模的项目。以下是一些关于MySQL的重要知识点,这些内容可能会在面试中...

    MySQL数据库高级工程师-面试题-MySQLDBA面试题03-风哥整理面试必过.rar

    2. **存储引擎**:MySQL支持多种存储引擎,如InnoDB、MyISAM、Memory等。重点是InnoDB,它是默认引擎,支持事务处理和行级锁定。了解它们各自的优缺点和适用场景。 3. **事务处理**:理解ACID(原子性、一致性、...

Global site tag (gtag.js) - Google Analytics