Eclipse JKube көмегімен Kubernetes үшін Java қосымшаларын жасау

25 жыл бұрын Java бағдарламалаудың негізгі ағымына енді және сайып келгенде, қолданбалы стектерді құрастыратын негізгі элементтердің біріне айналды. Алайда бүгінде көптеген жылдар бойы Java-ға адал болған көптеген адамдар мен ұйымдар көшумен айналысуда немесе платформаға көшуді қарастыруда. Kubernetes немесе оның туындылары, мысалы Red Hat OpenShift немесе Amazon EKS.

Eclipse JKube көмегімен Kubernetes үшін Java қосымшаларын жасау

Өкінішке орай, Кубернетес оқудың тік сызығына ие және Java бағдарламашылары үйренген даму процесіне басқа операциялық деңгейді енгізеді. Бүгін біз сізге қалай пайдалану керектігін айтамыз Eclipse JKube, Kubernetes және контейнерлермен байланысты осы қосымша операцияларды жеңілдету және таныс Java экожүйесін сақтай отырып, бұлттық платформаға ауыртпалықсыз көшуді қамтамасыз ету. Сонымен қатар, біз OpenShift Maven плагинінің көмегімен Java қолданбаларын OpenShift платформасында қалай орналастыру керектігін көрсетеміз.

Дәстүрлі Java әзірлеу процесі

Дәстүрлі даму процесі Java (1-сурет) әзірлеуші ​​кодын жазуды, содан кейін JAR немесе WAR файлдары түрінде орналастыру бірліктерін жасауды, содан кейін осы файлдарды веб немесе қолданба серверінде орналастыруды және іске қосуды қамтиды. Мұны істеудің негізгі жолы - командалық жолдан Maven пайдалану немесе қолданбаларды кодтау және бумалау үшін IntelliJ немесе Eclipse сияқты IDE пайдалану. Әзірлеушілер кодты енгізіп, оны нұсқаны басқаруға жібермес бұрын кодты өзгертуге және барлығын мұқият тексеруге дағдыланады.

Eclipse JKube көмегімен Kubernetes үшін Java қосымшаларын жасау

Күріш. 1. Дәстүрлі Java әзірлеу процесі.

Бұлтқа арналған Java әзірлеу процесі

Бұлтты қолданбаларға көшкен кезде, Kubernetes және контейнерлер. Сондықтан, қазір әзірлеушіге Java қосымшаларын бумалау қажет контейнер суреттері және осы кескіндерді сипаттайтын Кубернетес манифесттерін жасаңыз. Содан кейін бұл манифесттер Kubernetes іске қосылған өндіріс серверіне қолданылады. Өз кезегінде, Кубернетес бұл кескіндерді тізілімнен алады және қолданбаларды әдетте YAML файлдары болып табылатын манифесттерде жазған конфигурацияларға сәйкес орналастырады.

Бұлтқа көшудегі дәстүрлі Java әзірлеу процесінің метаморфозы суретте көрсетілген. 2.

Eclipse JKube көмегімен Kubernetes үшін Java қосымшаларын жасау

Күріш. 2. Бұлтқа арналған Java әзірлеу процесі.

Eclipse JKube

Кубернетеске көшу әзірлеу процесіне тағы бір операциялық деңгей қосады және көптеген әзірлеушілер бұл туралы алаңдайды, өйткені олар оларды қалай орналастыруға емес, өздерінің негізгі жұмысына - қолданба логикасына назар аударғысы келеді. Міне, бұл ойынға түседі. Eclipse JKube, бұл әзірлеушілерге өздерінің кітапханалары мен плагиндерін пайдалануға мүмкіндік береді (JKube жинағы бірге Kubernetes Maven плагині немесе OpenShift Maven плагині) суреттегі диаграмманы орындау арқылы контейнерге және Кубернетеске қатысты әрекеттерді оңай орындау. 2.

Осы мақаланың қалған бөлігінде Eclipse JKube бағдарламасын Kubernetes Maven плагинімен пайдалану арқылы Kubernetes ортасында Java әзірлеу процесін қалай жеңілдету керектігін көрсетеміз.

Eclipse JKube көмегімен бұлтты әзірлеу процесі

Суретте көрсетілгендей, оған Eclipse JKube және Kubernetes Maven Plugin енгізе отырып, 2-суреттегі бұлтқа арналған сәл өзгертілген Java әзірлеу схемасын қарастырайық. 3.

Eclipse JKube көмегімен Kubernetes үшін Java қосымшаларын жасау

Күріш. 3. Eclipse JKube көмегімен бұлтқа арналған Java әзірлеу процесі.

Көріп отырғанымыздай, мұнда Kubernetes және контейнерлермен өзара әрекеттесуге арналған барлық операциялар (диаграммада қызыл түспен белгіленген) кестеде келтірілген әдепкі Eclipse JKube мақсат тапсырмаларымен ауыстырылады. 1.

Кесте 1. Eclipse JKube әдепкі тапсырмалары.

Мақсаты
Кезең
сипаттамасы

k8s: құрастыру
PRE_INTEGRATION_TEST
Докер кескіндерін құру

k8s:басу
ОРНАТУ
Реестрге докер кескіндерін жүктеп салу

k8s:ресурс
PROCESS_RESOURCES
K8 манифесттерін құру

k8s:қолдану
ҚҰРАСТЫРУ
Жасалған манифесттерді K8-ге қолдану

k8s:қолданбау
ҚОЛДАНУ
k8s:apply және k8s:deploy арқылы орналастырылған K8s ресурстарын жою

Ескертпе: Тапсырмалардың осы пікірі бар әдепкі мәндерді пайдаланғанын қаламасаңыз, Eclipse JKube бағдарламасын өзіңіз үшін қолмен конфигурациялауға болады, себебі ол арқылы конфигурациялауды қолдайды. XML и ресурстар.

Енді қолданбалармен жұмыс істеу кезінде Eclipse JKube және Kubernetes Maven Plugin пайдалану мысалдарын қарастырайық.

Eclipse JKube көмегімен Kubernetes жүйесінде Java қолданбасын қолдану

Бұл мысалда біз кластерде қарапайым Java қолданбасын орналастырамыз Миникубе Eclipse JKube көмегімен. Kubernetes Maven плагинін пайдалану арқылы біз кез келген конфигурацияны жазбай-ақ орналастыру параметрлерін орната аламыз.

Мысал ретінде біз қолданамыз қарапайым кездейсоқ сандар генераторы, ол /кездейсоқ соңғы нүктеде 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>

Егер таза Kubernetes орнына OpenShift пайдаланылса, pom.xml келесідей өзгертіледі:

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

2-қадам. Докер кескінін құрастырыңыз

Қолданбаның JAR файлын mvn бумасы пәрменімен құрастыруға болады, содан кейін mvn мақсаты тапсырмасы k8s:build қолданбаның докер кескінін құру үшін пайдаланылуы мүмкін. Осы сипатпен әдепкі сурет атауын қайта анықтағанымызды ескеріңіз:

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

Кескінді құрастырмас бұрын докер демонының дұрыс ашылғанына көз жеткізу керек. Мұны келесі пәрмен арқылы жасауға болады:

$ eval $(minikube docker-env)

Содан кейін біз mvn k8s:build командасын енгіземіз және Eclipse JKube құрастыру тапсырмасын пайдаланып докер кескінін құру кезінде экранда мынаны көреміз:

~/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-қадам. Кескінді докер тізіліміне жүктеңіз

Конфигурацияланған push тізілімімен докер кескінін құрастырғаннан кейін (біздің жағдайда бұл docker.io), біз бұл кескінді тізілімге жібере аламыз. Бұл Eclipse JKube қызметінен mvn k8s: push 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 хабында көреміз, суретте көрсетілгендей. 4.

Eclipse JKube көмегімен Kubernetes үшін Java қосымшаларын жасау

Күріш. 4. Тізілімге жіберілген кескін Docker Hub ішінде пайда болды.

4-қадам. Қолданба үшін 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 application тапсырмасын орындауды сұрағаннан кейін экранда мына нәрсе пайда болады:

~/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 кластерінен қолданбаларды жою

Ол үшін жай ғана алдыңғы қадамда, яғни қолдану тапсырмасы орындалғанда қолданылған барлық ресурстарды алып тастайтын undeploy тапсырмасы пайдаланылады. Eclipse JKube-дан mvn k8s:undeploy 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 арқылы тағы не істеуге болады

Сонымен, біз Kubernetes платформасы үшін Java қосымшаларын әзірлеуді жеңілдететін Eclipse JKube және Kubernetes Maven Plugin негізгі мақсаттық міндеттерін қарастырдық. Егер сіз бұл тапсырмаларды пернетақтадан үнемі енгізгіңіз келмесе, оларды плагин конфигурациясында жаза аласыз, мысалы, келесідей:

<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: жөндеу
Буып-түю
Түзету портын ашыңыз, осылайша Kubernetes жүйесінде жұмыс істейтін қолданбаны тікелей IDE арқылы жөндеуге болады.

k8s:орналастыру
ОРНАТУ
Орнату тапсырмасы үшін шанышқы жасау және жасалған манифесттерді қолдану тапсырмасы жағдайындағы сияқты 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 бағдарламасының Kubernetes-пен жұмыс істеу кезінде Java әзірлеушісінің өмірін қалай жеңілдететінін көрсеттік. Eclipse JKube туралы қосымша ақпаратты мына жерден табуға болады жобаның сайты мен GitHub.

Ақпарат көзі: www.habr.com

пікір қалдыру