在OpenShift上部署Java EE微服务

我昨天用WildFly Swarm在博客上发布了有关简单JAX-RS微服务的博客。 您学习了如何使用Maven构建一个所谓的“胖子”,还使用Maven Docker插件对我们的微服务进行了Docker化并在Docker Machine上本地运行。 这是在本地测试事物的好方法。 到目前为止,缺少的是将其投入生产。 让我们看一下在OpenShift Origin上运行昨天的示例所需的步骤。

企业Java开发人员为什么要关心?

但是首先,让我们简要地探讨为什么Enterprise Java开发人员甚至应该关心所有这些。 关于最近的炒作和嗡嗡声,我有些疑惑。 当然,它们构成了一个有趣的运动场,您可以花费数小时来下载容器图像并在笔记本电脑上运行它们。 但是到目前为止,将它们投入生产是一个挑战。 Nigel的博客文章很好,关于Docker中不推荐使用的功能 。 它还有另一个宝石:一段称为“企业影响力”。 主要报价是:

“我敢肯定,这类事情总是在很酷的时髦公司[...]中完成的,但是绝对不会在生锈的老公司[...]中完成。”

(奈杰尔·波顿)

我绝对可以支持。 企业开发人员,架构师和项目经理正在采用慢得多且保守的方法来采用所有这些技术。 他们正在寻找成功管理基础架构和项目的方法。 所有这些技术都将进入我们的日常工作中,但它们将以更易于管理的方式出现。 因此,我们只是在做作业,对所有这些进行自我教育,并评估可以帮助我们的解决方案。 但是足够的一般思想; 让我们开始部署和扩展Java EE应用程序。

先决条件

安装并运行OpenShift Origin,并按照以下步骤在Docker容器中构建WildFly Swarm JAX-RS微服务 。 因为这是示例,所以我将进一步部署和扩展。

注意:我同时使用OpenShift项目中的all-in-vm和Fabric8项目提供的Vagrant映像,它们可以互换。它们的工作原理几乎相同,并且都依赖于OpenShift Origin。 .f8,例如代码或示例之一中的https://vagrant.f8:8443,则可以使用localhost或其他可互换的主机映射。)

什么是OpenShift起源?

OpenShift Origin是Red Hat分布式应用程序系统OpenShift的上游开源版本。 我们启动了这个项目,以提供一个平台,开发团队可以在该平台上构建和管理基于Docker和Kubernetes的云本机应用程序。 您可以在Github上找到源代码 ,我们知道您有改善OpenShift Origin的好主意。 因此,请袖手旁观, 加入我们的社区 。

掌握所有集成技术有很多知识。 但是社区正在努力使这对我们(企业Java开发人员)尽可能地易于理解和管理。 为了给您OpenShift的简要概述,这是所有工作原理的简单示意图:

起源概述

如果您一直在关注有关Docker和Kubernetes的最新话题,那么您会在这里看到很多常见的部分。 请求通过客户端进入,并在路由层结束。 它被分发到服务,并命中了一个容器,该容器在容器中运行我们的Docker映像之一。 吊舱由复制控制器控制。 当然,还有很多事情要做,但这应该是您现在需要了解的全部知识,以便对整个事情有一个初步的了解。

另一个更详细的概述为您提供了我们今天将要使用的零件的更精确的概念。

来源概览2

尤其是现在,集成的Docker注册表,映像流,部署配置和路由到我们的服务特别重要。

基础知识–管理界面和客户端工具

设置无用信息框并将其启动后,可以通过浏览到以下地址来访问基于Web的管理:https:// localhost:8443。 多合一虚拟机没有配置安全性。 这意味着将使用“全部允许”身份提供者。 您可以使用任何非空的用户名和密码登录。 “管理员”用户是具有所有权限的管理用户。 使用“ admin / admin”登录可让您充分使用Origin。 基于Web的管理非常适合查看日志文件和整体情况。 它(尚未)功能齐全,并且不允许您进行调整或更改。 首先,您需要使用命令行工具:“ oc”。 与网络管理类似,您还必须登录到OpenShift:

oc login https://localhost:8443

还提示您输入用户名和密码(admin / admin),并显示项目列表:

Authentication required for https://vagrant.f8:8443 (openshift)
Username: admin
Password:
Login successful.Using project "default".
You have access to the following projects and can switch between them with 'oc project <projectname>':* default (current)* openshift* openshift-infra

现在,您可以在OpenShift中进行一些管理了。

公开内部Docker注册表

如果我们想在OpenShift中运行dockerized应用程序,而docker-hub中没有该应用程序,则需要将其推送到OpenShift Docker Registry。 默认情况下,它不是外部公开的,因此首先要做的是通过Route在OpenShift Docker Registry中公开该构建。

oc create -f registry-route.json

json文件包含路由的定义,并签入我的Github存储库。 确保根据需要调整第8行中的主机名 。 为了使该示例正常工作,我在Windows上的主机文件中添加了以下映射:

172.28.128.4 registry.vagrant.f8

成功创建路由后,您所要做的就是相应地设置环境(在关注我的介绍性博客文章时,您已经完成了此操作。这只是在提醒您):

set DOCKER_HOST=tcp://vagrant.f8:2375

创建一个项目和一个用户

让我们为我们的示例创建一个新项目。 由于名称空间的原因,我们将在用户名和图像名之后精确命名项目:在本示例中为“ myfear”。

oc new-project myfear --description="WildFly Swarm Docker Image on OpenShift v3" --display-name="WildFly Swarm Project"

描述和显示名称是可选的,但可以使其在Web界面中看起来更好。

起源项目

让我们通过简单地登录为以下用户来创建用户“ myfear”:

c login https://vagrant.f8:8443 -u myfear

调整示例

我们需要从昨天的示例中更改pom.xml的某些部分。 首先,我们需要告诉Docker Maven插件,它应该使用运行在Registry.vagrant.f8:80的私有注册表。 想知道为什么不是5000端口? 因为,我们通过OpenShift公开了服务,而HAProxy通过端口80公开了该服务。取消注释pom.xml中的两行 :

<docker.host>tcp://vagrant.f8:2375</docker.host>
<docker.registry>registry.vagrant.f8:80</docker.registry>

并通过oc客户端工具获取用户myfear的登录令牌:

$oc whoami -t

这将输出如下内容:

ykHRzUGGu-FAo_ZS5RJFcndjYw0ry3bskMgFjqK1SZk

现在,在pom的<authConfig>元素中更新令牌。 基本上就是这样。

建立并推动形象

该图像已经在我之前的博客文章中构建,但是让我们在这里再次做它:

mvn clean install docker:build

现在将映像推送到我们的OpenShift Docker Registry:

mvn docker:push

它将输出将映像推送到registry.vagrant.f8:80 / myfear / swarm-sample的过程。

在OpenShift上运行Docker映像

现在,我们仅使用常规方法在OpenShift上启动新的Docker映像:

oc new-app --docker-image=myfear/swarm-sample:latest

观察发生了什么:OpenShift实际上在幕后创建了一些资源,以便处理部署和运行此Docker映像。 首先,它创建了一个服务,该服务标识它将代理和负载平衡的一组Pod。 服务分配IP地址和端口对,访问时将重定向到适当的后端。您关心服务的原因是,它们基本上充当Pod和需要使用内部运行Pod的任何事物之间的代理/负载平衡器。 OpenShift环境。 使用describe命令获取有关从我们的映像创建的OpenShift的完整描述:

oc describe service swarm-sample

哪个输出:

Name:                   swarm-sample
Namespace:              myfear
Labels:                 app=swarm-sample
Selector:               app=swarm-sample,deploymentconfig=swarm-sample
Type:                   ClusterIP
IP:                     172.30.25.44
Port:                   8080-tcp        8080/TCP
Endpoints:              172.17.0.5:8080
Session Affinity:       None
No events.

到目前为止,我们缺少的一件事是通过路线的外部映射。 您还记得我们为Docker Registry做的事情吗? 这是到目前为止的下一步也是最后一步。

oc expose service swarm-sample --hostname=wildfly-swarm.vagrant.f8

您可能已经猜到了,我们还需要在主机文件中映射主机名:

172.28.128.4    wildfly-swarm.vagrant.f8

我们完成了。 为什么我没有使用json文件创建路由? 因为我想向您展示,只要图像为端口使用正确的EXPOSE定义,它就会更容易,因此ocpose命令可以完成此工作而不必弄乱json。 这是相同的结果。

浏览至:http://wildfly-swarm.vagrant.f8/rs/customer并查看输出:

{"text":"WildFly Swarm Docker Application on OpenShift at http://wildfly-swarm.vagrant.f8/rs/ - Hostname: swarm-sample-1-7mmd7"}

主机名是容器,容器在其上运行。

翻译自: https://www.javacodegeeks.com/2015/10/deploying-java-ee-microservices-on-openshift.html

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

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

相关文章

rocketmq 订阅组_必须先理解的RocketMQ入门手册,才能再次深入解读

推荐阅读一下下2020年后想跳槽&#xff1f;MQ、ZK、Nginx、Kafk等分布式技术你都掌握了&#xff1f;阿里架构师推荐学习的《RabbitMQ实战指南》&#xff0c;渣渣的你都看过吗&#xff1f;RocketMQ入门手册RocketMQ是一个分布式、队列模型的开源消息中间件&#xff0c;前身是Met…

关于返回按钮的事情

在微信的项目涉及到多个不同的项目间跳转那么头部的返回按钮怎么办呢&#xff1f; 在项目之间跳转还有在微信菜单进入页面时我们用了一个中转页进行参数处理和页面跳转判断 目前要用到code&#xff0c;userId等从后端写好的带参数的url到前端获取然后去调用后端的一个校验code和…

.net数据源控件绑定mysql_理解asp.net中DropDownList编辑数据源,绑定数据库数据。...

一、理解asp.net绑定数据库终于学习到了连接数据库部分的内容&#xff0c;杨中科老师视频看起来挺轻松的&#xff0c;如果是高清版就更ok了。我发现我学习新的编程语言会有一个特点&#xff0c;都想要赶紧学习数据库&#xff0c;数据就是一切&#xff0c;有了数据才能操作一切的…

jetty代理jetty_如何在Jetty中使用SPDY

jetty代理jettySPDY是Google提出的一种新协议&#xff0c;是针对网络的新协议。 SPDY与HTTP兼容&#xff0c;但尝试通过压缩&#xff0c;多路复用和优先级降低网页负载。准确地说&#xff0c;快速的目标是&#xff1a;&#xff08; http://dev.chromium.org/spdy/spdy-whitepap…

五指棋,贪吃蛇,中国银行ATM源码链接

https://i.cnblogs.com/Files.aspx 转载于:https://www.cnblogs.com/weixiaoling/p/6083710.html

mysql select db error_select error:不能用DB-library(如isql)不能用DB-library(如isql

在我们php连接mssql出现select error:不能用DB-library(如isql)或odbc3.7或更早版本将ntext数据或仅使用Unicode排序规则的Unicode数据发送到客户端不能用DB-Library(如 ISQL)或 ODBC 3.7或更早版本将 ntext 数据Warning: mssql_query() [function.mssql- query]: message: 不能…

排序算法之二分治法

MERGE(A,p,q,r) n1 q-p1 n2 r-q let L[1..n_11] and R[1..n_21] be new arraysfor i 1 to n_1   L[i] A[pi-1]for j 1 to n_2   R[j] A[qj] L[n_11] \infty R[n_21] \infty i 1 j 1for k p to r   ifL[i] \leq R[j]     A[k] L[i]     i i1else A[k…

将Java EE与jOOQ结合使用的初学者指南

Java EE附带了自己的持久性API&#xff1a;JPA。 当您想要将RDBMS实体&#xff08;表/关系&#xff09;映射到Java实体&#xff08;类&#xff09;时&#xff0c;JPA最强大&#xff0c;主要遵循1&#xff1a;1映射策略。 其背后的想法是&#xff0c;业务逻辑通常并不像关系代数…

niva mysql_Nivacat for mysql是一种第三方提供的()_学小易找答案

【单选题】以下不包括在OSI环境中的是【单选题】以下不是直接推动新疆建省原因的选项是( ) (3.0分)【填空题】TOEFL stands for 1____________________________. More than four thousand American universities and other schools require students seeking 2________ to take…

清理SYSAUX表空间

1.查看SYSAUX表空间中数据分布情况 col SEGMENT_NAME for a30 set lines 999 select * from (select segment_name,PARTITION_NAME,segment_type,bytes/1024/1024 from dba_segments where tablespace_nameSYSAUX order by 4 desc) where rownum<10; 2.删除WRH$_LATCH_CHILD…

mysql备份需要停应用吗_对于含有innodb表的实例进行文件拷贝备份时必须停mysql实例吗...

展开全部在实际环境中&#xff0c;62616964757a686964616fe59b9ee7ad9431333361313261时不时需要备份恢复单个或多个表(注意&#xff1a;这里除非明确指定&#xff0c;所说的表一律指InnoDB表)&#xff0c;而对于innodb引擎恢复单个表需要整体的恢复&#xff0c;xtrabackup也可…

Apache Camel 2.16发布–十大亮点

Apache Camel 2.16于上周五发布。 这篇博客文章是我尝试在此新版本中进行前10名&#xff08;加1作为奖励&#xff09;的亮点。 1.动态到 来自骆驼用户的最常见的常见问题是如何将消息发送到端点&#xff0c;uri应该使用消息中的动态值&#xff08;例如标头&#xff09;。 在…

[原创软件]体验组批量加分工具

软件主要功能&#xff1a; 从excel批量导入用户QQ、昵称、年龄信息批量粘贴用户QQ或昵称进行筛选批量添加积分软件界面截图&#xff1a; 开发环境及语言&#xff1a; c#.NET Framework 4.0Visual Studio 2015更新日志&#xff1a; v1.2&#xff08;2016.9.30&#xff09; 增加格…

java8 filter return_java8新特性Java 8 Streams filter示例 - Java教程

在这篇教程中我将向你展示 filter(), collect(), findAny() 和 orElse() 的用法1. Streams filter() 和 collect()1.1 在 Java 8 以前, 像下面这样过滤一个 List:BeforeJava8.javapackage com.mkyong.java8;import java.util.ArrayList;import java.util.Arrays;import java.ut…

java 线性表的表示和实现_线性表中顺序表的的理解和实现(java)

线性表的顺序表示指的是用一组地址连续的存储单元以此存储线性表的数据元素&#xff0c;这种表示也称作线性表的顺序存储结构或顺序映像。通常&#xff0c;称这种存储结构的线性表为顺序表。特点是&#xff1a;逻辑上相邻的数据元素&#xff0c;其物理次序上也是相邻的。顺序表…

akka连接是什么_什么是Akka?

akka连接是什么在深入探讨什么是Akka之前&#xff0c;让我们退后一步来了解并发编程的概念在应用程序开发世界中是如何演变的。 应用程序已从大型的整体程序演变为面向对象的模型。 随着Java EE和Spring框架的出现&#xff0c;应用程序设计演变为更多的基于流程或任务的设计模型…

java socket 判断断网_java socket 判断对方在线或离线、断线

1 在客户端和服务器端做心跳检测(这个后来我放弃了)2 客户端中断连接&#xff0c;服务器会抛出异常&#xff0c;利用这点3这是我为什么不用心跳包的原因&#xff0c;因为不需要了。 有的时候&#xff0c;我们可能网络突然中断了。但是服务器依然会监听那个连接。而且很长都不抛…

java 可重入读写锁 ReentrantReadWriteLock 详解

详见&#xff1a;http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt206 读写锁 ReadWriteLock读写锁维护了一对相关的锁&#xff0c;一个用于只读操作&#xff0c;一个用于写入操作。只要没有writer&#xff0c;读取锁可以由多个reader线程同时保持。写入锁是独占的…

将JPA Hibernate与OptaPlanner集成

我们一直在改进OptaPlanner与JEE其余部分的集成&#xff0c;因此&#xff0c;构建可以正常工作的最终用户应用程序更加容易。 让我们看一下改进的JPA Hibernate集成。 基础 JPA Hibernate和OptaPlanner都可以在POJO&#xff08;普通的旧Java对象&#xff09;上工作&#xff0c…

c java 系统开发_java开发系统内核:使用C语言开发系统应用程序

更详细的讲解和代码调试演示过程&#xff0c;请参看视频用java开发C语言编译器如果你对机器学习感兴趣&#xff0c;请参看一下链接&#xff1a;机器学习&#xff1a;神经网络导论我们的操作系统通过增添内核接口导出机制后&#xff0c;已经可以作为平台&#xff0c;运行应用程序…