Apache Camel 2.19发布–新增功能

Apache Camel 2.19于2017年5月5日发布,大约在一段时间后,我做了一个小博客,介绍了该版本包含的值得注意的新功能和改进。

这是值得注意的新功能和改进的列表。

1. Spring Boot的改进

Camel 2.19版本已针对Spring Boot进行了许多改进。 例如,所有Camel组件现在都在其Spring Boot元数据文件中包含更多详细信息,以进行自动配置。 这意味着工具现在可以显示您可能使用的每个组件,语言和数据格式上所有选项的默认值,文档等,并在application.properties或.yml文件中进行配置。

该发行版也是最新的Spring Boot 1.5.3发行版。 某些组件已改进了自动配置,使其更易于使用,例如camel-servlet,您可以在其中轻松地从application.properties文件设置上下文路径。 我们还提供了在CamelContext上配置更多选项的功能,因此您可以调整JMX,流缓存和许多其他选项。

2.骆驼目录的改进

骆驼目录现在包含该发行版中随附的每个工件的细粒度细节,也包括其他种类的骆驼-hystrix,camel-cdi等。

该目录现在还包括所有以ascii doc和html格式提供的文档。 该目录为Spring Boot和Karaf运行时提供了专门的提供程序,使工具可以知道可以在这些运行时上使用哪些Camel工件。

Camel项目使用目录本身,因此我们现在使用它来自动生成并保留网站上所有工件以及添加每个工件的完整列表。 因此,您可以查看它是在此发行版中还是在Camel 2.17等中引入的新工件。

在骆驼核心RuntimeCamelCatalog中提供了CamelCatalog的专用运行时版本,使用它可以在运行Camel时使用目录。 离线目录是骆驼目录,完全独立。

3. Camel Maven插件现在可以验证

camel-maven-plugin上有一个新的验证目标,该目标使您可以检查源代码并验证所有Camel端点和简单表达式是否具有无效的配置或选项。 我以前有
关于此的博客

4.自动重新加载XML文件

如果您在XML文件中开发Camel路由,则现在可以打开自动重载,因此Camel将监视XML文件中的更改,然后动态地自动更新路由。 我以前有
博客并记录了视频

5.服务呼叫EIP的改进

Luca一直在购买用于改善服务呼叫EIP的产品,因此它可以与Camel在云上(例如kubernetes或spring-boot-cloud)一起更好,更轻松地工作。

Luca 最近对此发表了博客。

6.调用REST服务更容易

如果您想使用Camel来调用RESTful服务,那么现在就可以轻松了,因为我们将生产方添加到了REST DSL。 这意味着您可以使用rest组件调用REST服务,该组件可以插入并使用Camel中的任何基于HTTP的组件,例如restlet,http4,undertow等。

有关更多信息,请参见rest-producer示例 。 我们还添加了一个新的camel-swagger-rest组件,使调用Swagger REST API更加容易,您可以在其中引用其操作ID,然后让Camel自动映射到其API。

有关更多信息,请参见rest-swagger示例rest-swagger文档

7. CDI与JEE交易

camel-cdi组件现在支持JEE事务,因此您可以立即使用它,而不必再依赖Spring事务。

8.改进了示例文档

现在,我们将生成一个包含所有示例的表格,并按类别进行排序。 这使用户可以找到初学者的示例,休息的示例,云计算等。此外,还可以确保将来保留示例的更好文档,因为如果我们有没有文档的示例,则生成器工具将警告。

同样,所有示例都有一个自述文件,其中包含有关示例以及如何运行的信息。

9. Spring Cloud组件

有新的Camel组件与Spring Cloud和Spring Cloud Netflix集成。 这样一来,通常可以轻松地将ServiceCall EIP或Hystrix EIP与Spring Cloud Netflix一起使用,或者将Camel与Spring Cloud一起使用。 您可以在
例子

10.卡夫卡改进

camel-kafka组件已得到改进,可以更直观地工作。 不幸的是,这意味着uri语法以向后不兼容的方式进行了更改。 因此,如果您要升级,请确保更改您的uri。 但是,新语法类似于使用kafka:topicName?opt​​ions的其他消息传递组件的处理方式。

而且,该组件现在可以立即自动转换为kafka序列化器和解串器,因此您不必为此烦恼。 我们提供了通常使用的转换,例如byte []和字符串类型。

该组件也已升级到最新的Kafka版本,现在可以离线存储偏移状态,因此,如果停止并稍后启动应用程序,则可以从此偏移中恢复。

配置和使用可作为标头值提供的自定义键和分区键也更加容易。

并且有一个新的Kafka幂等存储库

11.航线合同

我们已经添加了最初的支持,以便能够为骆驼路线指定传入和传出的类型(在骆驼内部称为转换器和验证器)。 然后,这将允许Camel在运行时和Camel开发人员都知道路由期望将哪些有效负载作为输入以及返回的内容。 例如,您可以指定路由接受XML并返回JSon。 借助XML,您甚至可以指定名称空间。 同样,您可以为POJO类指定Java类型。 基于这些合同,Camel能够在运行时自动在需要时在这些类型之间自动键入消息有效负载(如果可能)。

我们将继续在这方面进行更多改进。 例如,我们希望可以向Camel组件中添加此类功能,以便它们能够提供此类信息,从而使您的Camel路由在路由过程中的消息有效负载更加类型安全。

工具也将能够利用这种形式,然后例如“标记”用户有关路线不兼容的提示等。

您可以在本示例 (以及CDI和XML)和文档中找到更多详细信息。

12.活性骆驼

有一个新的camel-reactive-streams组件,它使Camel可以在无功流API中发挥一流的作用,因此您可以轻松地在无功流中使用Camel组件,或者从Camel路由调用流。

在下一个发行版中,作品中有一个camel-rx2组件,它通过流行的RxJava 2框架改进了对Camel的支持。

对于想要与vert.x一起使用react的用户,则在两个项目中都有一个camel-vertx和vertx-camel-bridge组件。 我们计划将它们合并在一起,并在将来有空时将它们各自的最佳功能融合在一起。 但是,Claus正在与vert.x团队进行此讨论。

您可以在此示例中找到更多信息。 《 行动中骆驼》第二版包含整章21章,涵盖了所有这些内容。

13. Java 8 DSL改进

而且,对我而言,Java 8 DSL稍有改进,可以在您的骆驼路线和EIP中使用更多Java 8 lambda和功能样式。 当我们发现对于精通Java 8的用户而言,EIP变得更加出色时,我们将不时地改善这一点。 我们也在寻求这方面的反馈,因此,如果您深陷Java 8风格,那么可以帮助我们确定可以改进DSL的地方。

14.骆驼连接器

我们引入了一个名为Camel Connector的新概念。 但是,它仍处于早期阶段,我们将在接下来的几个版本中进一步改进和完善Camel连接器。

简短的故事是,骆驼连接器是经过专门配置且经过预先配置的骆驼组件
一件事一件事 。 例如,如果您需要知道何时有人在Twitter上提及您,则可以使用camel-twitter组件。 但是它可以做10件事,并且可能需要一些时间来了解如何使用该组件并使之正常工作。 因此,您可以构建一个可以做到这一点的连接器,即骆驼推子连接器。 它是预先构建的,并配置为可以执行此操作。 因此,您所需要做的就是配置您的Twitter凭据,然后就可以使用了。 在运行时,连接器是Camel组件,因此从Camel的角度来看,它们都是组件,因此在Camel中它是一流的。

我们在源代码中提供了一些连接器示例

15.更多组件

像往常一样,每个Camel版本中都有很多新组件,而这次我们有大约20个新组件。 您可以在
发行说明 ,或在Camel组件网站上按2.19发行版号进行搜索。

例如,有一个骆驼开放式跟踪组件,可以将Camel与分布式跟踪一起使用。 Gary Brown对此发表了博客

Jens Reimann发表了一些新的用于物联网的骆驼组件,例如camel-milo。

您可以在发行说明中找到许多其他较小的改进。 例如,jsonpath语言现在允许使用嵌入式简单语言,并且您可以使用更简单的语法定义谓词,而无需太多令人困惑的jsonpath标记,以防万一您只想说order.customer.id> 1000等。

翻译自: https://www.javacodegeeks.com/2017/05/apache-camel-2-19-released-whats-new.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值