原文地址:http://blog.itpub.net/22664653/viewspace-1714269/
一 前言
MySQL 的主从复制作为一项高可用特性,用于将主库的数据同步到从库,在维护主从复制数据库集群的时候,作为专职的MySQL DBA,笔者相信大多数人都会遇到“Got fatal error 1236 from master when reading data from binary log” 这类的报错/报警。本文整理了常见的几种 error 1236 报错,并给出相应的解决方法,有所不足之处,当然也希望各位读者朋友指正。
二 常见的error 1236 报错
2.1 logevent超过max_allowed_packet 大小
- Got fatal error 1236 from master when reading data from binary log: 'log event entry exceeded max_allowed_packet; Increase max_allowed_packet on master; the start event position from 'mysql-bin.006730' at 290066246, the last event was read from '/u01/my3309/log/mysql-bin.006730
【原因】
此类报错和max_allowed_packet相关。首先max_allowed_packet控制着主从复制过程中,一个语句产生的二进制binlog event大小,它的值必须是1024的倍数 。出现此类错误的常见原因是
1 该参数在主备库的配置大小不一样,主库的配置值大于从库的配置值。 从主库传递到备库的binlog event大小超过了主库或者备库的max_allowed_packet大小。
2 主库有大量数据写入时,比如在主库上执行 laod data,insert into .... select 语句,产生大事务。
当主库向从库传递一个比从库的max_allowed_packet 大的packet ,从库接收该packet失败,并报 “log event entry exceeded max_allowed_packet“。
【如何解决】
需要确保主备配置一样,然后尝试调大该参数的值。
- set global max_allowed_packet =1*1024*1024*1024;
- stop slave;
- start slave
另外,5.6 版本中的 slave_max_allowed_packet_size 参数控制slave 可以接收的最大的packet 大小,该值通常大于而且可以覆盖 max_allowed_packet 的配置, 进而减少由于上面的问题导致主从复制中断。
2.2 slave 在主库找不到binlog文件
- Got fatal error 1236 from master when reading data from binary log:
【原因】
该错误发生在从库的io进程从主库拉取日志时,发现主库的mysql_bin.index文件中第一个文件不存在。出现此类报错可能是由于你的slave 由于某种原因停止了好长一段是时间,当你重启slave 复制的时候,在主库上找不到相应的binlog ,会报此类错误。或者是由于某些设置主库上的binlog被删除了,导致从库获取不到对应的binglog file。
【如何解决】
1 为了避免数据丢失,需要重新搭建slave 。
2 注意主库binlog的清理策略,选择基于时间过期的删除方式还是基于空间利用率的删除方式。
不要使用rm -fr 命令删除binlog file,这样不会同步修改mysql_bin.index 记录的binlog 条目。在删除binlog的时候确保主库保留了从库 show slave status 的Relay_Master_Log_File对应的binlog file。
2.3 主库空间问题,日志被截断
- Got fatal error 1236 from master when reading data from binary log: 'binlog truncated in the middle of event; consider out of disk space on master; the start event position from 'mysql-bin.006730' at 290066434, the last event was read from '/u01/my3309/log/mysql-bin.006730
【原因】
该错误和主库的空间问题和sync_binlog配置有关,当主库 sync_binlog=N不等于1且磁盘空间满时,MySQL每写N次binary log,系统才会同步到磁盘,但是由于存储日志的磁盘空间满而导致MySQL 没有将日志完全写入磁盘,binlog event被截断。slave 读取该binlog file时就会报错"binlog truncated in the middle of event;"
当sync_binlog 的默认值是0,像操作系统刷其他文件的机制一样,MySQL不会同步到磁盘中去而是依赖操作系统来刷新binary log。
当sync_binlog =N (N>0) ,MySQL 在每写 N次 二进制日志binary log时,会使用fdatasync()函数将它的写二进制日志binary log同步到磁盘中去。
【如何解决】
在从库重新指向到主库下一个可用的binlog file 并且从binlog file初始化的位置开始
- stop slave;
- change master to master_log_file='mysql-bin.006731', master_log_pos=4;
- start slave;
2.4 主库异常断电,从库读取错误的position
- 120611 20:39:38 [ERROR] Error reading packet from server: Client requested master to start replication from impossible position ( server_errno=1236)
- 120611 20:39:38 [ERROR] Slave I/O: Got fatal error 1236 from master when reading data from binary log: 'Client requested master to start replication from impossible position', Error_code: 1236
- 120611 20:39:38 [Note] Slave I/O thread exiting, read up to log 'mysql-bin.000143', position 664526789
【原因】
该问题也是和sync_binlog=N不等于1有关,多出现在主机异常crash ,比如磁盘损坏,raid 卡损坏,或者主机异常掉电导致binlog 未及时同步到磁盘。从库读取了主库binlog file中的不存在的binlog position ,一般比binlogfile 的end position 的值还要大。
【如何解决】
1 在从库重新指向到主库下一个可用的binlog file 并且从binlog file初始化的位置开始
- stop slave;
- change master to master_log_file='mysql-bin.000144', master_log_pos=4;
- start slave;
2 主备库设置 sync_binlog=1,但是设置为1的时候,会带来性能下降。
三 相关阅读
1 max_allowed_packet 官方介绍
2 Percona MySQL的特性 max_binlog_files
3 sync_binlog innodb_flush_log_at_trx_commit 浅析
相关推荐
Mysql主从同步的Last_IO_Errno:1236...Last_IO_Error: Got fatal error 1236 from master when reading data from binary log: 'Slave can not handle replication events with the checksum that master is configur
1. **错误识别**:在描述中提到的错误`Last_IO_Error: Got fatal error 1236 from master when reading data from binary log...`通常表示从库在尝试读取主库的二进制日志时遇到了问题,可能是由于日志文件丢失或者...
#### 错误三:`fatal error: gnu/stubs.h: No such file or directory` **原因分析**:此错误表明编译器在寻找`gnu/stubs.h`文件时未能找到。这个文件是GNU C库的一部分,对于构建交叉编译器来说非常重要。 **解决...
一、简介 主从复制的原理本站的其他文章已经介绍得很详细了,这里不再赘述。简单概况一下就是:从端服务器获取主端服务器的操作日志,并对其进行解析,再在从端复现同样的操作...Got fatal error 1236 from master whe
Got fatal error 1236 from master when reading data from binary log: ‘Client requested master to start replication from position > file size; the first event ‘mysql-bin.000342’ at 1028687822, the ...
在配置过程中,如果遇到`Slave_IO_Running`为`NO`,并且报错`Got fatal error 1236 from master when reading data from binary log`,这通常意味着从服务器无法处理主服务器上的某些事件。可能的原因包括版本不兼容...
今天我上网站的管理后台,登录时提示 MySQL error:Can’t create/write to file ‘#sql_5c0_0.MYD’ ...解决思路和原因: 1、权限问题 C:/WINDOWS/TEMP文件夹权限不够,最少要给出USERS组的可读可写权限、
3. **文件和目录操作**:接下来,使用提供的方法创建、修改或删除文件和目录。 ```go f, err := fs.Create("myfile.txt") if err != nil { t.Fatal(err) } defer f.Close() f.WriteString("Hello, World!") ...
在Golang中,单元测试是开发过程中的重要组成部分,它能帮助我们确保代码的质量和功能的正确性。本文将基于给定的标题“Golang单元测试快速上手 示例代码”和描述,深入讲解如何在Go语言中进行单元测试,并通过实际...
printf( stderr, "Got fatal error processing query\n" ); exit(1); } process_result_set(result); /* client function */ mysql_free_result(result); } while( !mysql_next_result( mysql ) ); ``` 这段...
Go的`testing`包还提供了各种断言方法,如`t.Fatal`和`t.Error`,用于在测试失败时打印错误信息。 为了进行更全面的测试,我们还可以使用依赖注入和mocking技术。Go中的`github.com/stretchr/testify`库提供了丰富...
测试函数通常使用`t.Fatal`或`t.Error`来报告失败,如果测试未达到预期结果。例如: ```go func TestAdd(t *testing.T) { result := add(1, 2) if result != 3 { t.Fatal("Expected 3, got", result) } } ``...
### Go语言中文PDF文档知识点概览 #### 一、简介 ...通过以上内容,我们不仅可以了解到Go语言的基础知识,还可以深入了解其高级特性和应用场景,这将有助于开发者更好地掌握Go语言,从而写出高质量的程序。
3. **断言**:`*testing.T`对象提供了多种断言方法,如`t.Fatal`、`t.Error`和`t.Log`。这些方法用于检查预期结果与实际结果是否相符,如果测试失败,它们会停止当前测试并打印错误信息。 ```go func TestMain(t *...