文章首发于【博客园-陈树义】,点击跳转到原文Canal同步异常分析:Could not find first log file name in binary log index file

公司搜索相关的业务系统采用了ElasticSearch + Canal实现了实时搜索(详情可参考文章:ElasticSearch + Canal 开发千万级的实时搜索系统)。

最近在查看线上Canal Server日志的时候发现了异常,这直接导致了其中一个数据库停止了数据同步。

从异常信息可以看到是实例为dbxxxx225_photo的实例发生了同步异常,对应的数据库机器为x.x.x.225,异常关键信息为:Could not find first log file name in binary log index file

仔细排查问题日志,还发现有另外一个异常:

这个异常大致意思是无法从该binlog位点(mysql-bin.000231)开始同步。于是我们登录对应的数据库主库,运行show master status\G命令查看主从同步情况:

File: mysql-bin.000298
Position: 323871973
Binlog_Do_DB:
Binlog_Ignore_DB: mysql,test,information_schema,performance_schema,sys
Executed_Gtid_Set:
1 row in set (0.01 sec)

从上面的运行结果可以看到最新的文件是mysql-bin.000298,而Canal Server还在同步位点mysql-bin.000231

我们知道MySQL保存的binlog文件是有限制的,当超过一定限制时,最早的文件会被删除。因此可以初步确定是因为数据库主从同步出现问题,导致Canal Server服务器所同步的binlog文件不存在,最终导致同步异常。

确定了问题所在,接下来就是如何解决问题了。因为binlog文件已经被删除了,所以在binlog位于231-298中间的数据是无法找回的,这导致了部分数据的丢失,但好在这部分数据并不是非常关键的数据,因此一部分的数据丢失可以承受。

因此我的解决方案是直接从最新的binlog位点进行同步。我们知道Canal Server和Canal Client之间的位点同步信息是存储在zookeeper节点中的,因此我们接下来要删除zookeeper上的节点信息,并重启相关服务。

关闭Canal Server、Canal Client

上面是系统简单的业务架构图。如果Canal Server、Canal Client没有关闭,是无法正常删除zookeeper上相应的节点的,所以我们要关闭所有的Canal Server和Canal Client。我一开始在删除的时候,只关闭了Canal Server,没有关闭Canal Client,后来在删除的时候发现无论如何都删除不了其中一个节点。最后将Canal Client也关闭之后,节点成功删除掉了。

所以,第一步就是要关闭所有的Canal Server和Canal Client节点,如果你部署了keepalive,另一台机器的也要关闭。

删除zookeeper节点信息

登录zookeeper所在服务器,使用zkCli.sh脚本进入到命令行。

使用ls命令查看canal正在运行的所有实例信息:

$ls /otter/canal/destinations
db10xxxx225003_photo db10xxxx225003_user ....

之后直接使用rmr节点删除该实例节点下的所有子节点:

rmr /otter/canal/destinations/db10xxxx225003_photo

修改Canal Server同步位点信息

进入Canal Server服务器的conf目录,修改对应实例的instance.properties文件,将其中的canal.instance.master.journal.namecanal.instance.master.position修改为主库中最新的值。其中journal.name表示最新的binlog文件名,master.position表示位点信息。我这里对应的就是下面:

File: mysql-bin.000298  //对应canal.instance.master.journal.name
Position: 323871973     //对应canal.instance.master.position

如果你部署了两台Canal Server组成keepalive,这里可以只修改其中一台Canal Server,因为当成功修改位点信息后,只要zookeeper中有位点信息,Canal Server就不会从本地配置文件读取。

修改完后,直接启动Canal Server,再启动Canal Client,这时候查看Kafka队列是否有增加对应的消息。一般情况下,都没有什么问题。

完成后,如果部署了keepalive,那么将其他的Canal Server和Canal Client都启动一下就可以了。

参考资料

文章首发于【博客园-陈树义】,点击跳转到原文Canal同步异常分析:Could not find first log file name in binary log index file

Canal 同步异常分析:Could not find first log file name in binary log index file的更多相关文章

  1. canal同步异常:当表结构变化时,同步失败

    场景 canal 同步Mysql一段时间后突然失败,报如如下错误: 2021-08-06 16:16:51.732 [MultiStageCoprocessor-Parser-Twt_instance ...

  2. Got fatal error 1236 from master when reading data from binary log: 'Could not find first log file name in binary log index file'系列三:重置主从同步

    1:停止slave服务器的主从同步 stop slave; 2:对Master数据库加锁 flush tables with read lock; 3:备份Master上的数据 mysqldump - ...

  3. 主从同步遇到 Got fatal error 1236 from master when reading data from binary log: 'Could not find first log file name in binary log index file'时怎么解决

    首先遇到这个是因为binlog位置索引处的问题,不要reset slave: reset slave会将主从同步的文件以及位置恢复到初始状态,一开始没有数据还好,有数据的话,相当于重新开始同步,可能会 ...

  4. 【Canal源码分析】整体架构

    本文详解canal的整体架构. 一.整体架构 说明: server代表一个canal运行实例,对应于一个jvm instance对应于一个数据队列 (1个server对应1..n个instance) ...

  5. 【转】Java ConcurrentModificationException 异常分析与解决方案--还不错

    原文网址:http://www.2cto.com/kf/201403/286536.html 一.单线程 1. 异常情况举例 只要抛出出现异常,可以肯定的是代码一定有错误的地方.先来看看都有哪些情况会 ...

  6. LCD显示异常分析——撕裂(tear effect)【转】

    转自:LCD显示异常分析--撕裂(tear effect) 概述 在上一篇<LCD显示异常分析--开机闪现花屏>中,我们一起分析了开机花屏的问题,在这一篇中,我将对LCD撕裂(tear e ...

  7. group_concat函数导致的主从同步异常

    group_concat函数导致的主从同步异常的问题总结 今天在处理一个group_concat函数导致的主从异常的问题,排查过程比较简单,不过第一次遇到这个问题记录一下排查的思路,后面如果再遇到其他 ...

  8. MySQL主从同步异常问题解决Client requested master to start replication from position > file size

    MySQL主从同步异常问题解决Client requested master to start replication from position > file size 一.问题描述 MySQ ...

  9. mysql主从同步异常原因及恢复

    mysql主从同步异常原因及恢复 前言 mysql数据库做主从复制,不仅可以为数据库的数据做实时备份,保证数据的完整性,还能做为读写分离,提升数据库的整体性能.但是,mysql主从复制经常会因为某些原 ...

随机推荐

  1. Android WebView基本使用

    转载请注明出处: http://blog.csdn.net/lowprofile_coding/article/details/77928614 WebView介绍 Android WebView在A ...

  2. chrome开发工具指南(十一)

    检查资源 使用 Application 面板的 Frames 窗格可以按框架组织资源. 您也可以在 Sources 面板中停用 Group by folder 选项,按框架查看资源. 要按网域和文件夹 ...

  3. ajax请求成功前loading

    1.jquery方式 <!DOCTYPE html><html lang="en"><head> <meta charset=" ...

  4. ReentrantLock和synchronized的性能对比

    详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcytpo8 ReentrantLock和内部锁的性能对比     Reentran ...

  5. jvm系列 (五) ---类的加载机制

    类的加载机制 目录 jvm系列(一):jvm内存区域与溢出 jvm系列(二):垃圾收集器与内存分配策略 jvm系列(三):锁的优化 jvm系列 (四) ---强.软.弱.虚引用 我的博客目录 什么是类 ...

  6. WebForm页面间传值方法(转)

    Asp.NET WEB FORMS 给开发者提供了极好的事件驱动开发模式.Asp .NET为我们提供了三种方式,一种是可以通过用QueryString来传送相应的值,再一种是通过session变量来传 ...

  7. 微信录音文件上传到服务器以及amr转化成MP3格式

    微信公众号音频接口开发 根据业务需求,我们可能需要将微信录音保存到服务器,而通过微信上传语音接口上传到微信服务器的语音文件的有效期只有3天,所以需要将文件下载到我们自己的服务器. 上传语音接口 wx. ...

  8. Flask05 cookie

    1 什么是cookie 就是网站存放到你浏览器中的一部分固定内容:当你下次访问我这个网站的时候,你会把之前我存放到你浏览器中的数据带回来给我        你要先登录(用户名.密码) ->   ...

  9. 半个月学习的it内容

    1  基本头部标签: 1 head: HEAD里面主要放一些有关网页设置的相关语句-->2编码格式: 设置网页的字符集编码格式:GB2312,简体中文的编码格式 GBK:扩展的国标码,比国标码多 ...

  10. LaTeX排版指南

    V0.0.1 工具链 CTeX:http://www.ctex.org/HomePage ,CTeX是一个中文套装,但也同时发布一个独立的ctex宏包 TeXLive:https://tug.org/ ...