游戏电视苹果数码历史美丽
投稿投诉
美丽时装
彩妆资讯
历史明星
乐活安卓
数码常识
驾车健康
苹果问答
网络发型
电视车载
室内电影
游戏科学
音乐整形

canal一个MYSQL增量日志解析神器

  canal是什么
  canal〔knl〕,译意为水道管道沟渠,主要用途是基于MySQL数据库增量日志解析,提供增量数据订阅和消费,目前主要支持了mysql。工作原理
  原理图canal模拟MySQLslave的交互协议,伪装自己为MySQLslave,向MySQLmaster发送dump协议MySQLmaster收到dump请求,开始推送binarylog给slave(即canal)canal解析binarylog对象(原始为byte流)使用场景
  基于日志增量订阅消费支持的业务:数据库镜像数据库实时备份多级索引(卖家和买家各自分库索引)searchbuild业务cache刷新价格变化等重要业务消息快速开始
  准备
  要使用canal必须要开启binlog,通过下面语句可以查看binlog是否开启,关于binlog的文章请移步到showvariableslikelogbin
  开启配置
  OFF表示没有开启,那么就需要开启binlog,找到mysql配置文件,windows系统配置文件名为my。ini,Linux系统配置文件名为my。conf。
  如果不知道配置文件的位置在哪,可以通过SELECTdatadir语句查看文件位置
  查询文件位置
  配置文件会在datadir的上一级目录中。
  找到配置文件之后,添加如下配置表示开启binloglogbinmysqlbin开启binlogbinlogformatROW选择ROW模式
  修改完配置文件之后重启mysql,再使用showvariableslikelogbin语句查看binlog是否开启,ON表示开启。
  查询是否开启
  下载
  下载链接:https:github。comalibabacanalreleases,目前最新的版本是1。1。6
  下载版本
  配置
  下载之后解压,得到如下文件夹
  解压文件
  进入到confexample文件加下,修改instance。properties配置positioninfo,需要改成自己的数据库信息canal。instance。master。address127。0。0。1:3306canal。instance。master。journal。namecanal。instance。master。positioncanal。instance。master。timestampcanal。instance。standby。addresscanal。instance。standby。journal。namecanal。instance。standby。positioncanal。instance。standby。timestampusernamepassword,需要改成自己的数据库信息canal。instance。dbUsernamerootcanal。instance。dbPassword1234canal。instance。connectionCharsetUTF8tableregex数据库表的过滤canal。instance。filter。regexdbtest。
  这里配置的是本地数据dbtest,里面有张user表CREATETABLEuser(idbigint(20)NOTNULLAUTOINCREMENTCOMMENTid,usernamevarchar(40)NOTNULLDEFAULTCOMMENT全名,gendertinyint(2)NOTNULLDEFAULT0COMMENT性别,createdatedatetimeNOTNULLCOMMENT创建时间,PRIMARYKEY(id))ENGINEInnoDBAUTOINCREMENT14DEFAULTCHARSETutf8mb4COMMENT用户表
  启动
  进入到解压后的bin文件夹下,双击startup。bat或者通过命令行启动
  启动
  然后进入logscanal文件夹下查看canal。log文件,出现以下界面表示成功
  查询日志文件实操
  canal1。1。1版本之后,默认支持将canalserver接收到的binlog数据直接投递到MQ,目前默认支持的MQ系统有:kafka、RocketMQ、RabbitMQ、pulsarmq。
  本篇文章将使用springbootcanalRocketMQ进行一次简单的实操,如果项目中用不到消息队列也可参考官网示例使用https:github。comalibabacanalwikiClientExample,这里就不多赘述。
  准备实操前要先把rocketmq安装好,关于rocketmq的安装这里也不过多赘述,可以看这篇文章RocketMq系列】rocketmq安装教程修改instance配置文件confexampleinstance。propertiesmqconfig要发送到的topiccanal。mq。topicconsumertopic针对库名或者表名发送动态topiccanal。mq。dynamicTopicmytest1。user,topic2:mytest2。。,。。。canal。mq。partition0hashpartitionconfigcanal。mq。enableDynamicQueuePartitionfalsecanal。mq。partitionsNum3canal。mq。dynamicTopicPartitionNumtest。:4,mycanal:6库名。表名:唯一主键,多个表之间用逗号分隔canal。mq。partitionHashtest。table:idname,。。。修改canal配置文件confcanal。properties默认为tcp,可选项:tcp,kafka,rocketMQ,rabbitMQ,pulsarMQcanal。serverModerocketMQRocketMQ生产者组rocketmq。producer。groupcanalproducergrouprocketmq。enable。message。tracefalserocketmq。customized。trace。topicrocketmq。namespacerocketmq。namesrv。addr127。0。0。1:9876rocketmq。retry。times。when。send。failed0rocketmq。vip。channel。enabledfalserocketmqtag标签rocketmq。tag
  修改完重启一下canal。
  集成到springboot中新建一个springboot项目,引入依赖
  canal把数据都发送到了mq里面,所以这里可以不引入canal的依赖,直接从rockemq中获取数据即可。dependencygroupIdorg。apache。rocketmqgroupIdrocketmqspringbootstarterartifactIdversion2。1。1versiondependency修改配置server。port8090rocketmq。nameserverlocalhost:9876消费者组rocketmq。producer。groupcanalproducergroup消息发送rocketmq。producer。retrytimeswhensendasyncfailed2消息发送失败重试次数,默认为2rocketmq。producer。retrytimeswhensendfailed2rocketmq。consumer。topicconsumertopicrocketmq。consumer。groupconsumergroup新建一个RocketMQListener实现类RocketMQMessageListener(topic{rocketmq。consumer。topic},consumerGroup{rocketmq。consumer。group})ComponentpublicclassCanalListenerimplementsRocketMQListenerMessageExt{OverridepublicvoidonMessage(MessageExtmessage){finalbyte〔〕bodymessage。getBody();System。out。println(newString(body,StandardCharsets。UTF8));}}测试
  修改表中一条记录信息UPDATEdbtest。userSETid13,usernameusername13,gender1,createdate2022090910:13:53WHERE(id13);
  控制台会打印一条如下数据:{data:〔{createdate:2022090910:13:53,gender:1,id:13,username:username13}〕,database:dbtest,es:1665633148000,id:8,isDdl:false,mysqlType:{createdate:datetime,gender:tinyint(2),id:bigint(20),username:varchar(40)},old:〔{createdate:2022090910:18:53,username:username133}〕,pkNames:〔id〕,sql:,sqlType:{createdate:93,gender:6,id:5,username:12},table:user,ts:1665633148529,type:UPDATE}
  数据解释:data:修改前的字段和数据database:数据库名old:修改字段和数据table:表名type:事件类型。INSERT、UPDATE、DELETE、CREATE等mysqlType:字段名及数据结构isDdl:是否是DDL操作pkNames:主键名
  至此,一个canal的简单入门就完成了,感兴趣的可以更深入的了解一下。
  参考资料:
  https:github。comalibabacanalwiki

月子中心最大的作用是炫富,但为何超7成月子中心都在赔钱?文华商韬略王寒赵昱看起来是稳赚不赔,实际上却是赔的多赚的少。这样一门生意,能诞生下一个巨头吗?【1】在爱帝宫官网首页,黄磊、孙红雷、梅婷等明星家庭的照片……50狂胜!AC米兰毫不留情8分钟3球打花弱旅,21岁天才爆发一场季前热身赛,AC米兰客场对阵沃尔夫斯贝格。上半场比赛,莱奥和雷比奇相继破门,下半场梅西亚斯、阿德利和加比亚连进3球,AC米兰50狂胜对手,完全可以用残暴来形容。AC米……下课!一场丑陋的比赛中国男篮通过加时8067战胜巴林,没看错,居然是加时。巴林篮球队世界排名100多,通过对伊朗的比赛,本以为是一场大比分的胜利!没想到可以说胜得如此丑陋,巴林一个150万人……去布吉岛,怎么玩才有意思?满满的干货计划去布吉岛旅游?那么接下来就是准备出行了!下面是一份500字左右的布吉岛旅游指南,可以帮助你有效地准备旅行:1。各种证件:要想去布吉岛,最好带上护照、机票等相关证件,准……新赛季等我回来!打野宁王发布试训视频,我的规矩就是规矩前言:S11赛季的比赛已经全部结束了,相信绝大多数的玩家都关注了最近一段时间的转会期,lpl赛区的整体人员变动是非常大的,各大战队基本上都已经陆续官宣了自己的最新阵容,整个的春……春季养生有什么讲究春天是一个万物复苏的季节,我们生活在大自然之间,跟随着季节的变化而变化。春天的到来,春季养生的时间也跟着开始了。桃花和柳树那么春季养生有什么讲究呢?春季养生,……有没有大侠知道木瓜怎么做酒?此酒可丰胸,壮阳,袪风湿!食材明细木瓜、米酒、冰糖。1、洗净表皮,凉干或擦干2、去头3、去尾4、去籽就剩下6斤了,切片,5毫米厚左右5……旅游到底是跟团好还是是自由行好这个问题其实需要一分为二来看,我之前跟过一个团去青岛,总体来说就是省心,旅游车把你拉到高铁站,有人提前等候,把车票送到手上,之后就是到站有人接。跟团游其实就是傻瓜式旅游,不用你……时钟逻辑类型接口LVDS简述在硬件开发过程中,涉及高速时钟或者数据接口时,均会遇到LVDS(Lowvoltagedifferentialsignaling)这种技术接口。引用百度百科文献:LVDS(……假期消息面很多,但主要有七条消息影响明天大盘走势一是央行下调首套个人住房公积金贷款利率0。15个百分点这是节日放假释放的第一条利好,但在节前房地产板块已经出现大涨,不排除有对这条消息利好兑现的预期,但节后港股大涨,主要……问问大家你们家里每天吃的剩饭剩菜怎么处理的?下一顿吃,下顿吃不完,下下顿吃,直到吃完为止!想想三年自然灾害,红军两万五千里长征,树皮草根都吃不上,怎么还忍心把剩下的饭菜,毫不犹豫的扔掉!寿命长短,身体健康如否……原来吃虾皮并不补钙?提醒真正补钙的4种食物,很多人并不爱吃王女士的儿子东东今年13岁了,最近她儿子总说,晚上睡觉的时候腿会一抽一抽,有时候还会很痛。王女士想应该是小孩长身体,缺钙导致的腿抽筋,于是在网上寻找补钙的方法,她看到很多……
豆瓣7。8分,林心如大尺度悬疑剧,会让多少内地导演脸红曾经的国产悬疑剧一部接一部的出爆款,从《白夜追凶》到《无证之罪》,再到《沉默的真相》,《隐秘的角落》,每一部都是口碑之作,尺度也一步步的突破。但2020年之后,国产悬疑剧就又一……朋友送了几件摘要酒,有懂行的吗?我怎么没听过这酒呀?摘要酒,还是算不错的酱香酒了。摘要酒是贵州省毕节市金沙县的贵州金沙窖酒酒业核心产品之一,采取回沙工艺酿造的,其酒体风格和茅台酒风格略有不同。摘要酒是贵州金沙酒业集团……Q1芯片市场高通收益第一,发哥出货量第一近日市场调研机构StrategyAnalytics发布了2022年Q1全球智能手机应用处理器市场情况:收益同比增长了35,总计达到了89亿美元。高通、联发科、苹果、三星和紫光展……炮兵连三进阵地,向胜利前进百年大党,风华正茂!今年是中国共产党成立100周年!值此之际,解放军报微信熄灯号特别推出四史微讲堂栏目,讲述红色经典,弘扬先辈精神。四史知识问答1985年6月……2022年智能手表怎么选智能手表推荐现在很多小伙伴已经不再满足于机械手表的单一功能,而是把更多的注意力放在智能手表之上,因为现在的智能手表不但拥有健康监测、运动数据监测、移动支付等功能,而且在外观设计上也更加轻便……消息称苹果CEO库克与中国达成2750亿美元交易,奠定成功事IT之家12月8日消息,今天,TheInformation发布了一份冗长的报告,介绍了苹果首席执行官蒂姆库克为在苹果在中国发展所做的努力,从而为苹果在中国亮眼的成绩铺平了道路。……家长不理解孩子,总是活在抱怨的状态里,家庭就一定会面临孩子为何频频自杀?家长的教育真的对吗?今年的9月1号,光重庆市就有14个学生跳楼自杀。开学了当天,如果你去问这14个孩子是怎么死的,你会发现其中有一个只是因为他要去上学,……生产队时期过年啃骨头我们国家有句俗话:谁家过年不吃顿饺子?不但饺子,但凡有一点条件,过年都得炖点肉。我出生于六十年代中期,没经历过挨饿的时候。对于过年,有清晰记忆是1977年,过年的时候,我……为什么一些人要把占女人便宜说成吃豆腐?有什么典故和讲究?吃豆腐就是占异性便宜民间早有传统豆腐本是一种普通的食物,为什么老百姓要把占女人便宜称吃豆腐呢,这背后有个历史典故。据记载,豆腐这种食品是汉代淮南王刘安在炼制丹药过程中无意……火箭热火商讨5换2交易,戈登辅佐巴特勒!火箭接手9000万垃北京时间8月27日,NBA进入休赛期。热火上赛季季后赛的表现非常出色,不被看好的他们连克强敌,成功挺进东部决赛,决赛当中也是抢七大战惜败凯尔特人无缘总决赛,非常令人惊喜。不过迈……腊肉的腌制配方腊肉的腌制配方腊肉是指肉经腌制后再经过烘烤(或日光下曝晒)的过程所制成的加工品。腊肉的防腐能力强,能延长保存时间,并增添特有的风味,这是与咸肉的主要区别。做法一:……云南有哪些看起来就吓人,吃起来更吓人的美食?云南少数民族多,民风自然也要比其它地方彪悍一些。来过云南的人,在云南市场上、餐馆里、或是路边,都能看见一些奇奇怪怪,甚至是恐怖的食物,吃起来都需要勇气!血拌肉血拌肉……
友情链接:易事利快生活快传网聚热点七猫云快好知快百科中准网快好找文好找中准网快软网