3.4. 프런트 엔드 애플리케이션 배포
OpenShift Container Platform에서 애플리케이션을 배포하는 가장 간단한 방법은 제공된 컨테이너 이미지를 실행하는 것입니다.
다음 절차에서는 national-parks-app
애플리케이션의 프런트 엔드 구성 요소인 parksmap
을 배포합니다. 웹 애플리케이션에는 전 세계의 국립 공원 위치에 대한 대화형 맵이 표시됩니다.
사전 요구 사항
- OpenShift Container Platform 클러스터에 액세스 권한을 보유합니다.
-
OpenShift CLI(
oc
)가 설치되어 있습니다.
프로세스
다음 명령을 실행하여
parksmap
애플리케이션을 배포합니다.oc new-app quay.io/openshiftroadshow/parksmap:latest --name=parksmap -l 'app=national-parks-app,component=parksmap,role=frontend,app.kubernetes.io/part-of=national-parks-app'
$ oc new-app quay.io/openshiftroadshow/parksmap:latest --name=parksmap -l 'app=national-parks-app,component=parksmap,role=frontend,app.kubernetes.io/part-of=national-parks-app'
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 출력 예
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
3.4.1. 프런트 엔드 서비스 노출 링크 복사링크가 클립보드에 복사되었습니다!
기본적으로 OpenShift Container Platform에서 실행되는 서비스는 외부에서 액세스할 수 없습니다.
외부 클라이언트가 액세스할 수 있도록 서비스를 공개하려면 경로를 생성할 수 있습니다. Route
오브젝트는 Kubernetes Ingress
오브젝트와 유사한 OpenShift Container Platform 네트워킹 리소스입니다. 기본 OpenShift Container Platform 라우터(HAProxy)는 들어오는 요청의 HTTP 헤더를 사용하여 연결을 프록시할 위치를 결정합니다.
선택적으로 경로에 대해 TLS와 같은 보안을 정의할 수 있습니다.
사전 요구 사항
-
parksmap
프런트 엔드 애플리케이션을 배포했습니다. -
cluster-admin
또는 프로젝트 수준관리자
권한이 있어야 합니다.
프로세스
다음 명령을 실행하여
parksmap
프런트 엔드 애플리케이션을 공개할 경로를 생성합니다.oc create route edge parksmap --service=parksmap
$ oc create route edge parksmap --service=parksmap
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
검증
다음 명령을 실행하여 애플리케이션 경로가 성공적으로 생성되었는지 확인합니다.
oc get route parksmap
$ oc get route parksmap
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 출력 예
NAME HOST/PORT PATH SERVICES PORT TERMINATION WILDCARD parksmap parksmap-user-getting-started.apps.cluster.example.com parksmap 8080-tcp edge None
NAME HOST/PORT PATH SERVICES PORT TERMINATION WILDCARD parksmap parksmap-user-getting-started.apps.cluster.example.com parksmap 8080-tcp edge None
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
3.4.2. Pod 세부 정보 보기 링크 복사링크가 클립보드에 복사되었습니다!
OpenShift Container Platform에서는 하나의 호스트에 함께 배포되는 하나 이상의 컨테이너이자 정의, 배포 및 관리할 수 있는 최소 컴퓨팅 단위인 Pod 의 Kubernetes 개념을 사용합니다. Pod는 컨테이너에 대한 머신 인스턴스, 물리 또는 가상과 대략적으로 동일합니다.
클러스터의 Pod를 보고 해당 Pod 및 클러스터의 상태를 전체적으로 확인할 수 있습니다.
사전 요구 사항
-
parksmap
프런트 엔드 애플리케이션을 배포했습니다.
프로세스
다음 명령을 실행하여 현재 프로젝트의 모든 Pod를 나열합니다.
oc get pods
$ oc get pods
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 출력 예
NAME READY STATUS RESTARTS AGE parksmap-5f9579955-6sng8 1/1 Running 0 77s
NAME READY STATUS RESTARTS AGE parksmap-5f9579955-6sng8 1/1 Running 0 77s
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 다음 명령을 실행하여 Pod 세부 정보를 표시합니다.
oc describe pod parksmap-5f9579955-6sng8
$ oc describe pod parksmap-5f9579955-6sng8
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 출력 예
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 다음 명령을 실행하여 Pod의 로그를 확인합니다.
oc logs parksmap-5f9579955-6sng8
$ oc logs parksmap-5f9579955-6sng8
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 출력 예
... 2025-03-26 18:03:24.774 INFO 1 --- [ main] o.s.m.s.b.SimpleBrokerMessageHandler : Started. 2025-03-26 18:03:24.798 INFO 1 --- [ main] s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat started on port(s): 8080 (http) 2025-03-26 18:03:24.801 INFO 1 --- [ main] c.o.evg.roadshow.ParksMapApplication : Started ParksMapApplication in 4.053 seconds (JVM running for 4.46)
... 2025-03-26 18:03:24.774 INFO 1 --- [ main] o.s.m.s.b.SimpleBrokerMessageHandler : Started. 2025-03-26 18:03:24.798 INFO 1 --- [ main] s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat started on port(s): 8080 (http) 2025-03-26 18:03:24.801 INFO 1 --- [ main] c.o.evg.roadshow.ParksMapApplication : Started ParksMapApplication in 4.053 seconds (JVM running for 4.46)
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
3.4.3. 배포 확장 링크 복사링크가 클립보드에 복사되었습니다!
Kubernetes에서 Deployment
오브젝트는 애플리케이션이 배포하는 방법을 정의합니다. 애플리케이션을 배포할 때 OpenShift Container Platform은 포드
,서비스
,ReplicaSet
및 배포
리소스를 생성합니다.
parksmap
이미지를 배포하면 배포 리소스가 생성됩니다. 이 예에서는 하나의 Pod만 배포됩니다. 사용자 요구에 맞게 애플리케이션을 확장하거나 하나의 Pod가 다운된 경우에도 애플리케이션이 항상 실행 중인지 확인할 수 있습니다.
다음 절차에서는 두 개의 인스턴스를 사용하도록 parksmap
배포를 스케일링합니다.
사전 요구 사항
-
parksmap
프런트 엔드 애플리케이션을 배포했습니다.
프로세스
다음 명령을 실행하여 배포를 하나의 Pod 인스턴스에서 두 개의 Pod 인스턴스로 확장합니다.
oc scale --replicas=2 deployment/parksmap
$ oc scale --replicas=2 deployment/parksmap
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 출력 예
deployment.apps/parksmap scaled
deployment.apps/parksmap scaled
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
검증
다음 명령을 실행하여 배포가 올바르게 확장되었는지 확인합니다.
oc get pods
$ oc get pods
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 출력 예
NAME READY STATUS RESTARTS AGE parksmap-5f9579955-6sng8 1/1 Running 0 7m39s parksmap-5f9579955-8tgft 1/1 Running 0 24s
NAME READY STATUS RESTARTS AGE parksmap-5f9579955-6sng8 1/1 Running 0 7m39s parksmap-5f9579955-8tgft 1/1 Running 0 24s
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 두 개의
parksmap
Pod가 나열되어 있는지 확인합니다.
배포를 하나의 Pod 인스턴스로 다시 축소하려면 1
을 --replicas
옵션으로 전달합니다.
oc scale --replicas=1 deployment/parksmap
$ oc scale --replicas=1 deployment/parksmap