热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

apache.camel_ApacheCamelK1.0在这里–您为什么要关心

apache.camel

昨天我们发布了Apache Camel K 1.0,并在社交媒体和Camel网站上宣布了该版本。

apache.camel_Apache Camel K 1.0在这里–您为什么要关心

那么,骆驼K是什么,为什么你要在乎呢? 这是一个很好的问题,我想通过提及伟大的思想来帮助回答这个问题。

Hugo Guerrero发表了以下推文

apache.camel_Apache Camel K 1.0在这里–您为什么要关心

这是Hugo的有力声明,他着重介绍了Camel K的突破性创新,该创新为开发人员提供了构建基于Java的服务的工具和手段,这些服务既无服务器又有功能,并使用标准Kubernetes构建块运行。

骆驼K是过去十年来Apache骆驼中最大的创新。 因此,将咖啡或茶装满杯子,然后坐下来享受接下来的10分钟阅读。

我请尼古拉·费拉罗(Camel K的共同创始人)发言,他使我得以从昨天的公告中重新发布他的博客文章。

自成立以来,Apache Camel K取得了很大的进步,我们现在很自豪地宣布1.0版本。 在过去的几个月中,我们一直在努力为Camel K添加更多很棒的功能,同时也提高了稳定性和性能。 这篇文章包含了一些有趣的东西,您可以在1.0 GA版本中找到它们。

首先,如果您生活在岩石下,这是您第一次听说骆驼K,

您可以在此处阅读一些介绍性博客文章( 1-介绍Camel K )( 2-knative上的骆驼k ),或查看Apache Camel网站,其中包含Camel K部分 ,其中包含大量从Github存储库自动生成的材料

用户体验

Camel K的开发风格非常简单:您只需使用集成路径编写一个文件,即可立即在任何Kubernetes集群上运行它们。 这种定义事物的方式在许多FaaS平台上很常见(尽管Camel K不是合适的FaaS平台,而是轻量级的集成平台),并且在技术上很难为开发人员提供IDE支持,例如代码完成和其他实用程序。

但是现在我们拥有了。 集成工具团队为VS Code创建了一些很酷的扩展,这些扩展使Camel K的开发经验更加令人兴奋。

您无需记住Camel DSL语法,IDE会为您提供建议和错误突出显示。

apache.camel_Apache Camel K 1.0在这里–您为什么要关心

代码完成功能适用于Java代码,但不仅限于此:编写Camel URI和属性文件时,您还可以立即使用建议和文档。

而且,您还有许多选项可以运行集成并与之交互,所有这些都集成在IDE中。

只需安装VS Code Extension Pack for Apache Camel即可使用所有这些功能。

入门教程

好的工具是拥有Camel K良好开发经验的基础,但是随后您需要学习使用如此强大的功能可以做什么。

我们在Apache组织中创建了一个新的存储库,用于托管入门示例: camel-k-examples存储库。

到目前为止,我们已经添加了指导您完成操作的指南:

– 01基础 :学习Camel K的基础知识和一些有趣的用例

– 02无服务器API :如何设计无服务器(即自动缩放,缩放为零)API并在几分钟内运行

基本的快速入门也可以在线获得 ,因此您可以查看骆驼k的工作原理, 而无需在笔记本电脑上安装任何东西

预计在接下来的几个月中将会有更多的教程。 如果您想通过贡献自己的力量来帮助我们,也欢迎您。 它们基于VSCode Didact项目,该项目提供了

很棒的用户体验。

如果您正在寻找仅可以使用CLI挑选并运行的Camel K代码示例,则Camel K主存储库的examples目录包含许多示例 。 您也可以直接从Github运行它们:

kamel运行https://raw.githubusercontent.com/apache/camel-k/master/examples/Sample.java

您可以找到用不同语言编写的现成示例(例如
XML , Javascript等)。

无服务器

无服务器是最重要的领域,我们将重点放在Apache Camel K的新开发上,尽管您应该记住,即使没有无服务器功能,您也可以拥有出色的Camel K体验。 要在Camel K中启用无服务器配置文件,您只需要安装Knative 。

在最新版本中,我们增加了对Knative最新进展的支持,例如Camel K与Knative事件代理很好地集成在一起,您可以轻松地从中生成或使用事件。

使用2行代码,您可以将事件(例如,由IoT设备生成的事件)从MQTT代理传输到网格:

桥梁

来自('paho:mytopic?brokerUrl = tcp:// broker-address:1883&clientId = knative-bridge')

.to('knative:event / device-event')

别开玩笑,您只需要在文件中编写这两行代码,然后使用kamel run bridge.groovy运行它,即可将数据推送到Knative代理中。

您还可以向外扩展Integration(Integration是Kubernetes的自定义资源,kubectl可以获取集成以查看所有集成)

以获得更高的吞吐量。 这里的扩展是手动的,因为事件的源是MQTT代理(但是我们计划在这种情况下也进行自动扩展

当您想对某些Knative事件做出React时,Camel K嵌入式自动缩放功能非常有效:

侦听器

from('knative:event / device-event')

.to('http:// myhost / webhook / random-id')

该集成配置为接收所有带有“ type = device-event”类型的事件,并随负载自动扩展,因为它已具体化为Knative Serving Service,并通过触发器自动订阅了Eventing Broker 。

然后,当您的IoT设备产生某些东西时,它将收到一个CloudEvent ;如果没有数据,它会缩小为零。 您只需要创建它(就像以前一样,只需kamel运行listener.groovy),其余所有配置都由Camel K操作员自动完成。

我们添加了更多功能,以更好地与Knative生态系统集成,并且还修复了以前版本中存在的一些兼容性和性能问题。 现在,用户体验更加流畅。

如果您是Knative YAML开发人员(!),则可以直接使用Knative版本中的Knative Camel Sources ,而不是直接使用CamelK 。 它们是Camel K集成的包装,与Knative开发人员使用的所有工具(例如kn CLI或OpenShift无服务器控制台)兼容。

Knative中的源只能将数据推送到各个Knative端点中,而不能反过来(即,它们不能用于将数据从Knative发布到外部)。 在Camel K中,您没有此限制:Route是Camel集成的基本组成部分,您可以使用它进行任何操作。

快速启动和低内存

我们不能说我们没有服务器,而没有提到我们在改善Camel K集成性能方面所做的工作。

从Camel 3.3.0(这是Camel K 1.0.0使用的默认版本)开始,您可以受益于直接在Camel核心中进行的所有改进,以使其更加轻巧。 可以在以下博客系列中找到有关Camel核心改进的更多详细信息,这些博客系列重点介绍了3.x Camel时间轴中为减少内存占用和加快启动时间而进行的更改,这是在无服务器环境中运行集成时的基础:
第1部分 , 第2 部分 , 第3 部分 , 第4部分 。

但是,改进不仅限于Camel核心:我们还有很多工作要做。 几个月前,我们开始了一个名为Camel Quarkus的Apache Camel的新子项目,目的是在Quarkus框架之上无缝地运行集成。 如您所知,Quarkus能够减少Java应用程序的内存占用并缩短启动时间,因为它将很多启动逻辑移到了构建阶段。 Quarkus应用程序也可以编译为本机二进制文件,从而极大地提高了启动性能并降低了内存占用。

在Camel K 1.0.0中,我们在JVM模式下支持Camel Quarkus。 我们的目标是在下一个发行版中尽快提供集群内本机编译(对于某些DSL语言,例如YAML)!

要将Quarkus用作基础运行时,只需启用
运行集成时的Quarkus特性 :

kamel运行myintegration.groovy -t quarkus.enabled = true

预期Quarkus将在下一发行版中成为默认的基础运行时,并且将不赞成并删除对Standalone模式(通过camel-main)的支持。 这意味着您不需要在下一版本中手动启用Quarkus,但仍需要在1.0中启用它。

快速建立时间

Kubernetes上运行的每个应用程序都需要打包在一个容器映像中,但是在Camel K中,您仅提供集成DSL,并且操作员会执行它所需的操作,包括直接在集群中构建映像。

操作员管理着一个可重复使用的容器映像池,如果您重新部署集成代码,它的确会尝试重用池中的现有映像,而不是在每次更改时都新建一个映像,因为创建新映像需要一些时间。 一开始是一分钟...

但是Kubernetes的发展速度如此之快,以至于您无法一次解决一个问题而忘却它,您需要不断地加以解决。 碰巧,我们在“香草Kube”中进行构建时使用的某些第三方依赖项的性能已缓慢下降,直至严重影响Camel K用户体验的程度。

我们决定在构建系统上加倍努力,以大幅度改善(再次!)Camel K集成的构建阶段。

现在可以在Minikube等开发环境中以秒为单位测量构建时间。 大部分时间都是一秒钟。 这不仅仅是简单的改进!

更好的CLI

“ kamel” CLI是我们提供给开发人员以运行集成的主要工具。 这不是强制性要求:最后,集成是Kubernetes的自定义资源,您可以使用任何Kubernetes标准工具(例如kubectl)对其进行管理。 但是,kamel CLI为集成开发人员增加了很多价值。

例如,如果您是Camel Java开发人员,记住要实例化Camel路由构建器而必须编写的样板并不是一件容易的事。 现在您不必记住这一点:

kamel初始化Handler.java

您将获得一个Java文件,其中包含为您编写的所有样板文件,而您只需要编写集成路径即可。

它还可以与所有其他语言一起使用:Groovy,XML,YAML,Kotlin和Javascript。

例如,您可以编写:

kamel初始化foo.js

这样,您将获得一个用Javascript编写的简单路由。

不只是那样 通常Camel K开发人员需要添加许多命令行选项来配置其集成的最终行为。 例如,您可能想使用-d选项添加自定义库,或使用-t配置特征。 例如:

kamel run -d mvn:org.my:lib:1.0.0 -d mvn:org.my:otherlib:2.0.0 -t quarkus.enabled = true Handler.java

有时,您必须添加的命令行参数数量可能会过多。 因此,我们增加了在集成文件中将它们指定为模型选项的可能性(通过添加带有`camel-k:`作为前缀的注释行来完成)。

Handler.java

// camel-k:依赖关系= mvn:org.my:lib:1.0.0依赖关系= mvn:org.my:otherlib:2.0.0 trait = quarkus.enabled = true

//…

//您的路线

将选项写入文件后,您可以使用以下命令运行路由:

//简单地说,就是从文件中读取其他args

kamel运行Handler.java

其他选项是从文件模型自动获取的。 CLI还显示完整命令,以让您知道正在运行什么。

这种配置在CI / CD场景中非常有用,因为它允许您拥有独立的集成文件,并且无需更改管道即可设置其他选项。 如果您对CI / CD配置感到好奇,可以遵循有关Tekton管道的教程以获取更多信息。

监控和追踪

好的,您已经完成了Camel K开发的第1级,并且您想做些严肃的事情。 您处于非常好的位置,因为Camel K提供了许多有用的工具来增加您的集成途径的可视性。

假设您在名称空间中有一个Prometheus实例,并且想要发布集成指标:

kamel运行Routes.java -t prometheus.enabled = true

而已。 无需设置服务标签即可启用抓取。 还为集成提供了默认的prometheus配置文件,并带有合理的默认值。 当然,您也可以选择为高级用例提供自己的配置 。

现在,让我们假设您想看看您的路由在做什么,并跟踪集成的执行流程。 您需要做的是在命名空间(例如Jaeger )中安装与opentracing兼容的应用程序,然后按以下方式运行集成:

kamel运行Routes.java -t prometheus.enabled = true -t tracing.enabled = true

就是这样。 Camel K运算符将添加camel-opentracing库并将其连接到命名空间中可用的Jaeger收集器。 同样,这里支持高级用例 。

主路线

骆驼的老用户知道为什么主路由有用,何时使用主路由,但是对于那些不熟悉该术语的人,我将提供一个简短的解释。

只要您有一个集成路由必须在任何时间最多在一个Camel实例中运行,就需要使用主路由。 主路由可以通过简单地在消费者端点前面加上'master'关键字和一个用于创建命名锁的名称来声明,例如

来自('master:mylock:********:bots')

.to('log:info')

它可以用于打印发送到******** bot的所有消息。 由于******** API仅支持单个使用者,因此您可以使用主前缀来保护路由,以确保在任何给定时间最多只有一个使用者。

如果您想知道如何在一个实例中运行两个实例,那么想一想,当您更改代码并需要进行滚动更新时:一段时间内,会有两个Pod并行运行。 在某些情况下,您可能决定扩展服务范围,但在服务的所有Pod中仅保留特定路由的一个实例。 或者,您可能希望将主路由嵌入Knative自动缩放服务中:在这种情况下,该服务可以根据负载进行自动缩放,但任何时候都只有一个电报使用者。

主路由在Camel K中是开箱即用的,您只需要在端点uri中添加前缀即可。 将自动为您配置基于Kubernetes API资源锁的领导者选举协议!

CronJobs

所有足够复杂的系统都包含几个计划的作业。 对于系统中与外部集成的那部分尤其如此。

理想情况下,如果需要执行快速的周期性任务(例如,每两秒执行一次),则可以通过基于计时器的路由启动集成以执行周期性任务。 例如

来自(“ timer:task?period = 2000”)

.to(此为“ businessLogic”)

但是,如果两次执行之间的时间间隔是2分钟(“ 120000”)或2小时(“ 7200000”),而不是2秒(骆驼URI中的“ 2000”,以毫秒为单位)?

您会看到,保持一个运行JVM的容器执行应该每两分钟执行一次的任务可能是过大的(肯定是在2小时内过大了)。 我们生活在内存和CPU等资源非常宝贵的时代。

因此,Camel K操作员可以通过将您的集成部署为Kubernetes CronJob而不是Kubernetes部署来自动处理这种情况。 这样可以节省大量资源,尤其是在两次执行之间的时间间隔较长时。 当需要运行集成代码时,容器将启动,触发执行,然后正常终止。 一切由Camel K和Kubernetes自动处理。

在某些情况下,您不希望启用此功能,例如,当您的代码使用内存缓存时,最好在两次执行之间保持同步。 在这种情况下,可以通过将标志-t cron.enabled = false传递给kamel run命令来安全地关闭该功能。

Cron功能不仅适用于`timer`组件。 从Camel 3.1开始,我们还添加了一个cron组件 ,与cron特质结合使用时效果非常好。

因此,您也可以直接在路由中编写cron表达式:

来自(“ cron:job?schedule = 0/5 + * + * + * +?”)

.to(此为“ businessLogic”)

在这种情况下,每5分钟启动一个带有JVM的新容器以执行计划的任务。 在剩下的4分钟以上时间内,您不会使用任何资源。

透明度

当您在集群中运行集成代码时,Camel K会为您完成很多工作,并且您可能在代码中放置了一些错误,这些错误会阻止部署过程。 我们在部署过程中增加了很多可见性,现在可以通过使用CLI时在控制台上打印的Kubernetes事件与用户进行通信。

这样一来,您总是会收到有关代码中问题的通知,并且您可以更好地了解要解决的问题以使集成运行。

如何尝试Camel K 1.0

第一步是转到Apache Camel K发布页面 ,下载适用于您的OS的kamel CLI,并将其放在系统路径中。

通常使用`kamel install`命令完成安装,但是,根据所使用的Kubernetes集群的类型,您可能需要执行其他配置步骤。

Camel K文档包含有关在各种类型的Kubernetes集群上安装它的部分。

如果您遇到问题或需要将其安装在未列出的特定群集上,只需与Gitter聊天联系 ,我们将尽最大努力为您提供帮助。

未来

我们已经达到了1.0.0版,这对我们来说是一个伟大的里程碑。 但是我们现在不会停下来:我们为未来制定了宏伟的计划,并且我们将继续开发出色的新功能。

我们需要您的帮助来改善骆驼K,我们热爱贡献!

加入我们:

– Gitter: https : //gitter.im/apache/camel-k

– GitHub: https : //github.com/apache/camel-k

翻译自: https://www.javacodegeeks.com/2020/06/apache-camel-k-1-0-is-here-why-should-you-care.html

apache.camel


推荐阅读
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • 在Docker中,将主机目录挂载到容器中作为volume使用时,常常会遇到文件权限问题。这是因为容器内外的UID不同所导致的。本文介绍了解决这个问题的方法,包括使用gosu和suexec工具以及在Dockerfile中配置volume的权限。通过这些方法,可以避免在使用Docker时出现无写权限的情况。 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
  • 安卓select模态框样式改变_微软Office风格的多端(Web、安卓、iOS)组件库——Fabric UI...
    介绍FabricUI是微软开源的一套Office风格的多端组件库,共有三套针对性的组件,分别适用于web、android以及iOS,Fab ... [详细]
  • 解决Cydia数据库错误:could not open file /var/lib/dpkg/status 的方法
    本文介绍了解决iOS系统中Cydia数据库错误的方法。通过使用苹果电脑上的Impactor工具和NewTerm软件,以及ifunbox工具和终端命令,可以解决该问题。具体步骤包括下载所需工具、连接手机到电脑、安装NewTerm、下载ifunbox并注册Dropbox账号、下载并解压lib.zip文件、将lib文件夹拖入Books文件夹中,并将lib文件夹拷贝到/var/目录下。以上方法适用于已经越狱且出现Cydia数据库错误的iPhone手机。 ... [详细]
  • CF:3D City Model(小思维)问题解析和代码实现
    本文通过解析CF:3D City Model问题,介绍了问题的背景和要求,并给出了相应的代码实现。该问题涉及到在一个矩形的网格上建造城市的情景,每个网格单元可以作为建筑的基础,建筑由多个立方体叠加而成。文章详细讲解了问题的解决思路,并给出了相应的代码实现供读者参考。 ... [详细]
  • 标题: ... [详细]
  • 闭包一直是Java社区中争论不断的话题,很多语言都支持闭包这个语言特性,闭包定义了一个依赖于外部环境的自由变量的函数,这个函数能够访问外部环境的变量。本文以JavaScript的一个闭包为例,介绍了闭包的定义和特性。 ... [详细]
  • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
  • 本文介绍了一个适用于PHP应用快速接入TRX和TRC20数字资产的开发包,该开发包支持使用自有Tron区块链节点的应用场景,也支持基于Tron官方公共API服务的轻量级部署场景。提供的功能包括生成地址、验证地址、查询余额、交易转账、查询最新区块和查询交易信息等。详细信息可参考tron-php的Github地址:https://github.com/Fenguoz/tron-php。 ... [详细]
author-avatar
艾米27
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有