什么时候使用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”

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

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

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

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

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

相关文章

软工个人总结

目录 一、个人提升二、写下属于自己的人月神话三、对下一届、后来人、自己的建议四、我的团队——Clover五、关于代码质量六、学过软件工程?七、自我介绍八、个性发挥一、个人提升 1. 开学初的目标 希望通过团队合作领会团队合作的内在精神,希望在分工完…

排序算法之(7)——堆排序

【堆排序的思路】 堆排序主要是利用了堆的性质。对于大顶堆:堆中的每一个节点的值都不小于它的孩子节点的值,具体可參考我的还有一篇博客http://blog.csdn.net/adminabcd/article/details/46880591,那么大顶堆的堆顶元素就是当前堆中全部元素…

重新登录:重新登录

嗨,我再次回到日志中来,这是任何应用程序设计和开发的固有部分。 我是坚强的基础知识的忠实拥护者,在我的拙见中,日志记录是任何企业级应用程序中经常被忽略但基本的关键要素之一。 我已经写在此之前这里 。 为了理解当前文章&…

分治1--二分查找

分治1--二分查找 一、心得 二、题目和分析 三、代码和结果 1 #include <iostream>2 using namespace std;3 int a[10]{1,2,4,5,7,8,9,10,13,20};4 5 6 //非递归 7 int find(int i){8 int l0,r9;9 int mid(lr)/2; 10 while(l<r){ 11 mid(lr)/2; 12…

Spring自定义命名空间

Spring自定义命名空间提供了一种很好的方式来简化用于描述Spring应用程序上下文的bean定义的xml文件。 这是一个相当古老的概念&#xff0c;最初是在Spring 2.0中引入的&#xff0c;但值得不时地进行审查。 考虑一种情况&#xff0c;必须为没有自定义名称空间的Spring MVC应用程…

预告片:裸指关节SOA

我正在研究这个想法&#xff0c;但我不知道它是否对你们有吸引力。 我想就您是否需要进一步探讨提出您的意见。 达成协议&#xff1a;我遇到过一些团队&#xff0c;他们在使用SOA技术时由于其工具的复杂性而陷入泥潭。 我只在Java中看到过这种情况&#xff0c;但是我从一些C&am…

JMX和Spring –第1部分

这是三篇文章的第一篇&#xff0c;这三篇文章将展示如何通过JMX支持为Spring应用程序赋能。 Maven配置 这是用于设置此示例代码的Maven pom.xml&#xff1a; <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSche…

java婚庆网站源码_基于jsp的婚庆网站-JavaEE实现婚庆网站 - java项目源码

基于jspservletpojomysql实现一个javaee/javaweb的婚庆网站, 该项目可用各类java课程设计大作业中, 婚庆网站的系统架构分为前后台两部分, 最终实现在线上进行婚庆网站各项功能,实现了诸如用户管理, 登录注册, 权限管理等功能, 并实现对各类婚庆网站相关的实体进行管理。该婚庆…

JQuery实现的模块交换动画效果

<!doctype html> <html><head><meta http-equiv"content-type" content"text/html;charsetutf-8" /><title>JQuery实现的模块交换动画效果</title><meta name"Keywords" content"jquery&#xff0c…

JMX和Spring –第2部分

这篇文章从本教程的第1部分继续。 嗨&#xff0c;在我的前一篇文章中&#xff0c;我解释了如何通过Spring设置JMX服务器以及如何通过身份验证和授权保护对它的访问。 在本文中&#xff0c;我将展示如何实现一个简单的MBean&#xff0c;该MBean允许用户在运行时更改Log4j记录器…

android p wifi一直在扫描_(一百六十八)Android P wifi 扫描失败结果上报流程梳理-扫描上报梳理②...

接(一百五十五)Android P wifi 扫描失败结果上报流程梳理-扫描上报梳理 扫描失败上报梳理发现梳理的差了很多&#xff0c;特补充1.WificondScannerImplOverridepublic boolean startSingleScan(WifiNative.ScanSettings settings,WifiNative.ScanEventHandler eventHandler) {i…

带有ActiveMQ的JMS

带有ActiveMQ的JMS JMS是Java Message Service的缩写&#xff0c;它提供了一种以松散耦合&#xff0c;灵活的方式集成应用程序的机制。 JMS以存储和转发的方式跨应用程序异步传递数据。 应用程序通过充当中介的MOM&#xff08;面向消息的中间件&#xff09;进行通信&#xff0c…

用户故事排球教练助手

计划&#xff1a;估计这个任务需要一周时间 需求分析&#xff1a;作为一名排球教练助手&#xff0c;我需要了解每场每位队员的技术动作&#xff0c;每场比赛每位队员的得分情况&#xff0c;以便教练更好的了解到每位队员的发挥情况和特长。 设计文档&#xff1a;用户进入此界面…

TMS320DM642学习----第一篇(硬件连接)

DSP设备型号&#xff1a;SEED-DTK-VPM642&#xff08;目前实验室用途&#xff1a;视频处理&#xff0c;图像处理方向&#xff0c;预计搭载目标跟踪以及云台防抖等算法&#xff09; 官网链接&#xff1a;http://www.seeddsp.com/index.php/Home/Product/detail/name/1/id/174.ht…

关于inline-block 元素之间为何会产生间隔

关于inline-block 元素之间为何会产生间隔 现象&#xff1a; <body><input type"text"><input type"text"> </body> 在浏览器中的表现&#xff1a; 实时上不仅仅是 inline-block 会导致这种现象。 inline 也会导致。 那问题来了&a…

数据库备份 java jar_Java实现数据库备份并利用ant导入SQL脚本

​数据备份对于经常在运维部署方面的工作者来说&#xff0c;是一件相对简单的事情&#xff0c;都可以通过某一个SQL工具进行备份&#xff0c;但是如果在项目运行当中&#xff0c;我们需要对数据进行实时&#xff0c;或者是每隔一星期&#xff0c;一个月&#xff0c;等等进行数据…

JSF简单Ajax示例

今天&#xff0c;我们将看到一些使用JSF的Ajax简单样本。 如果要查看有关JSF / Web应用程序的其他文章&#xff0c;请单击以下链接&#xff1a; 重定向后的JSF持久化对象和消息 &#xff0c; 使用JAAS和JSF进行用户登录验证 &#xff0c; JSF&#xff1a;Converter and Bean Au…

常用的好用的window工具

1. FastStone Capture截图录屏软件 百度软件中心&#xff1a;http://rj.baidu.com/soft/detail/13504.html?ald 注册企业版&#xff1a; 用户名&#xff1a;c1ikm 注册码&#xff1a;AXMQX-RMMMJ-DBHHF-WIHTV 中文输入乱码解决方法&#xff1a; 2. Notepad文本编辑器&#xff…

python socket模块实现udp通信_Python基于socket模块实现UDP通信功能示例

Python基于socket模块实现UDP通信功能示例本文实例讲述了Python基于socket模块实现UDP通信功能。分享给大家供大家参考&#xff0c;具体如下&#xff1a;一 代码1、接收端import socket#使用IPV4协议&#xff0c;使用UDP协议传输数据ssocket.socket(socket.AF_INET, socket.SOC…