Mule ESB中entry-point-resolver的使用(1) 总论

醉酒当歌 提交于 2019-12-02 03:36:00

前面介绍Mule ESB使用的系列文章中我们使用了自定义的Java Transformer和Java Component,用于接收和处理Mule Message。然而我们使用的Transformer和Component都必须实现AbstractTransformer接口或者org.mule.api.lifecycle.Callable接口,这使得普通的POJO对象无法直接被Mule ESB流程引用,必须填写实现接口的代码。这样不仅增加了代码开发的工作量,而且进行单元测试时无法脱离Mule ESB Container进行,具有很大的局限性。

   从Mule ESB 3开始,引入了entry point resolver机制,Mule Flow在引用自定义Component时,同时定义对应的entry point resolver, 使得在Component没有实现接口的前提下,Mule ESB可以准确匹配到Component对应方法,将Mule Message传送给这些方法处理。Mule ESB将这一策略称为entry-point resolution strategy(EPRS),下图显示了Mule ESB如何使用EPRS进行Mule Message传递(Mule in Action 第二版的6.1中原来有配图,不过它基于Mule ESB 3.3版本,已经不适用于当前Mule ESB 3.8版本,因此我重新绘制了流程图)

1)当消息到达Flow中定义的Component时,Mule会检查是否定义了EPRS(可以定义在Flow级别,Component级别,后者定义的entry-point resolver可以覆盖前者定义的entry-point resolver),如果没有定义,Mule会使用默认的entry-point resolver。

  2)Mule根据entry-point resolver寻找匹配的entry point,如果没有找到,会抛出Failed find entry point for component的异常消息。如果找到匹配的entry point,不论有多少个,会执行第一个匹配的entry point。

Mule ESB中定义的entry point resolver有以下几种:

  • Callable Entry Point Resolver
  • Property Entry Point Resolver
  • Method Entry Point Resolver
  • Reflection Entry Point Resolver
  • Array Entry Point Resolver
  • No Arguments Entry Point Resolver
  • Custom Entry Point Resolver

 下面将对这些Entry Point Resolver进行逐一介绍

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!