在 Java EE 组件中使用 Camel Routes

来源:互联网 发布:ubuntu os update 编辑:程序博客网 时间:2024/05/16 15:12

摘要:你可以通过集成 Camel 和 WildFly 应用服务器(使用 WildFly-Camel 子系统)在 Java EE 组件中开始使用 Apache Camel Routes。

【编者按】作者 Markus Eisele 是 Red Hat 的 Developer Advocate,主要从事 JBoss Middleware 相关研究,拥有超过14年的 Java EE 工作经验。本篇博文中, Markus 主要分享了基于 Java EE 组件的 Camel Routes 应用实践。

以下为译文:

在生产环境中使用 Camel 有一段时间后,我愈发的喜欢上它的简单。在 Java EE 上使用它确实存在一些挑战,而在最近一次演讲中我也提到了如何实现这一点。在 Java EE 中,我们可以通过不同的途径来使用 Camel 的,其中比较推荐的是使用 WildFly-Camel 子系统。在接下来的一个系列中,我将探索实现它的不同方法,并提供一些在演讲中没有涉及的例子。很期待能够通过留言或者在 Twitter上@myfear 的方式获得你的反馈和提问。

Camel On WildFly 8.2入门

WildFly-Camel 子系统提供了 Apache Camel 和 WildFly 应用服务器的集成环境。它允许你添加 Camel Routes(路由)作为 WildFly 配置的一部分。Routes 可以作为 Java EE 应用程序的一部分部署。Java EE 组件能够使用 Camel 的核心 API 和多个 Camel Component APIs。你的企业级集成解决方案可以架构于 Java EE 和 Camel 的联合功能之上。

备注:最新的 WildFly9 预期将由 WildFly-Camel 的 3.x 版本支持。

准备阶段

下载并解压 WildFly 8.2.0.Final 到你指定的目录下,下载并解压 wildfly-camel patch(2.3.0) 到 wildfly 目录下。通过以下命令启动 WildFly:

bin/standalone[.bat|.sh] -c standalone-camel.xml

最快速的启动和运行方式是使用 Docker 和 WildFly Camel image。这里的 image 需要预先安装好 WindFly8.1 和 Camel 子系统。

定义和使用Camel Context

CamelContext 代表着一个 Camel 路由规则库。使用 CamelContext 和使用 Spring ApplicationContext 的方式是十分相似的。它包含针对你应用的所有路由。你可以根据需求使用任意数量的 CamelContext,当然它们需要使用不同的名称来定义。

WildFly-Camel 可以通过下面3种不同的方式定义和部署:

  1. 在 standalone-camel.xml 和 domain.xml 中作为子系统的一部分来定义;
  2. 在一个支持它们的 deployment artifact 进行部署,当然这个 deployment artifact 必须包含后缀为 -camel-context.xml 的文件;
  3. 通过 RouteBilder 和 CDI integration 定义部署并提供路由信息。

一个定义的 CamelContext 可以通过两种不同的方式被使用:

  1. 通过Camel-CDI注入
  2. 通过 JNDI 树进入。

Context 和 Route 示例

在接下来的例子中,我将使用一个关联路由的 context,通过 CDI 和 RouteBuilder 提供。是一个应用级别的 bean,在应用启动的时候自动启动。@ContextName 注解给了 CamelContext 一个特定的名字。

@ApplicationScoped@Startup@ContextName("cdi-context")public class HelloRouteBuilder extends RouteBuilder {    @Inject    HelloBean helloBean;    @Override    public void configure() throws Exception {        from("direct:start").transform(body().prepend(helloBean.sayHello()).append(" user."));    } }

路由本身并不真的具有挑战性。它有一个空的信息主体 from direct:start 并且用 CDI bean 方法 “sayHello” prepends 输出,再 append 字符串” user.”。作为参照,完整的代码可以在我的GitHub(https://github.com/myfear/camel-javaee)中找到。因此,接下来我们需要知道的是,如何在各种Java EE组件中使用这个路由。

在 CDI 中使用 Camel

Camel 自从2.10 版本即支持 CDI。在没有子系统之前,它需要被 bootstrapped。不过现在不需要了,你可以仅仅用一个已部署或者已定义的 CamelContext 在 @Named CDI bean 中通过简单的 @Injecting 注入它的 name 实现。

@Inject    @ContextName("cdi-context")    private CamelContext context;

在 JSF、JAX-RS 和 EJBs 中使用 Camel

在 Java EE 组件中使用 Camel Routes

有了对在 CDI 中如何使用 CamelContext 的了解,你可能会想,在 类似 JSF 中使用应该一样的简单,事实却并不如此——你无法将它注入 ManagedBeans 或者和 JSF 组件绑定的 CDI Beans。此外,它在 EJB 中也不能使用。这里我并没有深挖细节,但是认为它在边界控制上确实需要改进。一个合理的解决方法,事实上,更好的应用程序设计是将一个完整的 Camel 逻辑放入一个单独的 CDI bean 并且注入。

@Namedpublic class HelloCamel {    @Inject    @ContextName("cdi-context")    private CamelContext context;    private final static Logger LOGGER = Logger.getLogger(HelloCamel.class.getName());    public String doSomeWorkFor(String name) {        ProducerTemplate producer = context.createProducerTemplate();        String result = producer.requestBody("direct:start", name, String.class);        LOGGER.log(Level.INFO, result);        return result;    }}

ProducerTemplate 接口允许你从 Java 代码发送信息交换到 endpoint,通过多种不同的方式使得同 Camel Endpoint 实例协作非常容易。在这种特殊情况下,它仅仅是启动路由并且添加上代表我使用组件名称的字符串到 body 中。

CDI Bean,对于使用它的组件来说扮演着 backing-bean 的角色:

@Inject    HelloCamel helloCamel;    public String getName() {        return helloCamel.doSomeWorkFor("JSF");}

返回的字符串是 “Hello JSF user.”,同时也写进了 WildFly 的服务器日志。对于其他 Java EE 组件来讲这个方法同样是最好的。

在 EJB 中使用 Camel

如果你正在使用EJB作为你的主要应用组件模块,那么使用JNDI方法也是合理的:

CamelContext camelctx =              (CamelContext) inicxt.lookup("java:jboss/camel/context/cdi-context");

Hawtio:一个 Camel 控制台

在子系统中另一个隐藏的宝贝就是 Hawtio 控制台。这是一个模块化的 Web 控制台,用来管理你的 Java 组件,它有一个 Apache Camel 插件来可视化你的上下文和路由信息。记住,它是自动配置的,安全起见,你在使用它之前需要先添加一个管理用户。
在 Java EE 组件中使用 Camel Routes

原文地址:Using Camel Routes In Java EE Components

本文系 OneAPM 工程师编译整理。OneAPM 是应用性能管理领域的新兴领军企业,能帮助企业用户和开发者轻松实现:缓慢的程序代码和 SQL 语句的实时抓取。想阅读更多技术文章,请访问 OneAPM 官方博客。

7 2
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 缴社保没工资条怎么办 工作超过八小时怎么办 小孩晚上很晚睡怎么办 小孩睡觉时间短怎么办 上班没法吃午饭怎么办 蓝色牛仔裤掉毛怎么办 怀孕期间牙疼怎么办 孩子不愿意上学该怎么办 小孩子做作业拖拉怎么办 脚冷怎么办 小妙招 脸冻伤怎么办小妙招 睡觉很难入睡怎么办 早上起不了床怎么办 赖床早上起不来怎么办 晚上睡不着早上起不来怎么办 感觉自己好压抑怎么办 工地工作时间10.5小时怎么办 孩子早晨不起床怎么办 周末小孩不起床怎么办 宝宝有起床气怎么办 孕妇起夜次数多怎么办 体检没有尿意怎么办 晚上要工作作息怎么办 个孩子咬指甲怎么办? 家长上班小孩放学怎么办 小孩做作业走神怎么办 做作业容易走神怎么办 餐饮作息不规律怎么办? 学习安排科目表怎么办 考研进入懈怠期怎么办 在家睡一天头痛怎么办 讨厌自己的室友怎么办 受不了室友的习惯怎么办 工厂上班好累怎么办 15岁皮肤老化怎么办 减肥期间出汗太多怎么办 减肥运动不出汗怎么办 复读生没有学籍怎么办 透视表数据不准怎么办 初中数学不会做怎么办 初中生放暑假该怎么办