Openshift源中的高可用性Drools无状态服务

嗨,大家好! 在这篇博客文章中,我想举一个简单的例子,展示使用Openshift 3(Docker和Kubernetes)扩展Drools Stateless服务有多么容易。 我将展示如何通过按需提供新实例来扩展我们的服务,以及如何使用循环策略由Kubernetes平衡这些实例的负载。

我们的Drools无状态服务

首先,我们需要一个无状态的Kie Session进行游戏。 在这些简单的示例中,我创建了一个食品推荐服务,以演示您可以使用这种方法建立什么样的情景。 所有源代码都可以在github上托管的Drools Workshop存储库中找到: https : //github.com/Salaboy/drools-workshop/tree/master/drools-openshift-example

在这个项目中,您将找到4个模块:

  • drools-food-model:我们的业务模型,包括领域类,例如成分,三明治,沙拉等
  • drools-food-kjar:我们的业务知识,在这里,我们有一组规则来描述如何完成食品推荐。
  • drools-food-services:使用Wildfly群,我将展示封装规则引擎的特定于域的服务。 这里提供了一组休息服务,以便我们的客户可以进行交互。
  • drools-controller:通过使用Kubernetes Java API,我们可以根据需要向Openshift环境以编程方式提供食品推荐服务的新实例。

我们的工作单位将是Drools-Food-Services项目,该项目公开REST端点与我们的无状态会话进行交互。

您可以看一下非常简单的服务端点: https : //github.com/Salaboy/drools-workshop/blob/master/drools-openshift-example/drools-food-services/src/main/java/ org / drools / workshop / food / endpoint / api / FoodRecommendationService.java

还请注意,还有另一个服务可以为我们提供有关服务运行位置的非常基本的信息: https : //github.com/Salaboy/drools-workshop/blob/master/drools-openshift-example/drools-food-services/ src / main / java / org / drools / workshop / food / endpoint / api / NodeStatsService.java

稍后,我们将调用此服务以确切知道该服务的哪个实例正在答复我们的客户。

此示例的规则很简单,并且操作不多,如果您想学习Drools,我建议您创建更多有意义的完整规则并与我分享,以便我们改进示例;)您可以看一下这些规则此处: https : //github.com/Salaboy/drools-workshop/blob/master/drools-openshift-example/drools-food-kjar/src/main/resources/rules.drl

如您所料:男孩三明治和女孩沙拉:)

您需要了解的关于我们服务的最后一件重要的事情是服务端点如何挑选规则。 我正在使用Drools CDI扩展名@Inject一个KieContainer,可以使用KIE-CI模块来解决该问题,这在我以前的文章中已有解释。

  • https://github.com/Salaboy/drools-workshop/blob/master/drools-openshift-example/drools-food-services/src/main/java/org/drools/workshop/food/endpoint/impl/FoodRecommendationServiceImpl。 java#L33

我们将把这个项目捆绑到一个Docker Image中,该镜像可以根据需要/启动多次。 如果您已经安装在您的本地环境中的码头工人客户端,您可以通过观察它在举办的salaboy / Drools的食品服务形象开始这种食物推荐服务hub.docker.com/salaboy

通过启动Docker映像甚至不知道内部正在运行什么,我们立即注意到以下优点:

  • 除了Docker外,我们不需要安装Java或任何其他工具
  • 我们无需进行任何配置即可运行Rest Service
  • 由于映像托管在hub.docker.com中,我们甚至不需要在本地构建任何内容
  • 我们可以在任何操作系统上运行

同时,我们注意到以下缺点:

  • 我们需要知道我们的服务在哪个IP和端口中被Docker公开
  • 如果我们运行多个映像,则需要跟踪所有IP和端口,并向所有客户通知这些
  • 同一docker映像实例的不同实例之间没有内置的负载平衡方式

为了解决Openshift的这些缺点,更具体地说,Kubernetes可以拯救我们!

在Openshift中配置我们的服务

如前所述,如果我们只是开始创建服务的新Docker Image实例,我们很快就会发现我们的客户将需要知道我们正在运行多少个实例以及如何与每个实例联系。 显然这不好,因此,我们需要一个中间层来处理此问题。 Kubernetes为我们提供了这一抽象和供应层,这使我们可以创建POD的多个实例(在docker映像之上的抽象),并为其配置Replication Controllers和Services 。

Replication Controller的概念提供了一种方法,该方法可以定义在给定时间应运行多少个实例来运行我们的服务。 复制控制器负责确保如果我们至少需要运行3个实例,那么这些实例将一直运行。 如果这些实例之一死亡,则复制控制器将自动为我们生成一个。

Kubernetes中的服务解决了了解所有Docker实例详细信息的问题。 服务使我们能够为客户提供一个立面,以便与我们的Pod实例进行交互。 服务层还允许我们定义一种策略(称为会话亲和力)来定义如何在服务后平衡Pod实例的负载。 有内置策略:ClientIP和Round Robin。

因此,我们现在需要做的事情,我们需要安装Openshift Origin(v3)和项目Drools Controller,该项目将与Kubernetes REST端点进行交互以提供Pod,复制器控制器和服务。

对于Openshift安装,建议您遵循此处描述的步骤: https : //github.com/openshift/origin/blob/master/CONTRIBUTING.adoc

我在笔记本电脑上的上一个链接中介绍了Vagrant选项(第二个选项)。

最后,可以找到一个非常简单的示例,说明如何使用Kubernetes API在这种情况下将我们的drools-food-services供应到Openshift中。

注意,我们正在运行时定义所有内容,这确实很酷,因为我们可以从头开始或修改现有的服务,复制控制器和Pod。

您可以看一下drools-controller项目。 其中显示了我们如何创建指向Docker映像并定义1个副本的复制控制器(默认情况下会创建一个副本)。

  • https://github.com/Salaboy/drools-workshop/blob/master/drools-openshift-example/drools-food-controller/src/main/java/org/drools/workshop/drools/food/controller/Main。Java

如果您登录Openshift Console,您将能够使用Replication Controller和我们Pod的一个副本看到新创建的服务。 通过使用UI(或API,更改Main类),我们可以根据需要提供更多副本。 Kubernetes服务将确保在不同的Pod实例之间实现负载平衡。

瞧!我们的服务副本已启动并正在运行!

瞧! 我们的服务副本已启动并正在运行!

现在,如果通过对映射的Kubernetes服务端口执行GET来访问NodeStat服务,您将获得响应该请求的Pod。 如果您多次执行请求,您应该可以看到循环策略正在实施。

wget http://localhost:9999/api/node {"node":"drools-controller-8tmby","version":"version 1"}
wget http://localhost:9999/api/node {"node":"drools-controller-k9gym","version":"version 1"}
wget http://localhost:9999/api/node {"node":"drools-controller-pzqlu","version":"version 1"}
wget http://localhost:9999/api/node {"node":"drools-controller-8tmby","version":"version 1"}

以相同的方式,您可以在这3个Pod中的每个中与Statless会话进行交互。 在这种情况下,您实际上不需要知道哪个Pod在回答您的请求,您只需要由他们中的任何一个来完成工作即可。

加起来

通过利用Openshift起源基础架构,我们通过不重新发明Kubernetes和Docker等工具中已经存在的机制来简化架构。 在接下来的文章中,我将介绍使用此基础结构的其他一些不错的优点,例如汇总来升级我们的服务版本,增加安全性和Api管理。

如果您对此方法有疑问,请分享您的想法。

翻译自: https://www.javacodegeeks.com/2016/03/high-availability-drools-stateless-service-openshift-origin.html

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

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

相关文章

FTP配置文件详解vsftpd.conf

FTP配置文件详解vsftpd.conf 转载过来做个笔记,原文地址:https://blog.csdn.net/miss520jenny/article/details/92664533 #vi /etc/vsftpd/vsftpd.conf 1.登录和对匿名用户的设置 write_enableYES //是否对登录用户开启写权限。属全局性设…

Visual C++中MFC消息的分类

Visual C中MFC消息的分为三类:标准(窗口)消息、命令消息、控件消息。 1、标准(窗口)消息:窗口消息一般与窗口内部运作有关,如创建窗口,绘制窗口,销毁窗口,通常,消息是从系统发到窗口&#xff0c…

为什么配置了vsftpd.conf文件,用户还是可以访问上级目录?

因为选择的连接类型是 SFTP over SSH 所以访问的是 sftp服务器,sftp的配置文件中没对该用户限制根目录,所以可以访问上一级目录。但是,还是不可以写入了,除了该用户的目录文件,其他文件都是只读。 修改 /etc/ssh/sshd…

来呀,快活呀。iOS 超级码农群:538549344

特大喜讯: iOS开发的小伙伴们,咱们有群了 iOS 超级码农交流群: 538549344 建群源于最近好多人加我QQ交流技术问题,有时忙于工作无法及时回复,为了大家的问题能及时得到解答,还是建个群,群里很多…

jpa jsf_完整的Web应用程序Tomcat JSF Primefaces JPA Hibernate –第1部分

jpa jsf我们创建了这篇文章,将展示如何使用以下工具创建完整的Web应用程序:Tomcat7,带有Primefaces的JSF2(Facelets和Libraries)(具有AutoComplete),JPA / Hibernate(具有…

前端性能优化:Add Expires headers

合理设置 HTTP缓存 缓存的力量是强大的,恰当的缓存设置可以大大的减少 HTTP请求。 很少变化的图片资源可以直接通过 HTTP Header中的Expires设置一个很长的过期头 ;变化不频繁而又可能会变的资源可以使用 Last-Modifed来做请求验证。 (1)Apa…

错题

1. 本题考查String对象的声明和赋值方式。C#中没有new String() 这种方式来构造字符串。故选 AC 2. 在CSS中,控制列表样式的属性有:list-style-type,list-style-position,list-style-image,list-style equals比较的是像…

通过微调JVM Garbage Collector减少Java IDE滞后

有没有想过为什么Eclipse / Netbeans会一直暂停一段时间? 特别是在您想向亲爱的同事展示代码中的内容时? 感觉很尴尬和尴尬,不是吗? 我发现大多数时间由于垃圾收集器的执行而导致IDE暂停。 JVM设计中的微妙元素很少起作用&#x…

centos8部署nginx

Nginx 部署 1.创建 www用户, UID、GID 皆是 501,通过cat /etc/passwd,检查是否存在www用户 ~]# groupadd -g 501 www ~]# useradd -u 501 -g www www ~]# cat /etc/passwd 2.下载相应版本 ~]# wget http://nginx.org/download/nginx-1.16…

javascript-发布订阅模式

说明:本篇文章转载自小火柴的蓝色理想的一篇博文。原文地址:http://www.cnblogs.com/xiaohuochai/p/8031564.html 发布—订阅模式又叫观察者模式,它定义对象间的一对多的依赖关系,当一个对象的状态发生改变时,所有依赖…

centos8部署Django项目---后台运行

参考:https://www.cnblogs.com/yoyoketang/p/10220941.html 一、安装 pip install django创建项目 django-admin startproject mysite打开项目配置settings.py文件 cd mysite/mysitesettings.py文件( DEBUG TrueALLOWED_HOSTS [127.0.0.1, localh…

python-列表list和元组tuple

list Python内置的一种数据类型是列表:list。list是一种有序的集合,可以随时添加和删除其中的元素。 比如,列出班里所有同学的名字,就可以用一个list表示: >>> classmates [Michael, Bob, Tracy] >>&g…

jsf表单验证_动态表单,JSF世界期待已久

jsf表单验证新的PrimeFaces扩展版本0.5.0带来了新的DynaForm组件。 通常,如果知道行/列的数量,元素的位置等,则可以通过h:panelGrid或p:panelGrid构建非常简单的表单。 静态表单是正确的。 但是,如果在运行…

转载黑客是如何黑到你手机的?绝对涨姿势,一位黑客的Wi-Fi入侵实录!

声明:这是一虚构的故事,因此对图片均进行了模糊化处理。内容整理自网络! 故事的主人公小黑是一名从事IT相关工作的技术宅男。五一长假来临,宅在家中的他相当无聊,打开手机上的Wi-Fi模块,发现附近有将近10个…

linux安装pip

使用脚本安装和升级pip 要安装或升级pip,需要下载 get-pip.py. 地址:https://bootstrap.pypa.io/get-pip.py 然后运行以下命令 (需要管理员权限): $ wget https://bootstrap.pypa.io/get-pip.py $ python get-pip.py #查看pip版本 $ pip -V

我们如何意外地将Hibernate的JDBC流量增加了一倍

这篇文章描述了我最近使用Hibernate ORM的经验。 多年以来,该框架并没有让我感到惊讶,您可能会在使用它时遇到性能问题。 我以为我已经看完了,但是这次我又措手不及了。 该问题的基础是在对一个完全不相关的库进行故障排除时建立的&#xff…

html5——DOM扩展

元素获取 1、document.getElementsByClassName (class) 通过类名获取元素,以类数组形式存在。 2、document.querySelector(‘div’) 通过CSS选择器获取元素,符合匹配条件的第1个元素。 3、document.querySelectorAll(selector) 通过CSS选择器获取元素&am…

linux 系统安装mongodb数据库---方法1

参考:https://www.jianshu.com/p/994bc7b19b26 参考:https://blog.csdn.net/duan9015/article/details/106447942/ 1、制作 repo 文件 vim /etc/yum.repos.d/mongodb-org-4.2.repo[mongodb-org-4.2] nameMongoDB Repository baseurlhttps://repo.mongo…

JAVA递归实现全排列

全排列(permutation) 排列组合概念 排列,就是指从给定n个数的元素中取出指定m个数的元素,进行排序 组合,则是指从给定n个数的元素中仅仅取出指定m个数的元素,不考虑排序 全排列 以数字为例,全排…

centos8 linux部署node项目

1、域名解析到服务器 2、上传代码到项目目录 3、数据库: mongo use user user是数据库名 db.nfrc.insert({“name”:admin,“pawwsord”:“123456”}) nfrc集合名,相当于表名 db.nfrc.find() 数据行的id和项目中routes文件下index.js里面的id相一致 …