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

【Apache Camel】基础知识

【Apache Camel】基础知识

  • Apache Camel是什么
  • Apache Camel基本概念和术语
    • CamelContext
    • Endpoints
    • Routes
    • RouteBuilder
    • Components
    • Message
    • Exchange
    • Processors
    • Domain Specific Language(DSL)
  • Apache Camel 应用执行步骤
  • Apache Camel 示意图
  • 参考

Apache Camel是什么

Apache Camel是一个基于 EIP(Enterprise Integration Patterns) 的通用开源集成框架,用于集成各种异构系统,完成异构系统间数据交换和共享。

Apache Camel基本概念和术语

CamelContext

CamelContext 是 Camel 的运行时系统,管理了 Routes、Endpoints、Components、Message 等,工作方式类似 Spring ApplicationContext。通过 CamelContext 可以访问 Components、Endpoints、Routes、Type converters、Data formats、Registry、Languages。
CamelContext

通常应用程序中只有一个 CamelContext,但也可以同时存在多个 CamelContext,但多个 CamelContext 之间彼此需要隔离,如果要在多个 CamelContext 之间通信,则需要加入一个传输层(如消息队列)。

Endpoints

Endpoints 代表了一个可以通过某个地址 URL 进行通信的命名软件实体或资源,可以简单理解为是一个接口。可以从 Endpoints 中检索(Consumer Endpoints)或发送(Producer Endpoints)数据以进行路由及数据操作。
Endpoints
配置 Endpoints 的 URI 格式:

  • Schema:表示哪个 Component 组件处理此类 Endpoint,本例中的 file 表示使用 FileComponentFileComponent 被当做工厂,根据 URI 剩余部分创建 FileEndpoint
  • Context path:上下文路径,本例中配置 FileComponent 的起始文件夹是 data/inbox
  • Options:选项,本例中配置以5s的时间间隔轮询文件。
    Endpoints URI
    Endpoints 充当工厂,用于创建能够接收 Message 的 Consumer,或将 Message 发送到特定 Endpoint 的 Producer。

Endpoint as a factory

Routes

Routes 用于连接源 Endpoints 和目标 Endpoints,Routes 描述了消息从源 Endpoints 到目标 Endpoints 的移动过程。

RouteBuilder

封装了 Camel 运行时使用的规则(Rules)、Endpoints 和 Components,每个 CamelContext 可以包含一个或多个 RouteBuilder,RouteBuilder 被扩展并添加到 CamelContext 中以描述路由规则。通常自定义 RouteBuilder 继承自 org.apache.camel.builder.RouteBuilder

Components

Components 是一个基础构建模块,负责在路由构建过程中创建 Endpoints,Camel 提供了大量内置的 Components,这些 Components 提供了与各种技术和协议的连接。

Message

Message 接口提供了单个消息的抽象表示,如请求消息、回复消息、异常消息。Message 接口 API 提供了 Getter 和 Setter 方法用于访问消息ID、消息体(Body)和消息头(Header)的单个字段。

Exchange

Exchange 接口提供了一次消息交换的抽象表示,一次消息交换是指一个请求消息及其对应的回复或异常消息。Camel 将请求消息、回复消息、异常消息称为 in messages、out messages、fault messages。

Processors

Processors 在消息交换过程中对消息进行处理,可用作消息转换器实现。定义 Routes 时可以添加 Processors 在消息交换过程中执行自定义逻辑。自定义 Processor 需要实现 org.apache.camel.Processor 接口并重写 process() 方法,方法参数为 Exchange 而非 Message
Processors

Domain Specific Language(DSL)

领域特定语言,用于定义 Routes,主要包含三类:

  • XML
  • YAML
  • Java DSL

Apache Camel 应用执行步骤

  1. 创建 CamelContext 对象;
  2. 添加 Endpoints 和 Components;
  3. 在 CamelContext 中添加路由 Routes,连接源 Endpoints 和目标 Endpoints;
  4. 调用 CamelContext 的 start() 方法启动 Camel 内部线程负责发送、接收、处理 Endpoints 中的消息 Message;
  5. 最后,调用 CamelContext 的 stop() 方法,优雅地停止所有的 Endpoints 和 Camel 内部线程。

需要注意:

  • CamelContext 的 start() 方法不会无限期阻塞,在启动了每个 Component 和 Endpoint 的内部线程后就返回了,相反 stop() 方法会等待每个 Endpoint 和 Component 内部的所有线程都终止后才返回;
  • 如果忽略调用 start() 方法,Camel 将不会处理消息,因为内部线程还未创建;
  • 如果终止应用前忽略调用 stop() 方法,那么可能会以不一致的状态终止,如果在 JUnit 测试中忽略调用 CamelContext 的 stop() 方法则可能导致失败,因为消息没有机会得到完全处理。

Apache Camel 示意图

Apache Camel Diagram

参考

  • A Camel tutorial for beginners

相关文章:

  • 关于制作一个Python小游戏(三)
  • Batch Nomalization 迁移学习
  • 【框架学习 | 第一篇】一篇文章读懂MyBatis
  • 2024.1.28 校招 实习 内推 面经
  • 【嵌入式——QT】Model/View
  • 【PHP】PHP通过串口与硬件通讯,向硬件设备发送数据并接收硬件返回的数据
  • 基于Springboot免费搭载轻量级阿里云OSS数据存储库(将本地文本、照片、视频、音频等上传云服务保存)
  • 揭秘共享旅游卡项目变现的6种方式,至少有4种适合创业者!
  • STM32/GD32——I2C通信协议
  • Nodejs web服务器之GET、POST请求初次体验
  • 2024《》
  • 论文研读_多目标部署优化:无人机在能源高效无线覆盖中的应用(ImMOGWO)精简版
  • 100个Linux操作命令和20个常用脚本
  • docker中的具名和匿名挂载
  • MySQL CTEs通用表表达式:进阶学习-递归查询
  • 深入了解以太坊
  • ES6指北【2】—— 箭头函数
  • 4. 路由到控制器 - Laravel从零开始教程
  • Angular js 常用指令ng-if、ng-class、ng-option、ng-value、ng-click是如何使用的?
  • create-react-app做的留言板
  • Js基础知识(四) - js运行原理与机制
  • PV统计优化设计
  • Python_OOP
  • Spring核心 Bean的高级装配
  • zookeeper系列(七)实战分布式命名服务
  • 创建一个Struts2项目maven 方式
  • 对话 CTO〡听神策数据 CTO 曹犟描绘数据分析行业的无限可能
  • 多线程事务回滚
  • 分享一份非常强势的Android面试题
  • 关于Flux,Vuex,Redux的思考
  • 规范化安全开发 KOA 手脚架
  • 极限编程 (Extreme Programming) - 发布计划 (Release Planning)
  • 漂亮刷新控件-iOS
  • 算法-插入排序
  • 微信小程序:实现悬浮返回和分享按钮
  • 写代码的正确姿势
  • 3月7日云栖精选夜读 | RSA 2019安全大会:企业资产管理成行业新风向标,云上安全占绝对优势 ...
  • Python 之网络式编程
  • 测评:对于写作的人来说,Markdown是你最好的朋友 ...
  • 好程序员大数据教程Hadoop全分布安装(非HA)
  • 组复制官方翻译九、Group Replication Technical Details
  • ​【C语言】长篇详解,字符系列篇3-----strstr,strtok,strerror字符串函数的使用【图文详解​】
  • ​一些不规范的GTID使用场景
  • ###C语言程序设计-----C语言学习(3)#
  • #162 (Div. 2)
  • #我与Java虚拟机的故事#连载08:书读百遍其义自见
  • (2009.11版)《网络管理员考试 考前冲刺预测卷及考点解析》复习重点
  • (C语言)球球大作战
  • (echarts)echarts使用时重新加载数据之前的数据存留在图上的问题
  • (solr系列:一)使用tomcat部署solr服务
  • (附源码)springboot青少年公共卫生教育平台 毕业设计 643214
  • (附源码)springboot助农电商系统 毕业设计 081919
  • (附源码)计算机毕业设计ssm电影分享网站
  • (黑马C++)L06 重载与继承
  • (理论篇)httpmoudle和httphandler一览