使用 Eclipse JKube 为 Kubernetes 开发 Java 应用程序

25 年前,Java 进入了编程主流,并最终成为构建应用程序堆栈的核心元素之一。 然而如今,许多多年来一直忠于 Java 的个人和组织正忙于迁移或考虑迁移到该平台。 Kubernetes 或其衍生物,例如 红帽OpenShift или 亚马逊EKS.

使用 Eclipse JKube 为 Kubernetes 开发 Java 应用程序

不幸的是,Kubernetes 的学习曲线很陡峭,并且在 Java 程序员习惯的开发过程中引入了另一个操作层。 今天我们就来告诉大家如何使用 Eclipse JKube,简化这些与 Kubernetes 和容器相关的额外操作,并确保轻松迁移到云平台,同时保持熟悉的 Java 生态系统。 此外,我们将展示如何使用 OpenShift Maven 插件在 OpenShift 平台上部署 Java 应用程序。

传统Java开发流程

传统开发流程 爪哇岛 (图 1)涉及开发人员编写代码,然后以 JAR 或 WAR 文件的形式创建部署单元,然后在 Web 或应用程序服务器上部署和运行这些文件。 执行此操作的主要方法是从命令行使用 Maven 或使用 IntelliJ 或 Eclipse 等 IDE 来编码和打包应用程序。 开发人员习惯于在提交代码并将其提交给版本控制之前进行代码更改并彻底测试所有内容。

使用 Eclipse JKube 为 Kubernetes 开发 Java 应用程序

米。 1.传统Java开发流程。

云 Java 开发流程

当迁移到云应用程序时,Kubernetes 和 集装箱。 因此,现在开发者需要将Java应用程序打包在 容器 图片 并创建描述这些镜像的 Kubernetes 清单。 然后,这些清单将应用到运行 Kubernetes 的生产服务器。 反过来,Kubernetes 从注册表中获取这些镜像,并根据我们在清单(通常是 YAML 文件)中编写的配置来部署应用程序。

传统Java开发流程向云转型的蜕变如图2所示。 XNUMX.

使用 Eclipse JKube 为 Kubernetes 开发 Java 应用程序

米。 2. 云Java开发流程。

Eclipse JKube

迁移到 Kubernetes 为开发过程增加了另一个操作层,许多开发人员对此感到紧张,因为他们希望专注于核心工作(应用程序逻辑),而不是如何部署它们。 这就是它发挥作用的地方。 Eclipse JKube,它允许开发人员使用他们的库和插件(JKube套件Kubernetes Maven 插件 или OpenShift Maven 插件)按照图中的示意图轻松执行容器和 Kubernetes 相关操作。 2.

在本文的其余部分中,我们将向您展示如何通过使用 Eclipse JKube 和 Kubernetes Maven 插件来简化 Kubernetes 环境中的 Java 开发过程。

使用 Eclipse JKube 的云开发流程

我们考虑一下图2中稍微修改一下的云Java开发方案,引入Eclipse JKube和Kubernetes Maven Plugin,如图3所示。 XNUMX.

使用 Eclipse JKube 为 Kubernetes 开发 Java 应用程序

米。 3. 使用Eclipse JKube进行云Java开发流程。

正如我们所看到的,这里所有与 Kubernetes 和容器交互的操作(图中以红色突出显示)都被默认的 Eclipse JKube 目标任务替换,这些任务在表中列出。 1.

桌子1. Eclipse JKube默认任务。

任务
阶段
使用说明

k8s:构建
预集成测试
构建 docker 镜像

k8s:推送
载点
将docker镜像上传到registry

k8s:资源
PROCESS_RESOURCES
生成 K8s 清单

k8s:申请
编译
将生成的清单应用到 K8s

k8s:取消部署
取消部署
删除使用 k8s:apply 和 k8s:deploy 部署的 K8s 资源

注: 如果您不希望任务使用这些固执己见的默认值,您可以自己手动配置 Eclipse JKube,因为它支持通过以下方式进行配置 XML и 资源.

现在让我们看一下在处​​理应用程序时使用 Eclipse JKube 和 Kubernetes Maven 插件的示例。

使用 Eclipse JKube 在 Kubernetes 上部署 Java 应用程序

在此示例中,我们将在集群上部署一个简单的 Java 应用程序 迷你酷 使用 Eclipse JKube。 使用 Kubernetes Maven Plugin,我们可以设置部署参数,而无需编写任何配置。

作为示例应用程序,我们使用 简单的随机数生成器,它在 /random 端点生成 JSON 输出:

~/work/repos/eclipse-jkube-demo-project : $ curl localhost:8080/random | jq .
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100    45    0    45    0     0    818      0 --:--:-- --:--:-- --:--:--   818
{
  "id": "e80a4d10-c79b-4b9a-aaac-7c286cb37f3c"
}

步骤1.下载 Kubernetes Maven 插件

Kubernetes Maven 插件位于存储库中 Maven中央存储库。 要使用 Eclipse JKube,您需要将 Kubernetes Maven 插件作为依赖项添加到 pom.xml 中:

<plugin>
     <groupId>org.eclipse.jkube</groupId>
     <artifactId>kubernetes-maven-plugin</artifactId>
     <version>${jkube.version}</version>
 </plugin>

如果使用OpenShift而不是纯Kubernetes,则pom.xml修改如下:

<plugin>
     <groupId>org.eclipse.jkube</groupId>
     <artifactId>openshift-maven-plugin</artifactId>
     <version>${jkube.version}</version>
 </plugin>

步骤2.构建docker镜像

可以使用 mvn package 命令构建应用程序的 JAR 文件,然后使用 mvn 目标任务 k8s:build 构建应用程序的 docker 镜像。 请注意,我们已使用此属性覆盖默认图像名称:

<jkube.generator.name>docker.io/rohankanojia/random-generator:${project.version}</jkube.generator.name>

在构建镜像之前,您需要确保 docker 守护进程已正确暴露。 这可以通过以下命令来完成:

$ eval $(minikube docker-env)

然后我们输入 mvn k8s:build 命令,这就是使用 Eclipse JKube 构建任务构建 docker 镜像时我们将在屏幕上看到的内容:

~/work/repos/eclipse-jkube-demo-project : $ mvn k8s:build
[INFO] Scanning for projects...
[INFO] 
[INFO] ----------------------< meetup:random-generator >-----------------------
[INFO] Building random-generator 0.0.1
[INFO] --------------------------------[ jar ]---------------------------------
[INFO] 
[INFO] --- kubernetes-maven-plugin:1.0.0-rc-1:build (default-cli) @ random-generator ---
[INFO] k8s: Running in Kubernetes mode
[INFO] k8s: Building Docker image in Kubernetes mode
[INFO] k8s: Running generator spring-boot
[INFO] k8s: spring-boot: Using Docker image quay.io/jkube/jkube-java-binary-s2i:0.0.7 as base / builder
[INFO] k8s: [docker.io/rohankanojia/random-generator:0.0.1] "spring-boot": Created docker-build.tar in 251 milliseconds
[INFO] k8s: [docker.io/rohankanojia/random-generator:0.0.1] "spring-boot": Built image sha256:a20e5
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time:  5.053 s
[INFO] Finished at: 2020-08-10T11:28:23+05:30
[INFO] ------------------------------------------------------------------------
~/work/repos/eclipse-jkube-demo-project : $

步骤3.将镜像上传到docker注册表

在我们构建了配置了推送注册表的 docker 镜像后(在我们的例子中是 docker.io),我们可以将该镜像发送到注册表。 这是我们要求 Eclipse JKube 执行 mvn k8s:push 推送任务后将显示的内容:

~/work/repos/eclipse-jkube-demo-project : $ mvn k8s:push
[INFO] Scanning for projects...
[INFO] 
[INFO] ----------------------< meetup:random-generator >-----------------------
[INFO] Building random-generator 0.0.1
[INFO] --------------------------------[ jar ]---------------------------------
[INFO] 
[INFO] --- kubernetes-maven-plugin:1.0.0-rc-1:push (default-cli) @ random-generator ---
[INFO] k8s: Running in Kubernetes mode
[INFO] k8s: Building Docker image in Kubernetes mode
[INFO] k8s: Running generator spring-boot
[INFO] k8s: spring-boot: Using Docker image quay.io/jkube/jkube-java-binary-s2i:0.0.7 as base / builder
[INFO] k8s: The push refers to repository [docker.io/rohankanojia/random-generator]
5dcd9556710f: Layer already exists 
b7139ad07aa8: Layer already exists 
b6f081e4b2b6: Layer already exists 
d8e1f35641ac: Layer already exists 
[INFO] k8s: 0.0.1: digest: sha256:9f9eda2a13b8cab1d2c9e474248500145fc09e2922fe3735692f9bda4c76002d size: 1162
[INFO] k8s: Pushed docker.io/rohankanojia/random-generator:0.0.1 in 7 seconds 
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time:  11.222 s
[INFO] Finished at: 2020-08-10T11:35:37+05:30
[INFO] ------------------------------------------------------------------------
~/work/repos/eclipse-jkube-demo-project : $ 

发送图像后,您需要检查它是否包含在注册表中。 在我们的例子中,我们只是在 Docker Hub 中看到它,如图 4 所示。 XNUMX.

使用 Eclipse JKube 为 Kubernetes 开发 Java 应用程序

米。 4.发送到registry的镜像出现在Docker Hub中。

步骤 4. 为应用程序生成 Kubernetes 资源清单

所以,我们已经收集了应用程序镜像,现在我们需要编写 Kubernetes 清单。 为此,Eclipse JKube 有一项任务,即根据底层 Java 框架生成严格的资源清单(春季靴, 夸库斯、Vert.x 或其他)。 您还可以通过使用 XML 配置文件并将原始片段(所需资源清单的片段)放在应用程序文件夹 src/main/jkube 中来自定义清单。 在这种情况下,您的配置将上传到生成的清单中。

在我们的示例中,我们保留一切原样,因此 Eclipse JKube 为默认部署和类型为 ClusterIP 的服务生成一个清单。 然后我们修改服务清单,将服务类型更改为 NodePort。 您可以使用以下属性覆盖默认行为:

<jkube.enricher.jkube-service.type>NodePort</jkube.enricher.jkube-service.type>

这就是我们要求 Eclipse JKube 执行 mvn k8s:resource 资源任务后屏幕输出的样子。

~/work/repos/eclipse-jkube-demo-project : $ mvn k8s:resource
[INFO] Scanning for projects...
[INFO] 
[INFO] ----------------------< meetup:random-generator >-----------------------
[INFO] Building random-generator 0.0.1
[INFO] --------------------------------[ jar ]---------------------------------
[INFO] 
[INFO] --- kubernetes-maven-plugin:1.0.0-rc-1:resource (default-cli) @ random-generator ---
[INFO] k8s: Running generator spring-boot
[INFO] k8s: spring-boot: Using Docker image quay.io/jkube/jkube-java-binary-s2i:0.0.7 as base / builder
[INFO] k8s: jkube-controller: Adding a default Deployment
[INFO] k8s: jkube-service: Adding a default service 'random-generator' with ports [8080]
[INFO] k8s: jkube-healthcheck-spring-boot: Adding readiness probe on port 8080, path='/actuator/health', scheme='HTTP', with initial delay 10 seconds
[INFO] k8s: jkube-healthcheck-spring-boot: Adding liveness probe on port 8080, path='/actuator/health', scheme='HTTP', with initial delay 180 seconds
[INFO] k8s: jkube-revision-history: Adding revision history limit to 2
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time:  3.344 s
[INFO] Finished at: 2020-08-10T11:38:11+05:30
[INFO] ------------------------------------------------------------------------
~/work/repos/eclipse-jkube-demo-project : $ ls target/classes/META-INF/jkube/kubernetes
random-generator-deployment.yml  random-generator-service.yml
~/work/repos/eclipse-jkube-demo-project : $ cat target/classes/META-INF/jkube/kubernetes/random-generator-deployment.yml | head -n10
---
apiVersion: apps/v1
kind: Deployment
metadata:
  annotations:
    jkube.io/git-url: [email protected]:rohanKanojia/eclipse-jkube-demo-project.git
    jkube.io/git-commit: 1ef9ef2ef7a6fcbf8eb64c293f26f9c42d026512
    jkube.io/git-branch: master
    jkube.io/scm-url: https://github.com/spring-projects/spring-boot/spring-boot-starter-parent/random-generator
    jkube.io/scm-tag: HEAD
~/work/repos/eclipse-jkube-demo-project : $

步骤 5. 将应用程序部署到 Kubernetes 集群

现在我们已经准备好部署应用程序:我们已经生成了它的映像,然后自动生成了资源清单。 现在剩下的就是将这一切应用到 Kubernetes 集群上。 要部署应用程序,您当然可以使用 kubectl apply -f 命令,但插件可以为我们执行此操作。 这是我们要求 Eclipse JKube 执行 mvn k8s:apply apply 任务后屏幕上会出现的内容:

~/work/repos/eclipse-jkube-demo-project : $ mvn k8s:apply
[INFO] Scanning for projects...
[INFO] 
[INFO] ----------------------< meetup:random-generator >-----------------------
[INFO] Building random-generator 0.0.1
[INFO] --------------------------------[ jar ]---------------------------------
[INFO] 
[INFO] --- kubernetes-maven-plugin:1.0.0-rc-1:apply (default-cli) @ random-generator ---
[INFO] k8s: Using Kubernetes at https://192.168.39.145:8443/ in namespace default with manifest /home/rohaan/work/repos/eclipse-jkube-demo-project/target/classes/META-INF/jkube/kubernetes.yml 
[INFO] k8s: Using namespace: default
[INFO] k8s: Creating a Service from kubernetes.yml namespace default name random-generator
[INFO] k8s: Created Service: target/jkube/applyJson/default/service-random-generator.json
[INFO] k8s: Creating a Deployment from kubernetes.yml namespace default name random-generator
[INFO] k8s: Created Deployment: target/jkube/applyJson/default/deployment-random-generator.json
[INFO] k8s: HINT: Use the command `kubectl get pods -w` to watch your pods start up
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time:  7.306 s
[INFO] Finished at: 2020-08-10T11:40:57+05:30
[INFO] ------------------------------------------------------------------------
~/work/repos/eclipse-jkube-demo-project : $ kubectl get pods -w
NAME                                                     READY   STATUS             RESTARTS   AGE
random-generator-58b7847d7f-9m9df                        0/1     Running            0          7s
random-generator-58b7847d7f-9m9df                        1/1     Running            0          17s
^C~/work/repos/eclipse-jkube-demo-project : $ kubectl get svc
NAME                                    TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)           AGE
io-openliberty-sample-getting-started   NodePort    10.110.4.104    <none>        9080:30570/TCP    44h
kubernetes                              ClusterIP   10.96.0.1       <none>        443/TCP           18d
random-generator                        NodePort    10.97.172.147   <none>        8080:32186/TCP    22s
~/work/repos/eclipse-jkube-demo-project : $ curl `minikube ip`:32186/random | jq .
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100    45    0    45    0     0   1800      0 --:--:-- --:--:-- --:--:--  1875
{
  "id": "42e5571f-a20f-44b3-8184-370356581d10"
}

步骤 6. 从 Kubernetes 集群中取消部署应用程序

为此,需要使用取消部署任务,该任务只是删除上一步(即执行应用任务时)应用的所有资源。 这是我们要求 Eclipse JKube 执行 mvn k8s:undeploy 取消部署任务后,我们将在屏幕上看到的内容:

~/work/repos/eclipse-jkube-demo-project : $ kubectl get all
NAME                                    READY   STATUS    RESTARTS   AGE
pod/random-generator-58b7847d7f-9m9df   1/1     Running   0          5m21s

NAME                       TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)          AGE
service/kubernetes         ClusterIP   10.96.0.1       <none>        443/TCP          18d
service/random-generator   NodePort    10.97.172.147   <none>        8080:32186/TCP   5m21s

NAME                               READY   UP-TO-DATE   AVAILABLE   AGE
deployment.apps/random-generator   1/1     1            1           5m21s

NAME                                          DESIRED   CURRENT   READY   AGE
replicaset.apps/random-generator-58b7847d7f   1         1         1       5m21s
~/work/repos/eclipse-jkube-demo-project : $ mvn k8s:undeploy
[INFO] Scanning for projects...
[INFO] 
[INFO] ----------------------< meetup:random-generator >-----------------------
[INFO] Building random-generator 0.0.1
[INFO] --------------------------------[ jar ]---------------------------------
[INFO] 
[INFO] --- kubernetes-maven-plugin:1.0.0-rc-1:undeploy (default-cli) @ random-generator ---
[INFO] k8s: Using Kubernetes at https://192.168.39.145:8443/ in namespace default with manifest /home/rohaan/work/repos/eclipse-jkube-demo-project/target/classes/META-INF/jkube/kubernetes.yml 
[INFO] k8s: Using namespace: default
[INFO] k8s: Deleting resource Deployment default/random-generator
[INFO] k8s: Deleting resource Service default/random-generator
[INFO] k8s: HINT: Use the command `kubectl get pods -w` to watch your pods start up
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time:  3.412 s
[INFO] Finished at: 2020-08-10T11:46:22+05:30
[INFO] ------------------------------------------------------------------------
~/work/repos/eclipse-jkube-demo-project : $ kubectl get pods -w
^C~/work/repos/eclipse-jkube-demo-project : $ kubectl get all
NAME                 TYPE        CLUSTER-IP   EXTERNAL-IP   PORT(S)   AGE
service/kubernetes   ClusterIP   10.96.0.1    <none>        443/TCP   18d
~/work/repos/eclipse-jkube-demo-project : $

使用 Eclipse JKube 还可以做什么

因此,我们研究了 Eclipse JKube 和 Kubernetes Maven Plugin 的主要目标任务,它们促进了 Kubernetes 平台的 Java 应用程序的开发。 如果你不想不断地从键盘输入这些任务,你可以将它们写在插件配置中,例如,像这样:

<plugin>
     <groupId>org.eclipse.jkube</groupId>
     <artifactId>kubernetes-maven-plugin</artifactId>
     <version>${project.version}</version>
     <executions>
         <execution>
             <goals>
                  <goal>build</goal>
                  <goal>resource</goal>
                  <goal>apply</goal>
             </goals>
         </execution>
     </executions>
</plugin>

必须指出的是,在本文中,我们没有考虑 Eclipse JKube 和 Kubernetes Maven 插件中的所有目标任务,因此我们在表 2 中提供了可能对您也有用的其他任务列表。

桌子2. 其他 Eclipse JKube 目标任务。

任务
阶段
使用说明

k8s:日志
验证
从 Kubernetes 上运行的应用程序接收日志。

k8s:调试

打开调试端口,以便您可以直接从 IDE 调试在 Kubernetes 上运行的应用程序。

k8s:部署
载点
为 Install 任务创建一个分支,并以与 apply 任务相同的方式将生成的清单应用到 Kubernetes 集群。

k8s:手表

通过跟踪应用程序的命名空间来自动热部署应用程序。

使用 OpenShift Maven 插件在 Red Hat OpenShift 上部署 Java 应用程序

为了在 Red Hat OpenShift 平台上部署示例中的应用程序,我们使用插件 OpenShift Maven。 唯一的区别是任务前缀将从 k8s 更改为 oc。 默认情况下,Kubernetes Maven 插件会 搬运工人- 程序集和 OpenShift Maven 插件 - 程序集 S2I。 除了删除 jkube.generator.name 属性之外,我们没有对项目进行任何更改,因为推送到注册表时不需要它(OpenShift 在构建阶段将图像放置在其内部注册表中)。 这就是我们运行示例时屏幕上显示的内容,顺便说一句,我们不是一次执行一个目标任务,而是一次执行所有目标任务:

~/work/repos/eclipse-jkube-demo-project : $ mvn oc:build oc:resource oc:apply
[INFO] Scanning for projects...
[INFO] 
[INFO] ----------------------< meetup:random-generator >-----------------------
[INFO] Building random-generator 0.0.1
[INFO] --------------------------------[ jar ]---------------------------------
[INFO] 
[INFO] --- openshift-maven-plugin:1.0.0-rc-1:build (default-cli) @ random-generator ---
[INFO] oc: Using OpenShift build with strategy S2I
[INFO] oc: Running in OpenShift mode
[INFO] oc: Running generator spring-boot
[INFO] oc: spring-boot: Using Docker image quay.io/jkube/jkube-java-binary-s2i:0.0.7 as base / builder
[INFO] oc: [random-generator:0.0.1] "spring-boot": Created docker source tar /home/rohaan/work/repos/eclipse-jkube-demo-project/target/docker/random-generator/0.0.1/tmp/docker-build.tar
[INFO] oc: Adding to Secret pullsecret-jkube
[INFO] oc: Using Secret pullsecret-jkube
[INFO] oc: Creating BuildServiceConfig random-generator-s2i for Source build
[INFO] oc: Creating ImageStream random-generator
[INFO] oc: Starting Build random-generator-s2i
[INFO] oc: Waiting for build random-generator-s2i-1 to complete...
[INFO] oc: Caching blobs under "/var/cache/blobs".
[INFO] oc: Getting image source signatures
[INFO] oc: Copying blob sha256:cf0f3ebe9f536c782ab3835049cfbd9a663761ded9370791ef6ea3965c823aad
[INFO] oc: Copying blob sha256:57de4da701b511cba33bbdc424757f7f3b408bea741ca714ace265da9b59191a
[INFO] oc: Copying blob sha256:f320f94d91a064281f5127d5f49954b481062c7d56cce3b09910e471cf849050
[INFO] oc: Copying config sha256:52d6788fcfdd39595264d34a3959464a5dabc1d4ef0ae188802b20fc2d6a857b
[INFO] oc: Writing manifest to image destination
[INFO] oc: Storing signatures
[INFO] oc: Generating dockerfile with builder image quay.io/jkube/jkube-java-binary-s2i:0.0.7
[INFO] oc: STEP 1: FROM quay.io/jkube/jkube-java-binary-s2i:0.0.7
[INFO] oc: STEP 2: LABEL "io.openshift.build.source-location"="/tmp/build/inputs"       "io.openshift.build.image"="quay.io/jkube/jkube-java-binary-s2i:0.0.7"
[INFO] oc: STEP 3: ENV JAVA_APP_DIR="/deployments"     OPENSHIFT_BUILD_NAME="random-generator-s2i-1"     OPENSHIFT_BUILD_NAMESPACE="default"
[INFO] oc: STEP 4: USER root
[INFO] oc: STEP 5: COPY upload/src /tmp/src
[INFO] oc: STEP 6: RUN chown -R 1000:0 /tmp/src
[INFO] oc: STEP 7: USER 1000
[INFO] oc: STEP 8: RUN /usr/local/s2i/assemble
[INFO] oc: INFO S2I source build with plain binaries detected
[INFO] oc: INFO S2I binary build from fabric8-maven-plugin detected
[INFO] oc: INFO Copying binaries from /tmp/src/deployments to /deployments ...
[INFO] oc: random-generator-0.0.1.jar
[INFO] oc: INFO Copying deployments from deployments to /deployments...
[INFO] oc: '/tmp/src/deployments/random-generator-0.0.1.jar' -> '/deployments/random-generator-0.0.1.jar'
[INFO] oc: STEP 9: CMD /usr/local/s2i/run
[INFO] oc: STEP 10: COMMIT temp.builder.openshift.io/default/random-generator-s2i-1:48795e41
[INFO] oc: time="2020-08-10T06:37:49Z" level=info msg="Image operating system mismatch: image uses "", expecting "linux""
[INFO] oc: time="2020-08-10T06:37:49Z" level=info msg="Image architecture mismatch: image uses "", expecting "amd64""
[INFO] oc: Getting image source signatures
[INFO] oc: Copying blob sha256:d8e1f35641acb80b562f70cf49911341dfbe8c86f4d522b18efbf3732aa74223
[INFO] oc: Copying blob sha256:b6f081e4b2b6de8be4b1dec132043d14c121e968384dd624fb69c2c07b482edb
[INFO] oc: Copying blob sha256:b7139ad07aa8ce4ed5a132f7c5cc9f1de0f5099b5e155027a23d57f7fbe78b16
[INFO] oc: Copying blob sha256:98972fc90a1108315cc5b05b2c691a0849a149727a7b81e76bc847ac2c6d9714
[INFO] oc: Copying config sha256:27aaadaf28e24856a66db962b88118b8222b61d79163dceeeed869f7289bc230
[INFO] oc: Writing manifest to image destination
[INFO] oc: Storing signatures
[INFO] oc: --> 27aaadaf28e
[INFO] oc: 27aaadaf28e24856a66db962b88118b8222b61d79163dceeeed869f7289bc230
[INFO] oc: Getting image source signatures
[INFO] oc: 
[INFO] oc: Pushing image image-registry.openshift-image-registry.svc:5000/default/random-generator:0.0.1 ...
[INFO] oc: Copying blob sha256:f320f94d91a064281f5127d5f49954b481062c7d56cce3b09910e471cf849050
[INFO] oc: Copying blob sha256:cf0f3ebe9f536c782ab3835049cfbd9a663761ded9370791ef6ea3965c823aad
[INFO] oc: Copying blob sha256:57de4da701b511cba33bbdc424757f7f3b408bea741ca714ace265da9b59191a
[INFO] oc: Copying blob sha256:98972fc90a1108315cc5b05b2c691a0849a149727a7b81e76bc847ac2c6d9714
[INFO] oc: Copying config sha256:27aaadaf28e24856a66db962b88118b8222b61d79163dceeeed869f7289bc230
[INFO] oc: Writing manifest to image destination
[INFO] oc: Storing signatures
[INFO] oc: Successfully pushed image-registry.openshift-image-registry.svc:5000/default/random-generator@sha256:aa9e1a380c04ef9174ba56459c13d44420ebe653ebf32884d60fe4306b17306d
[INFO] oc: Push successful
[INFO] oc: Build random-generator-s2i-1 in status Complete
[INFO] oc: Found tag on ImageStream random-generator tag: sha256:aa9e1a380c04ef9174ba56459c13d44420ebe653ebf32884d60fe4306b17306d
[INFO] oc: ImageStream random-generator written to /home/rohaan/work/repos/eclipse-jkube-demo-project/target/random-generator-is.yml
[INFO] 
[INFO] --- openshift-maven-plugin:1.0.0-rc-1:resource (default-cli) @ random-generator ---
[INFO] oc: Using docker image name of namespace: default
[INFO] oc: Running generator spring-boot
[INFO] oc: spring-boot: Using Docker image quay.io/jkube/jkube-java-binary-s2i:0.0.7 as base / builder
[INFO] oc: jkube-controller: Adding a default DeploymentConfig
[INFO] oc: jkube-service: Adding a default service 'random-generator' with ports [8080]
[INFO] oc: jkube-healthcheck-spring-boot: Adding readiness probe on port 8080, path='/actuator/health', scheme='HTTP', with initial delay 10 seconds
[INFO] oc: jkube-healthcheck-spring-boot: Adding liveness probe on port 8080, path='/actuator/health', scheme='HTTP', with initial delay 180 seconds
[INFO] oc: jkube-revision-history: Adding revision history limit to 2
[INFO] 
[INFO] --- openshift-maven-plugin:1.0.0-rc-1:apply (default-cli) @ random-generator ---
[INFO] oc: Using OpenShift at https://api.crc.testing:6443/ in namespace default with manifest /home/rohaan/work/repos/eclipse-jkube-demo-project/target/classes/META-INF/jkube/openshift.yml 
[INFO] oc: OpenShift platform detected
[INFO] oc: Using project: default
[INFO] oc: Creating a Service from openshift.yml namespace default name random-generator
[INFO] oc: Created Service: target/jkube/applyJson/default/service-random-generator.json
[INFO] oc: Creating a DeploymentConfig from openshift.yml namespace default name random-generator
[INFO] oc: Created DeploymentConfig: target/jkube/applyJson/default/deploymentconfig-random-generator.json
[INFO] oc: Creating Route default:random-generator host: null
[INFO] oc: HINT: Use the command `oc get pods -w` to watch your pods start up
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time:  01:07 min
[INFO] Finished at: 2020-08-10T12:08:00+05:30
[INFO] ------------------------------------------------------------------------
~/work/repos/eclipse-jkube-demo-project : $ oc get pods -w
NAME                           READY     STATUS      RESTARTS   AGE
random-generator-1-deploy      1/1       Running     0          14s
random-generator-1-vnrm9       0/1       Running     0          11s
random-generator-s2i-1-build   0/1       Completed   0          1m
random-generator-1-vnrm9   1/1       Running   0         24s
random-generator-1-deploy   0/1       Completed   0         28s
~/work/repos/eclipse-jkube-demo-project : $ oc get routes
NAME                HOST/PORT                                    PATH      SERVICES            PORT      TERMINATION   WILDCARD
random-generator    random-generator-default.apps-crc.testing              random-generator    8080                    None
~/work/repos/eclipse-jkube-demo-project : $ curl random-generator-default.apps-crc.testing/random 
% Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
Dload  Upload   Total   Spent    Left  Speed
100    45    0    45    0     0   1666      0 --:--:-- --:--:-- --:--:--  1730
{
"id": "d80052d9-2f92-43cb-b9eb-d7cffb879798"
}
~/work/repos/eclipse-jkube-demo-project : $

视频课程

要详细了解如何使用 Eclipse JKube 简化 Kubernetes 开发,请观看此视频教程,了解如何在 Minikube 上快速部署简单的 Spring Boot 应用程序:

结论

在本文中,我们展示了 Eclipse JKube 如何让 Java 开发人员在使用 Kubernetes 时变得更轻松。 有关 Eclipse JKube 的更多信息,请访问 项目网站GitHub上.

来源: habr.com

添加评论