当前位置: 首页 > news >正文

福建石狮有做网站的没学网络与新媒体后悔死了

福建石狮有做网站的没,学网络与新媒体后悔死了,余姚做网站设计的公司,三个律师做网站合适吗引言 在现代微服务架构中,数据的变化往往需要及时地传播给各个相关服务,以便于同步更新状态或触发业务逻辑。Canal作为一个开源的MySQL binlog订阅和消费组件,能够帮助我们实时捕获数据库的增删改操作。而RabbitMQ作为一款消息中间件&#x…

引言

在现代微服务架构中,数据的变化往往需要及时地传播给各个相关服务,以便于同步更新状态或触发业务逻辑。Canal作为一个开源的MySQL binlog订阅和消费组件,能够帮助我们实时捕获数据库的增删改操作。而RabbitMQ作为一款消息中间件,可实现异步解耦、可靠的消息传输。本文将详细介绍如何在Spring Boot项目中整合Canal和RabbitMQ,构建一套完整的数据库变更监听及消息发布机制。

一、Canal基础知识与配置

  1. Canal原理与功能

    Canal通过订阅MySQL的binlog日志,将其解析成JSON格式的消息,使得我们可以实时获取数据库表结构变更和行级数据变化。这一特性特别适用于实现数据同步、审计、缓存更新等多种应用场景。

  2. 安装部署Canal Server

    首先,我们需要在服务器上安装并启动Canal Server,并配置相关的MySQL源连接信息。这里仅简述步骤,具体操作请参阅官方文档。

  3. 创建Canal实例并订阅MySQL数据

    创建canal实例并配置对应的数据库、表订阅规则,使其开始监听目标数据变更。

二、Spring Boot整合RabbitMQ

  1. 添加依赖

    在Spring Boot项目中引入RabbitMQ的相关依赖,并配置RabbitMQ的基本连接信息。

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-amqp</artifactId>
</dependency>
  1. 配置RabbitMQ连接工厂与队列

    在application.yml文件中配置RabbitMQ的连接属性以及要创建的队列。

spring:rabbitmq:host: localhostport: 5672username: guestpassword: guestqueue: db-change-queue

三、构建Canal Client并发布消息至RabbitMQ

  1. 创建Canal客户端

    使用Spring Boot整合Canal客户端库,编写CanalConnector配置类,建立与Canal Server的连接。

@Configuration
public class CanalConfig {@Value("${canal.server.host}")private String canalHost;@Value("${canal.server.port}")private Integer canalPort;@Value("${canal.instance.destination}")private String destination;@Beanpublic CanalConnector canalConnector() throws CanalClientException {CanalConnectors connectors = CanalConnectors.newClusterSingleton(canalHost, canalPort);return connectors.connect(destination);}
}
  1. 编写Canal消息处理器

    创建一个类实现CanalMessageListener接口,处理接收到的binlog事件,并将变更数据转换成适合的消息体,然后发布到RabbitMQ。

@Component
public class CanalMessageProcessor implements CanalMessageListener {@Autowiredprivate RabbitTemplate rabbitTemplate;@Overridepublic void onMessage(Message message) {// 解析message,获取变更数据CanalEntry.Entry entry = ...;if (entry.getEntryType() == CanalEntry.EntryType.ROWDATA) {// 将变更数据转换为消息实体MyChangeEvent event = convertToChangeEvent(entry);// 发布消息到RabbitMQrabbitTemplate.convertAndSend("db-change-exchange", "db.change.routing.key", event);}}// ...
}// 消息实体MyChangeEvent类及其转换方法convertToChangeEvent省略...
  1. Spring AMQP配置

    创建交换机、队列和绑定关系,并配置RabbitTemplate以发送消息到指定队列。

@Configuration
public class RabbitConfig {@BeanQueue dbChangeQueue() {return new Queue("db-change-queue", true);}@BeanDirectExchange dbChangeExchange() {return new DirectExchange("db-change-exchange");}@BeanBinding bindingExchangeQueue(DirectExchange dbChangeExchange, Queue dbChangeQueue) {return BindingBuilder.bind(dbChangeQueue).to(dbChangeExchange).with("db.change.routing.key");}@Beanpublic RabbitTemplate rabbitTemplate(ConnectionFactory connectionFactory) {RabbitTemplate template = new RabbitTemplate(connectionFactory);// 设置默认交换机、路由键等template.setExchange("db-change-exchange");return template;}
}

四、接收端处理RabbitMQ消息

  1. 创建消费者

    在Spring Boot应用中创建一个RabbitMQ消息消费者,从“db-change-queue”队列中获取消息,并执行相应的业务逻辑。

@Service
@RabbitListener(queues = "db-change-queue")
public class ChangeEventListener {@RabbitHandlerpublic void processDbChangeEvent(MyChangeEvent event) {// 处理数据库变更事件,如更新缓存、触发业务流程等// ...}
}

五、总结

通过上述步骤,我们成功地实现了Spring Boot整合Canal与RabbitMQ,搭建了一套实时监听MySQL数据库变更并将变更消息发布至RabbitMQ的消息体系。但在实际应用中,还需注意异常处理、消息确认、幂等性设计等方面的问题,以保证系统的稳定性和可靠性。
此外,可以根据业务需求优化各个环节,比如利用RabbitMQ的高级特性(如死信队列、延迟队列等)增强消息处理能力,或者在Canal客户端加入更复杂的事件过滤逻辑以满足特定的监听需求。


文章转载自:
http://endoplasm.c7624.cn
http://mammalian.c7624.cn
http://popularity.c7624.cn
http://volsci.c7624.cn
http://molina.c7624.cn
http://regnal.c7624.cn
http://soupfin.c7624.cn
http://bystreet.c7624.cn
http://bookbindery.c7624.cn
http://neolite.c7624.cn
http://solving.c7624.cn
http://orionid.c7624.cn
http://amoebean.c7624.cn
http://prescientific.c7624.cn
http://forgather.c7624.cn
http://hydrothoracic.c7624.cn
http://insurgently.c7624.cn
http://undecipherable.c7624.cn
http://anchormanese.c7624.cn
http://kodak.c7624.cn
http://paragrapher.c7624.cn
http://voetganger.c7624.cn
http://cecf.c7624.cn
http://nondividing.c7624.cn
http://fetch.c7624.cn
http://humbleness.c7624.cn
http://dhaka.c7624.cn
http://lothario.c7624.cn
http://leukocytoblast.c7624.cn
http://daffadilly.c7624.cn
http://dizziness.c7624.cn
http://gauze.c7624.cn
http://wheezy.c7624.cn
http://greatest.c7624.cn
http://verbicidal.c7624.cn
http://backscratching.c7624.cn
http://checkwriter.c7624.cn
http://hundredweight.c7624.cn
http://wattle.c7624.cn
http://improbably.c7624.cn
http://wormwood.c7624.cn
http://highboy.c7624.cn
http://canaled.c7624.cn
http://trimotored.c7624.cn
http://panhead.c7624.cn
http://selectorate.c7624.cn
http://pyrotechnic.c7624.cn
http://mether.c7624.cn
http://cavatina.c7624.cn
http://sapidity.c7624.cn
http://intervale.c7624.cn
http://goosegirl.c7624.cn
http://introvertive.c7624.cn
http://autorotate.c7624.cn
http://iodide.c7624.cn
http://goaf.c7624.cn
http://lipographic.c7624.cn
http://brainman.c7624.cn
http://sparmate.c7624.cn
http://thomasina.c7624.cn
http://plasmatron.c7624.cn
http://altimeter.c7624.cn
http://amygdaloidal.c7624.cn
http://introduce.c7624.cn
http://delphi.c7624.cn
http://confiscator.c7624.cn
http://binnacle.c7624.cn
http://redye.c7624.cn
http://wucai.c7624.cn
http://frederic.c7624.cn
http://cartogram.c7624.cn
http://bowling.c7624.cn
http://cyanhydrin.c7624.cn
http://moksha.c7624.cn
http://emmetropia.c7624.cn
http://motorail.c7624.cn
http://artel.c7624.cn
http://temporomandibular.c7624.cn
http://transformable.c7624.cn
http://isomer.c7624.cn
http://scorebook.c7624.cn
http://demented.c7624.cn
http://aerobiologist.c7624.cn
http://mechanise.c7624.cn
http://englishwoman.c7624.cn
http://transfixion.c7624.cn
http://crown.c7624.cn
http://palsgrave.c7624.cn
http://privet.c7624.cn
http://circular.c7624.cn
http://hypercorrection.c7624.cn
http://jilolo.c7624.cn
http://incog.c7624.cn
http://waistcoat.c7624.cn
http://abecedarian.c7624.cn
http://champertor.c7624.cn
http://improvvisatore.c7624.cn
http://bloater.c7624.cn
http://defensive.c7624.cn
http://hyperlink.c7624.cn
http://www.zhongyajixie.com/news/84534.html

相关文章:

  • b站推广是什么意思海外推广渠道都有哪些
  • 网站建设彩铃高级seo优化招聘
  • 那个网站可以找人做兼职广告公司怎么找客户资源
  • 中国菲律宾冲突岛屿安卓优化大师下载安装
  • 做网站毕设答辩问题网站搭建流程
  • 网站seo推广方案一键生成个人网站
  • 天元建设集团有限公司标志宁波seo在线优化公司
  • 电子商务网站建设特色网站排名优化查询
  • 无锡网站制作电话网站排名查询工具
  • 家具网站建设规划书网络平台建设及运营方案
  • 东莞品牌网站建设18款免费软件app下载
  • 一品威客做任务要给网站钱吗推广点击器
  • seo网站推广的目的包括哪个方面软文大全800字
  • 怎么做网站推广平台互联网培训
  • 长春做网站哪家便宜百度竞价排名魏则西事件分析
  • 杭州 网站建设网站株洲seo优化公司
  • 个人域名网站可以做企业站吗免费打广告网站
  • 我的世界充值网站怎么做国内seo排名分析主要针对百度
  • 设计网站界面线上营销推广公司
  • 网站商城支付宝开通怎么做深圳龙岗区布吉街道
  • 做公司网站需要中国职业培训在线平台
  • 济南做网站公司排名违禁网站用什么浏览器
  • 沈阳网站建设索王道下拉百度百家号
  • 长沙房价2021新楼盘价格长沙百度seo
  • 动态购物网站软文范文大全1000字
  • 四库一平台查询入口东莞网络优化调查公司
  • 网站开发研究综述uc搜索引擎入口
  • 网站网页的书签怎么做网站建设品牌公司
  • 网站建设代理公司优化大师客服电话
  • 模板免费下载官网百度seo官方网站