jboss fuse 教程_使用JBoss Fuse和OpenShift进行Cloud Native Camel骑行

jboss fuse 教程

红帽公司最近发布了一个微服务集成工具包,用于在OpenShift v3的Docker和Kubernetes环境中运行我们的微服务。 为了帮助人们更好地理解这一点,我将Rider Auto应用程序迁移到一组微服务中,该应用程序已经存在了一段时间,该应用程序用于演示Apache Camel和JBoss Fuse,可以通过Docker容器在OpenShift / Kubernetes上运行。 该博客详细介绍了一些背景知识,并指出了针对非平凡应用程序的“操作方法”的特定示例。 我还将制作一组视频来演示此操作,因此,请关注此博客( http://blog.christianposta.com )进行更新,或者在Twitter @christianposta上关注我。

糖

什么是用于OpenShift的保险丝集成服务(FIS)?

FIS是来自fabric8.io上游社区的一组开发人员工具和Docker映像,用于打包和部署我们的应用程序,该应用程序遵循微服务架构以及围绕应用程序部署,版本控制和生命周期管理的最佳做法,从而适合模型。 FIS是OpenShift上的Fuse的Red Hat支持的选项。

fabric8-徽标

部署Fuse Integration Services的两种主要方法是通过Fuse传统上使用的基于OSGI的Karaf方法以及一种更简单的平面类加载器选项,该选项从简单的旧Java main引导Camel。 这两个选项都打包并作为Docker容器交付。 两者都是不错的选择,具体取决于您的工作,因此让我们来看一下。

骆驼靴

Camel Boot是JVM引导程序选项,它使我们可以使用maven项目使用的相同类路径来打包应用程序,并使用Plain Old Java Main来启动Apache Camel集成。 这种方法具有许多优点,可以简化构建,组装,分发和运行我们的微服务。 最重要的是,我们不必猜测我们的应用程序行为是基于复杂的类加载器的层次结构或图形的,也不是我们是否包含了正确的元数据和依赖项,以便类可以解析或碰撞/覆盖/覆盖/动态加载/等等。 。 我们可以通过仅使用一个单一的平面类加载器来简化模型,从而不仅在Dev中而且在整个应用程序生命周期(例如IST,UAT,PM,PROD等)中都更容易推理应用程序。

骆驼靴

由于此选项并不打算部署在任何应用程序服务器(Java EE应用程序服务器,Servlet容器,OSGI容器等)中,因此我们将依靠我们的应用程序来提供“恰到好处”的功能,否则您将在应用服务器-诸如HTTP,JMS,持久性等内容。因此,您可以在我们的应用中嵌入Jetty或Undertow服务器以获取REST或SOAP端点的HTTP服务,并可以嵌入Spring-JMS和ActiveMQ库之类的JMS客户端以获取消息客户。 由于所有这些依赖项都作为应用程序的一部分包含在内,并且可以独立于任何应用程序服务器启动,停止,重新部署等,因此这也使对应用程序进行单元测试变得更加容易。

我建议在大多数用例中使用Camel Boot选项,在这些用例中,您已经分解了应用程序并对其进行了模块化,并且需要分别运行,调整,扩展和推理它们。 但是,在某些情况下,将服务并置在一起是必要的,并且只要应用程序类路径不会变得太复杂(即相互依赖的依赖关系),Camel Boot应该是一个不错的选择。 如果由于内聚的,位于同一位置的服务而使微服务变得复杂,请考虑使用Apache Karaf的下一个选项,该选项可让您精细地控制类加载器的行为并在单个app / JVM进程中隔离模块和API。

“不变”的Apache Karaf

Fuse Integration Services还提供了一个部署到基于Apache Karaf的JVM的选项,尽管该模型略有不同,因为我们遵循“不可变”部署的Docker模型。 在将应用程序热部署/重新部署到正在运行的JVM中/从中撤出应用程序之后,很难推断出JVM的状态。 实际上,由于JVM在运行时的这种“动态”可变性,您可能会遇到令人讨厌的,难以识别的JVM泄漏 (尤其是在生产中是个坏主意)。 FIS鼓励的模型是“用旧版本替换旧版本”之一(并依靠集群管理器通过滚动升级或蓝绿色部署等为您精心安排 )

这对于FIS的Apache Karaf意味着什么? 不建议在运行时动态加载和卸载包或更改配置值以更改应用程序状态。 相反,我们鼓励可预测的启动顺序,理解的配置值以及将预烘焙的应用程序移植到JVM中。 如果需要更改,那么您将通过应用程序交付管道来更改/构建/测试/部署新版本(理想情况下是通过CI / CD流程),就像上述Camel-Boot选项一样。 因此,对于Karaf for FIS,您的应用程序及其所有依赖项在构建时会打包,安装,解析并构建到一个Karaf程序集中 ,这是Karaf的自定义发行版,其中包含您的应用程序。 部署时无需再猜测OSGI元数据和类解析; 如果事情无法解决,所有这些都是预先计算的,并且在构建时会快速失败。 如果构建成功,您将对OSGI应用程序更有信心。

尽管大多数情况下建议使用Camel Boot选项,但对于OpenShift / Kubernetes / Docker之外的现有JBoss Fuse部署,此基于Karaf的选项可能是将现有Fuse工作负载迁移到此模型的最佳选择(并利用CI / CD ,服务发现,集群管理等-已内置在OpenShift中)。 同样,如果您要同时放置许多最终污染平面类路径的服务,那么不变的Karaf选项非常适合提供更精细的类路径隔离和API /模块化建模。

部署到Kubernetes / OpenShift

要部署到OpenShift,我们需要执行以下操作:

  • 打包我们的JVM(骆驼引导或不可变的karaf)
  • 构建我们的Docker容器
  • 生成并应用我们的OpenShift / Kubernetes配置

包装骆驼靴应用

要打包我们的Camel Boot应用程序,我们需要做的就是包括一个maven <build/>插件来为我们处理所有这些事情。

<plugin><groupId>io.fabric8</groupId><artifactId>hawt-app-maven-plugin</artifactId><version>${fabric8.version}</version><executions><execution><id>hawt-app</id><goals><goal>build</goal></goals><configuration><javaMainClass>org.apache.camel.spring.Main</javaMainClass></configuration></execution></executions>
</plugin>

在上述hawt-app-maven-plugin配置中,我们可以看到我们只指定了一个普通的旧Java Main,它将骆驼引导到依赖项注入上下文或您的选择(Spring,CDI等)中,并发现您的所有Spring / CDI资源,以及发现和启动您的骆驼路线。 可以使用的Main.java文件的不同类型是:

  • org.apache.camel.spring.Main –发现您的Spring上下文文件(默认位置META-INF / spring / *。xml
  • org.apache.camel.cdi.Main –加载CDI容器和Camel路由bean
  • org.apache.camel.main.Main –没有依赖项注入容器; 默认的SimpleRegistry实现
  • org.apache.camel.spring.javaconfig.Main使用Java配置的Spring配置
  • org.apache.camel.guice.Main – Guice依赖注入容器

可能还值得在您的pom.xml添加exec-maven-plugin ,以便您可以尝试并通过上述Java Main尝试进行引导:

<plugin><groupId>org.codehaus.mojo</groupId><artifactId>exec-maven-plugin</artifactId><version>1.4.0</version><configuration><mainClass>org.apache.camel.spring.Main</mainClass></configuration>
</plugin>

然后,如果您键入mvn exec:java您将获得与与hawt-app-maven-plugin打包的应用程序相同的行为,该应用程序保留了我们独立Camel Boot微服务的Maven类路径的顺序和行为。

当您进行Maven构建时,您应该在zip / tar.gz文件中看到您的应用与Maven依赖关系打包在一起。 如果您解压缩该文件,则会有一个bin/run.sh文件,可用于启动您的骆驼微服务。

要将其转换为Docker映像,请将以下docker-maven-pluginpom.xml

<plugin><groupId>org.jolokia</groupId><artifactId>docker-maven-plugin</artifactId><version>${docker.maven.plugin.version}</version><configuration><images><image><name>our-company/app-name:1.0</name><build><from>jboss-fuse-6/fis-java-openshift:1.0</from><assembly><basedir>/deployments</basedir><descriptorRef>hawt-app</descriptorRef></assembly><env><JAVA_LIB_DIR>/deployments/lib</JAVA_LIB_DIR><JAVA_MAIN_CLASS>org.apache.camel.spring.Main</JAVA_MAIN_CLASS></env></build></image></images></configuration>
</plugin>

有关设置和运行它的更多详细说明,请参阅Rider Auto OpenShift文档。

打包不可变的Karaf应用

如果您正在执行基于Karaf的微服务,我们将遵循与Camel Boot类似的路径。 通过将插件添加到我们的maven构建中,我们将使用karaf-maven-plugin将我们的Karaf应用打包到一个不变的Karaf程序karaf-maven-plugin

<plugin><groupId>org.apache.karaf.tooling</groupId><artifactId>karaf-maven-plugin</artifactId><version>${karaf.plugin.version}</version><extensions>true</extensions><executions><execution><id>karaf-assembly</id><goals><goal>assembly</goal></goals><phase>install</phase></execution><execution><id>karaf-archive</id><goals><goal>archive</goal></goals><phase>install</phase></execution></executions><configuration><karafVersion>v24</karafVersion><javase>1.8</javase><useReferenceUrls>true</useReferenceUrls><!-- do not include build output directory --><includeBuildOutputDirectory>false</includeBuildOutputDirectory><!-- no startupFeatures --><startupFeatures><feature>karaf-framework</feature><feature>shell</feature><feature>jaas</feature><feature>spring</feature><feature>camel-spring</feature><feature>camel-jaxb</feature><feature>camel-cxf</feature><feature>camel-bindy</feature><feature>cxf-http-jetty</feature><feature>activemq-client</feature><feature>activemq-camel</feature></startupFeatures><startupBundles><!--  this needs to be here for spring-dm to resolve properly!!--><bundle>mvn:org.apache.karaf.bundle/org.apache.karaf.bundle.core/3.0.4</bundle><bundle>mvn:io.fabric8.mq/mq-client/2.2.0.redhat-079</bundle><bundle>mvn:io.fabric8/fabric8-utils/2.2.0.redhat-079</bundle><bundle>mvn:${project.groupId}/${project.artifactId}/${project.version}</bundle></startupBundles></configuration>
</plugin>

请注意,上面的示例使用我们的微服务模块/ API构建了Karaf的完整发行版,并将所有依赖项烘焙到发行版中。 您可以在配置中看到,我们可以精确控制要预发布到发行版中的功能,包,JRE等。

还应使用docker-maven-plugin为该模块构建Docker映像。 再次,查看Rider Auto OpenShift文档以获取完整的,正在运行的示例。

生成OpenShift / Kubernetes组件清单

目前,FIS有两个用于生成OpenShift / Kubernetes清单文件的选项(json / yaml –尽管目前仅支持JSON选项。在上游社区中,我们也支持yaml选项)。 要生成复制控制器/ Pods /服务,我们需要添加fabric8-maven-plugin和一些maven <properties/>

<plugin><groupId>io.fabric8</groupId><artifactId>fabric8-maven-plugin</artifactId><version>${fabric8.version}</version><executions><execution><id>json</id><phase>generate-resources</phase><goals><goal>json</goal></goals></execution><execution><id>attach</id><phase>package</phase><goals><goal>attach</goal></goals></execution></executions>
</plugin>
<fabric8.service.name>${project.artifactId}</fabric8.service.name><fabric8.service.headless>true</fabric8.service.headless><fabric8.metrics.scrape>true</fabric8.metrics.scrape><fabric8.metrics.port>9779</fabric8.metrics.port><docker.port.container.soap>8183</docker.port.container.soap><fabric8.service.name>${project.artifactId}</fabric8.service.name><fabric8.service.port>80</fabric8.service.port><fabric8.service.containerPort>8183</fabric8.service.containerPort>

使用这些pom.xml条目,我们可以执行mvn fabric8:json并生成kubernetes.json文件到target/classes/kubernetes.json

我们还可以使用类型安全的DSL来增强或生成kubernetes.json文件,从而生成更高级的Kubernetes清单对象,例如PersistentVolumes,Secrets,多种服务等。 有关一些示例和说明,请参见rider-auto-file模块。

Rider Auto微服务回购中展示的功能

请查看Rider Auto项目,以了解有关这些功能的更多详细信息:

  • 使用fabric8 maven插件生成kubrenetes.json文件
  • 使用类型安全的DSL将PersistentVolumes添加到kubernetes.json文件
  • 构建Camel Boot应用
  • 构建不可变的Karaf应用
  • 在kubernetes环境中发现JBoss AMQ
  • 为Camel Boot和不可变的Karaf构建Docker映像
  • 将应用程序部署到OpenShift
  • 如何将多个kubernets.json文件合并到一个kubernetes.json文件中以进行“多合一”部署
  • 连接到本地/远程docker守护程序/ openshift安装
  • 通过Kubernetes Services公开SOAP和REST HTTP服务
  • 在Karaf中使用Spring
  • Kubernetes与fabric8-arquillian的集成测试

翻译自: https://www.javacodegeeks.com/2016/02/cloud-native-camel-riding-jboss-fuse-openshift.html

jboss fuse 教程

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

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

相关文章

javaone_JavaOne 2015 –又一年,又向前迈进了一步

javaoneJavaOne 2015 San Francisco于10月25日至29日举行。 我很自豪地说这是我第九个人参加JavaOne&#xff0c;第七个人是演讲者&#xff0c;第四个人是Oracle员工&#xff0c;第三个人是内容委员会成员&#xff0c;第二个人是项目负责人。 我认为对于JavaOne来说&#xff0c…

lnp和mysql分开安装_毕业设计之LNP+DISCUZ +分离的数据库操作

环境介绍&#xff1a;CentOS6.9最小化安装https://nginx.org/download/nginx-1.16.1.tar.gzhttps://www.php.net/distributions/php-7.3.14.tar.gzhttps://cdn.mysql.com//Downloads/MySQL-5.7/mysql-boost-5.7.29.tar.gznginxphp主机&#xff1a;192.168.111.141mysql主机&…

java中hotspot_Java 8中HotSpot选项的改进文档

java中hotspotOracle的HotSpot Java 8实现中引入的一些小但受欢迎的功能之一是在启动器的文档中添加了许多常见的HotSpot Java启动器 &#xff08; java &#xff09;选项/标志。 过去&#xff0c;甚至对某些相当常见的HotSpot JVM选项都感兴趣的开发人员不得不潜在地寻找多个不…

qchart折现图_Qt开发技术:QCharts(二)QCharts折线图介绍、Demo以及代码详解

若该文为原创文章&#xff0c;未经允许不得转载各位读者&#xff0c;知识无穷而人力有穷&#xff0c;要么改需求&#xff0c;要么找专业人士&#xff0c;要么自己研究敬请期待…红胖子&#xff0c;来也&#xff01;介绍了整体框架&#xff0c;开始动手码代码&#xff0c;按照顺…

各类算法思想

暴力枚举法 使用场景注意事项 1.建立一个简洁的搜索模型&#xff0c;变量尽可能少 2.尽可能减少搜索空间 递归与分治法 分治使用最广泛一类算法。采用递归的思想将较大规模的问题分成小问题来求。如果原问题可以分割成k个子问题&#xff0c;并且这些子问题可以重复利用&am…

eclipse neon_在自定义Java 9映像上运行Eclipse Neon

eclipse neon我已经开始修改自定义Java二进制运行时映像文件。 映像文件是打包为运行时平台的模块的配置。 基本上&#xff0c;默认映像包含组成Java运行时的所有内容。 自定义图像可以包含该图像的一些子集。 例如&#xff0c;我创建了一个仅包含“ compact 3”概要文件的映像…

java json注解_返回json用什么注解

返回json用“ResponseBody”注解&#xff0c;“ResponseBody”是作用在方法上的&#xff0c;“ResponseBody”表示该方法的返回结果直接写入“HTTP response body”中。本篇文章将介绍两种示例进行JSON返回注解方式演示。示例1ResponseBody是作用在方法上的&#xff0c;Respons…

java数据结构博客园_常见数据结构的Java实现

单链表的Java实现首先参考wiki上的单链表说明&#xff0c;单链表每个节点包含数据和指向链表中下一个节点的指针或引用。然后看代码import java.lang.*;public class SinglyLinkeList{Node start;public SinnglyLinkedList(){this.startnull;}public void addFront(Object newD…

jboss4 java_带有JBoss工具的OpenShift 3上的Java EE 7应用程序

jboss4 java您可以使用最新版本的JBoss Tools OpenShift插件在Eclipse中创建和管理OpenShift应用程序。 他们要么预先捆绑了最新的 JBoss Developer Studio&#xff08;9.0.0.GA&#xff09; &#xff0c;也可以将它们安装到现有的Eclipse Mars中。 这篇文章将引导您通过JBoss…

javaslang_使用Javaslang的Java 8中的功能数据结构

javaslangJava 8的lambda&#xff08;λ&#xff09;使我们能够创建出色的API。 它们极大地提高了语言的表达能力。 Javaslang利用lambda来基于功能模式创建各种新功能。 其中之一是功能性集合库&#xff0c;旨在替代Java的标准集合。 &#xff08;这只是鸟瞰图&#xff0c;您…

java调用kafka接口发送数据_Java调用Kafka生产者,消费者Api及相关配置说明

本次的记录内容包括&#xff1a;1.Java调用生产者APi流程2.Kafka生产者Api的使用及说明3.Kafka消费者Api的使用及说明4.Kafka消费者自动提交Offset和手动提交Offset5.自定义生产者的拦截器&#xff0c;分区器那么接下来我就带大家熟悉以上Kafka的知识说明1.Java调用生产者APi流…

java如何模拟请求_单元测试如何模拟用户请求

python web自动化测试设计构工具书40.9元包邮(需用券)去购买 >错误正当我高高兴兴写完后台c层的测试代码准备提交时&#xff0c;测试机器人报了很多401错误&#xff0c;把代码拉下来一看&#xff0c;原来当我写代码时&#xff0c;我的伙伴已经写好后台的拦截器了&#xff0c…

LeetCode 83. 删除排序链表中的重复元素

原题链接 解法&#xff1a;通过一个指针从头到尾进行扫描 class Solution { public:ListNode* deleteDuplicates(ListNode* head) {if(!head)return nullptr;auto p1 head;while(p1->next){if(p1->next->val p1->val)p1->nextp1->next->next;else p1 …

后端 java ee_刷新器-Java EE 7后端十大功能

后端 java ee这是我的小型Java EE 7复习系列的第二部分。 在进行了简要概述的第一篇介绍之后&#xff0c;我决定请Arjan Tijms撰写有关Java EE 7中他最喜欢的后端新功能的信息。如果您关注Java EE领域&#xff0c;您将会知道Arjan。 他是Java EE开发人员&#xff0c;JSF和Secur…

java cucumber_为Java + STANDARD值引入Cucumber

java cucumber作为软件开发人员&#xff0c;我们都有最喜欢的工具来使我们成功。 许多人在开始工作时就很适合这份工作&#xff0c;但很快就不见了。 其他人则需要太多的设置和培训才能“将脚趾浸入水中”&#xff0c;只是为了简单地确定它们是否是正确的工具即可。 Cucumber …

文章id 文章标题点击量php,WordPress如何通过文章ID获取文章标题等信息

如果我们想要在某一个主题的php文件中调用文章的标题&#xff0c;内容等信息&#xff0c;而在WordPress中唯一一直不会改变的就是文章发布时生成的ID&#xff0c;我们只需要获取文章的ID&#xff0c;即可通过文章ID来获取我们想要的文章信息。调用方法php$id // 文章的 id$tit…

javaone_JavaOne 2015:高级模块化开发

javaoneJavaOne 2015看到了Project Jigsaw团队关于Java 9中的模块化的一系列讨论 。它们都是非常有趣的&#xff0c;并且充满了宝贵的信息&#xff0c;我敦促每个Java开发人员都注意它们。 除此之外&#xff0c;我想给社区一种搜索和引用它们的方法&#xff0c;因此我在这里总…

spark rest_Spark简介,您的下一个REST Java框架

spark rest我希望您今年Java来了&#xff01; 今天&#xff0c;我们将研究一个清新&#xff0c;简单&#xff0c;美观且实用的框架&#xff0c;以Java编写REST应用程序。 它将非常简单&#xff0c;甚至根本不会看起来像Java。 我们将研究Spark Web框架。 不&#xff0c;它与Ap…

oracle 授权 增删改查权限_Oracle增删改查与函数

SQL -- 结构化查询语言 关系型数据库分类&#xff1a; DDL DML DCL DQL TCL Oracle 的数据类型&#xff1a;字符 char() varchar2()数字 number(p,s)时间 date timestamp 文件 clob blob 二维表 table 创建表 CREATE create table 表名 ( 列名 数据类型 [约束], 列名 类型 ... …

_用WSL,MobaXterm,Cmder配置linux开发环境

离不开Windows的理由很多,作为后端开发需要使用linux的情况也很多,双系统总归是不方便,而且linux下的GUI体验也没用Win 10好. 如果使用虚拟机,那么文件交换和网络等各种问题也需要解决,对系统的内存要求也更高一些.微软为了让更多的开发人员留在Win10上面,开发了WSL功能.目前的…