apache camel_什么时候使用Apache Camel?

apache camel

Apache Camel是JVM / Java环境中我最喜欢的开源框架之一。 它可以轻松集成使用多种协议和技术的不同应用程序。 本文介绍了何时使用Apache Camel以及何时使用其他替代方法。

问题:企业应用程序集成(EAI)

由于新产品和新应用,几乎每个公司都必须进行企业应用程序集成。 集成这些应用程序会产生一些问题。 每十年出现新的范例,例如客户端/服务器通信,面向服务的体系结构(SOA)或云计算。

此外,出现了不同的接口,协议和技术。 如今(而不是在过去(很多年前))将数据存储在文件中,现在经常使用SQL数据库。 有时,在某些用例中甚至需要NoSQL数据库。 同步远程过程调用或异步消息传递用于通过多种技术(例如RMI,SOAP Web服务,REST或JMS)进行通信。 存在许多软件孤岛。 尽管如此,这几十年来的所有应用程序和产品都必须相互通信才能完美地协同工作。

企业集成模式(EIP)

当然,您可以为每个问题重新发明轮子,编写一些意大利面条式代码,并使应用程序协同工作。 不幸的是,您的管理层将不喜欢该解决方案的长期前景。

企业集成模式(www.eaipatterns.com)帮助解决问题并使用标准化方法集成应用程序。 使用这些,您总是使用相同的概念来转换和路由消息。 因此,一个好主意是每次遇到问题时都不要重新发明轮子。

集成系统的替代方法

存在用于集成应用程序的三种选择。 EIP可以在每种解决方案中使用。

解决方案1:自己的自定义解决方案

实施适合您的问题的单独解决方案,而不必将问题分成几小部分。 这可行,并且可能是小型用例的最快替代方案。 您必须自己编写所有代码。 如果团队成员更换,维护成本可能会很高。

解决方案2:集成框架

使用有助于使用几种集成模式以标准化方式集成应用程序的框架。 它大大减少了工作量。 每个开发人员都将很容易理解您的工作(如果他知道所使用的框架)。

解决方案3:企业服务总线(ESB)

使用企业服务总线来集成您的应用程序。 在幕后,ESB还使用了集成框架。 但是还有更多功能,例如业务流程管理,注册表或业务活动监视。 通常,您可以在图形用户界面中配置路由和诸如此类的东西–您必须自己决定是否可以降低复杂性和工作量。 通常,ESB是一个复杂的产品。 学习曲线要​​高得多。 但是,您将获得一个非常强大的工具,该工具应该可以满足您的所有需求。

什么是Apache Camel?

Apache Camel是一个轻量级的集成框架,可实现所有EIP。 因此,您可以使用所需的模式轻松集成不同的应用程序。 您可以使用Java,Spring XML,Scala或Groovy。 您可以想象到的几乎每种技术都可以使用,例如HTTP,FTP,JMS,EJB,JPA,RMI,JMS,JMX,LDAP,Netty,还有很多(当然,大多数ESB都提供了对它们的支持)。 此外,可以非常轻松地创建自己的自定义组件。

您可以将Apache Camel作为独立的应用程序部署在Web容器(例如Tomcat或Jetty),JEE应用程序服务器(例如JBoss AS或WebSphere AS),OSGi环境中或与Spring容器结合使用。

如果您需要有关Apache Camel的更多信息,请以其网站为起点: http : //camel.apache.org 。 本文暂无技术介绍J

什么时候使用Apache Camel?

如果要集成具有不同协议和技术的多个应用程序,Apache Camel很棒。 为什么? 我非常欣赏其中一项功能(除了支持多种技术之外,还支持不同的编程语言): 每个集成都使用相同的概念! 无论您使用哪种协议。 无论您使用哪种技术。 无论您使用哪种领域专用语言(DSL),它都可以是Java,Scala,Groovy或Spring XML。 您以相同的方式进行操作。 总是! 有生产者,有消费者,有端点,有EIP,有自定义处理器/ bean(例如用于自定义转换),还有参数(例如用于凭证)。

这是一个包含使用Java DSL的所有这些概念的示例:

from(„ activeMQ:orderQueue“).. transaction()。log(„ processing order“)。to(mock:“ notYetExistingInterface”)

现在让我们看一下使用Scala DSL的另一个示例:

“ file:incomingOrders?noop = true”过程(新的TransformationProcessor)到“ jdbc:orderDatastore”

如果您是开发人员,那么您应该能够认识到这些路线的作用,不是吗?

另外两个非常重要的功能是对错误处理(例如使用死信队列)的支持和自动测试。 使用JUnit的Camel扩展,您可以非常轻松地测试一切! 同样,无论您要支持哪种技术,您都始终使用相同的概念。

Apache Camel已经成熟并且可以生产了。 它提供可伸缩性,事务支持,并发和监视。 FuseSource可提供商业支持: http : //fusesource.com/products/enterprise-camel

什么时候不使用Apache Camel?

好吧,是的,在某些用例中,我不使用Apache Camel。 我已经在下图中说明了这一点(请记住我上面提到的三种选择:自己的自定义集成,集成框架,企业服务总线)。

如果您只需要集成一种或两种技术,例如读取文件或发送JMS消息,则使用一些众所周知的库(例如Apache Commons IO或Spring JmsTemplate)可能会更容易,更快捷。 但是请务必使用这些帮助程序类,纯净的File或JMS与try-catch-error集成非常丑陋!

尽管FuseSource提供了商业支持,但我不会将Apache Camel用于大型集成项目。 在大多数情况下,ESB是完成此任务的正确工具。 它提供了许多其他功能,例如BPM或BAM。 当然,您也可以使用几个单一的框架或产品并“创建”您自己的ESB,但这是浪费时间和金钱(在我看来)。

已经有几种生产就绪的ESB。 通常,开源解决方案比诸如WebSphere Message Broker之类的商业产品要轻巧(安装该产品的评估版可能需要一两天的时间!)! 著名的开源ESB是Apache ServiceMix,Mule ESB和WSO2 ESB。 顺便说一句:您是否知道某些基于Apache Camel框架的ESB(例如Apache Service Mix和Talend ESB)。 因此,如果您喜欢Apache Camel,也可以使用Apache ServiceMix或基于ServiceMix的商业化Fuse ESB。

结论

Apache Camel是一个很棒的框架,用于将应用程序与不同的技术集成在一起。 最好的事情是您始终使用相同的概念。 此外,对许多技术的支持,良好的错误处理和轻松的自动测试使其可以用于集成项目。

由于每个公司的应用程序和技术的数量将进一步增加,因此Apache Camel拥有美好的未来。 今天,我们有了应用程序孤岛,十年后,我们很可能会部署在Goggle App Engine,CloudFoundry,Amazon EC3或任何其他云服务中的云孤岛。 因此,我希望Apache Camel也不要为适应云时代做好准备(例如,通过提供易于连接到云框架的组件)。 但这就是未来。如果您必须在JVM / Java环境中集成应用程序,那么现在您真的应该尝试一下该框架。

顺便说一句:我知道我在这篇文章中赞扬Camel,但是我既不是Camel的提交者,也不是FuseSource的工作人员。 我只是真的很喜欢这个框架。

最好的祝福,

参考: 何时使用Apache Camel? 来自我们的JCG合作伙伴 Kai Wahner在有关Java EE / SOA /云计算的博客上的博客。


翻译自: https://www.javacodegeeks.com/2012/07/when-to-use-apache-camel.html

apache camel

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/353229.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

GitHub多人协作简明教程

本文面向已经了解/熟悉git基本命令但是并不熟悉如何使用GitHub进行多人协作开发项目的同学。 为了简单起见,这里假设只有两个开发人员,HuanianLi 和 DaxiangLi。他们在GitHub上的地址和角色为: HuanianLi: https://github.com/huanianli # M…

2020地区mysql表_2020年甘肃省军队文职考试职位表下载:张掖地区招13人

2020年6月15日全军面向社会招考文职人员公告已发布,全国招聘27073人,甘肃省招聘370人,其中张掖地区总共招聘13人。此次考试博士招考岗位报名时间为2020年6月17日至21日,其他招考岗位报名时间为7月1日至10日。考试时间为2020年8月2…

superhot预告片下载_预告片:裸指关节SOA

superhot预告片下载我正在研究这个想法,但我不知道它是否对你们有吸引力。 我想就您是否需要进一步探讨提出您的意见。 这是一笔交易:我遇到了一些团队,这些团队在使用SOA技术时由于其工具的绝对复杂性而陷入泥潭。 我只在Java中看到过这种情…

多少秒算长镜头_下中国象棋,能算多少步才算高手?

下象棋,你能算多少步?这是一个让初学者很困扰,也很感兴趣的话题。 很多象棋爱好者说:我最多看2步,我觉得能看5步以上的,就是超级高手高手高高手了。 但一代象棋宗师、14届全国冠军胡荣华的看法则颇有“玄学…

对基于消息队列的Activiti异步执行器进行基准测试

一点历史 永不停息​​的一件事是,Activiti如何以惊人的规模在一些大型组织中使用。 过去,这导致了各种优化和重构,其中包括异步执行器-替换旧的作业执行器。 对于未启动的用户:这些执行器在流程实例中处理计时器和异步继续。 特别…

2020德勤面试开始了吗_2020公务员面试公告已出,5月28日开始面试

重磅!上海市2020年度考试录用公务员职位报名及面试工作公告出了!报岗时间:2020年5月11日10:00至5月15日18:00岗位调剂:2020年5月18日10:00至5月20日18:00面试时间:2020年5月28日至6月1日面试时需携带哪些证件和材料?答…

阿米洛键盘取消win_阿米洛花旦娘静电容V2键盘测评:不止是一把好看的键盘

文丨me王bigfun社区原文地址:【开箱/测评】阿米洛花旦娘静电容V2键盘,不止是一把好看的键盘 - bigfun序:我想要换一把好的键盘,因为这把雷柏的V500键盘已经跟了我4年,现在的它又老又丑,抚摸起来的手感还很生…

NY : 括号匹配问题

括号配对问题 时间限制&#xff1a;3000 ms | 内存限制&#xff1a;65535 KB难度&#xff1a;3描述现在&#xff0c;有一行括号序列&#xff0c;请你检查这行括号是否配对。 输入第一行输入一个数N&#xff08;0<N<100&#xff09;,表示有N组测试数据。后面的N行输入多…

【代码笔记】Web-ionic-select

一&#xff0c;效果图。 二&#xff0c;代码。 <!DOCTYPE html> <html> <head> <meta charset"utf-8"> <title>Todo</title> <meta name"viewport" content"initial-scale1, maximum-scale1, user-scalableno…

adf开发_ADF:动态视图对象

adf开发今天&#xff0c;我想写有关动态视图对象的信息&#xff0c;该对象允许我在运行时更改其数据源&#xff08;SQL查询&#xff09;和属性。 我将使用oracle.jbo.ApplicationModule :: createViewObjectFromQueryStmt方法来解决此问题。 我将逐步介绍如何执行此操作 创建…

stm32f407能跑linux吗_跑步能跑进医院?那我该做跑步运动吗?想健康一点太难了...

跑步能跑进医院&#xff1f;那我该做跑步运动吗&#xff1f;想健康一点太难了&#xff0c;小编学生时期最喜欢的课程永远都是体育课&#xff0c;但最头疼的项目却是磨人的800米和1000米&#xff0c;那简直是我的的噩梦&#xff0c;近日&#xff0c;西安一名初中生跑步居然跑进了…

60秒内使用Java 9的Project Jigsaw的JavaFX HelloWorld

到目前为止&#xff0c;您可能已经听说过Java 9的新模块系统&#xff0c;即项目Jigsaw。 如果您不了解Java 9的新模块系统&#xff0c;则应访问Mark Reinhold的论文“模块系统的状态” 。 此外&#xff0c;您还应该访问nipafx Nicolai Parlog的出色博客&#xff0c; 网址为http…

互补输出级采用共集形式是为了使_天津大学胡文平《先进材料》:溶液法制备厘米级高度取向有机晶体阵列,可用于高性能有机场效应晶体管...

有机场效应晶体管(OFET)以其低成本和柔性受到了广泛关注&#xff0c;在显示驱动、射频识别标签和逻辑电路等方面具有潜在应用。包括小分子材料和共轭聚合物在内的可溶性有机半导体(OSCs)由于其可溶液加工而引起了许多研究者的兴趣&#xff0c;这种溶液可加工性可通过在柔性基底…

c++ 显示图片_飞利浦256P1FR显示器一线直连MacBook使用体验分享

前言嗨&#xff0c;大家好&#xff0c;我是默咖&#xff0c;一个喜欢分享的数码控。最近刚忙完给媳妇升级桌面&#xff0c;自己就忍不住想要换一个Type-C直连MacBook Pro的显示器了&#xff0c;不仅仅为了可以单线直连MacBook Pro也是为了减少拓展坞再接一个转接头的麻烦&#…

ghost快速安装系统的详细步骤?

很多时候我们安装系统都是在很快的时间内给安装完毕&#xff0c;不用像原来那样安装一个系统需要一个多小时&#xff0c;有了ghost是比较方便&#xff0c;十几分钟就可以把系统安装完&#xff0c;这也是DIY爱好者的福音&#xff0c;没有事情的时候安装下自己的系统&#xff0c;…

python安装库报错Microsoft visual c++ 14.0 is required问题解决办法

下载安装包安装即可&#xff1a; https://964279924.ctfile.com/fs/1445568-239446865 or http://www.liangchan.net/liangchan/10220.html转载于:https://www.cnblogs.com/stkares/p/9384424.html

Apache PDFBox命令行工具:无需Java编码

在博客文章Apache PDFBox 2中 &#xff0c;我演示了将Apache PDFBox 2用作从Java代码中调用的库来操作PDF。 事实证明&#xff0c;Apache PDFBox 2还提供了可以直接从命令行直接使用的命令行工具 &#xff0c;而无需其他Java编码。 有几种命令行工具可用&#xff0c;我将在本文…

在分析了47,251个依赖关系之后,2016年排名前100的Java库

谁在上面&#xff0c;谁在后面&#xff1f; 我们分析了Github上的47,251个依赖关系&#xff0c;并抽取了前100个Java库 长周末我们最喜欢的消遣是浏览Github并搜索流行的Java库。 我们决定与您分享乐趣和信息。 我们分析了Github上前3,862个Java项目使用的12,059个独特Java库…

tortoise清理本地分支_本地:延庆运污水环卫抽化粪池

北京兴百荣清洁公司是清理排水管道的技术服务中心。提供下水道疏通&#xff0c;化粪池清理&#xff0c;抽污水&#xff0c;化粪池清掏&#xff0c;管道清淤&#xff0c;下水道清洗&#xff0c;化粪池清理&#xff0c;抽粪&#xff0c;管道疏通&#xff0c;雨水管道清理&#xf…

win7(windows 7)系统下安装SQL2005(SQL Server 2005)图文教程

由于工作需要&#xff0c;今天要在电脑上安装SQL Server 2005。以往的项目都是使用Oracle&#xff0c;MS的数据库还真的没怎么用过&#xff0c;安装Oracle已经轻车熟路&#xff0c;但装SQL Server好像还有点小麻烦&#xff0c;所以记录下来&#xff0c;以留备用。 ------------…