OpenShift-퀵 가이드

OpenShift는 Red Hat에서 호스팅하는 클라우드 개발 PaaS (Platform as a Service)입니다. 애플리케이션을 생성, 테스트 및 실행하고 마지막으로 클라우드에 배포하는 데 사용되는 오픈 소스 클라우드 기반 사용자 친화적 인 플랫폼입니다.

OpenShift는 Node.js, Ruby, Python, Perl 및 Java와 같은 다양한 언어로 작성된 애플리케이션을 관리 할 수 ​​있습니다. OpenShift의 주요 기능 중 하나는 확장 가능하므로 사용자가 다른 언어로 작성된 애플리케이션을 지원하는 데 도움이됩니다.

OpenShift는 추상화 계층으로 다양한 가상화 개념을 제공합니다. OpenShift의 기본 개념은 가상화를 기반으로합니다.

가상화

일반적으로 가상화는 시스템, 스토리지 또는 운영 체제에서 시작하는 모든 것의 물리적 또는 실제 버전이 아닌 가상 시스템의 생성으로 정의 될 수 있습니다. 가상화의 주요 목표는 IT 인프라의 확장 성과 안정성을 높이는 것입니다. 가상화의 개념은 수십 년 동안 존재 해 왔으며 오늘날 IT 산업의 발전과 함께 시스템 수준, 하드웨어 수준에서 서버 수준 가상화에 이르기까지 광범위한 계층에 적용될 수 있습니다.

작동 원리

모든 응용 프로그램 또는 운영 체제가 실제 물리적 계층에서 추상화되는 기술로 설명 할 수 있습니다. 가상화 기술의 주요 용도 중 하나는 하이퍼 바이저라는 소프트웨어를 사용하여 기본 하드웨어에서 계층을 추상화하는 서버 가상화입니다. 가상화에서 실행되는 운영 체제의 성능은 물리적 하드웨어에서 실행될 때만 큼 좋습니다. 그러나 실행중인 대부분의 시스템 및 응용 프로그램에서 기본 하드웨어를 사용할 필요가 없기 때문에 가상화 개념이 널리 사용됩니다.

물리적 대 가상 아키텍처

가상화 유형

  • Application Virtualization−이 방법에서 애플리케이션은 기본 운영 체제에서 추상화됩니다. 이 방법은 아래의 운영 체제에 의존하지 않고 응용 프로그램을 격리하여 실행할 수있는 경우 매우 유용합니다.

  • Desktop Virtualization−이 방법은 데스크에서 씬 클라이언트를 사용하여 원격으로 데스크톱에 액세스 할 수있는 워크 스테이션 부하를 줄이는 데 사용됩니다. 이 방법에서 데스크톱은 대부분 데이터 센터에서 실행됩니다. 전형적인 예는 대부분의 조직에서 사용되는 VDI (Virtual Desktop Image) 일 수 있습니다.

  • Data Virtualization − 기존의 데이터 및 데이터 관리 방법을 추상화하고 탈피하는 방법입니다.

  • Server Virtualization−이 방법에서는 물리적 서버, 프로세스 및 운영 체제를 포함하는 서버 관련 리소스가 가상화됩니다. 이러한 추상화를 가능하게하는 소프트웨어를 종종 하이퍼 바이저라고합니다.

  • Storage Virtualization − 단일 중앙 콘솔에서 관리되는 단일 저장 장치로 여러 저장 장치를 풀링하는 과정입니다.

  • Network Virtualization − 사용 가능한 모든 네트워크 리소스를 서로 독립적 인 사용 가능한 대역폭과 채널을 분할하여 결합하는 방법입니다.

OpenShift

OpenShift는 클라우드 지원 애플리케이션 PaaS (Platform as a Service)입니다. 조직이 기존 애플리케이션 인프라와 플랫폼을 물리적 가상 매체에서 클라우드로 이동하는 데 도움이되는 오픈 소스 기술입니다.

OpenShift는 OpenShift 클라우드 플랫폼에서 쉽게 개발하고 배포 할 수있는 매우 다양한 애플리케이션을 지원합니다. OpenShift는 기본적으로 개발자와 사용자를 위해 세 가지 종류의 플랫폼을 지원합니다.

IaaS (Infrastructure as a Service)

이 형식에서 서비스 제공 업체는 미리 정의 된 가상 하드웨어 구성이있는 하드웨어 수준 가상 머신을 제공합니다. 이 공간에는 AWS Google 클라우드, Rackspace 등에서 시작하는 여러 경쟁자가 있습니다.

오랜 설치 및 투자 절차를 거친 후 IaaS를 사용할 때의 가장 큰 단점은 운영 체제 및 서버 패키지의 설치 및 유지 관리, 인프라 네트워크 관리, 기본 시스템 관리 처리를 여전히 책임지고 있다는 것입니다.

SaaS (Software as a Service)

SaaS를 사용하면 기본 인프라에 대해 걱정할 필요가 없습니다. 플러그 앤 플레이처럼 간단합니다. 사용자는 서비스에 가입하고 사용하기 만하면됩니다. 이 설정의 가장 큰 단점은 서비스 공급자가 허용하는 최소한의 사용자 지정 만 수행 할 수 있다는 것입니다. SaaS의 가장 일반적인 예 중 하나는 사용자가 로그인하여 사용하기 만하면되는 Gmail입니다. 사용자는 자신의 계정을 약간 수정할 수도 있습니다. 그러나 개발자의 관점에서는별로 유용하지 않습니다.

PaaS (Platform as a Service)

SaaS와 IaaS 사이의 중간 계층으로 간주 할 수 있습니다. PaaS 평가의 주요 대상은 몇 가지 명령으로 개발 환경을 가동 할 수있는 개발자를위한 것입니다. 이러한 환경은 데이터베이스가있는 웹 응용 프로그램 서버를 사용하는 것에서 바로 모든 개발 요구 사항을 충족 할 수 있도록 설계되었습니다. 이렇게하려면 단일 명령 만 있으면 서비스 제공자가 대신 작업을 수행합니다.

OpenShift를 사용하는 이유

OpenShift는 엔터프라이즈 단위가 기본 운영 체제에 대한 걱정없이 클라우드에서 애플리케이션을 호스팅 할 수있는 공통 플랫폼을 제공합니다. 따라서 클라우드에서 애플리케이션을 사용, 개발 및 배포하기가 매우 쉽습니다. 주요 기능 중 하나는 모든 종류의 개발 및 테스트를 위해 관리되는 하드웨어 및 네트워크 리소스를 제공한다는 것입니다. OpenShift를 사용하면 PaaS 개발자는 사양에 따라 필요한 환경을 자유롭게 설계 할 수 있습니다.

OpenShift는 서비스 계획과 관련하여 다양한 종류의 서비스 수준 계약을 제공합니다.

Free −이 플랜은 3 년으로 제한되며 각 1GB 공간이 있습니다.

Bronze −이 플랜에는 3 년이 포함되며 연간 1GB 공간으로 최대 16 년까지 확장됩니다.

Sliver − 이것은 16 년 브론즈 플랜이지만 추가 비용없이 6GB의 저장 용량을 제공합니다.

위의 기능 외에도 OpenShift는 OpenShift Enterprise로 알려진 온 프레미스 버전도 제공합니다. OpenShift에서 개발자는 확장 가능하고 확장 불가능한 애플리케이션을 설계 할 수 있으며 이러한 설계는 HAproxy 서버를 사용하여 구현됩니다.

풍모

OpenShift에서 지원하는 여러 기능이 있습니다. 그들 중 소수는-

  • 다국어 지원
  • 다중 데이터베이스 지원
  • 확장 가능한 카트리지 시스템
  • 소스 코드 버전 관리
  • 원 클릭 배포
  • 다중 환경 지원
  • 표준화 된 개발자의 워크 플로우
  • 종속성 및 빌드 관리
  • 자동 애플리케이션 확장
  • 반응 형 웹 콘솔
  • 풍부한 명령 줄 도구 세트
  • 애플리케이션에 대한 원격 SSH 로그인
  • Rest API 지원
  • 셀프 서비스 온 디맨드 애플리케이션 스택
  • 기본 제공 데이터베이스 서비스
  • 지속적인 통합 및 릴리스 관리
  • IDE 통합
  • 응용 프로그램의 원격 디버깅

OpenShift는 주로 연도와 카트리지의 개념을 기반으로하는 OpenShift V2라는 기반에서 탄생했습니다. 각 구성 요소는 시스템 생성부터 애플리케이션 배포, 애플리케이션 구축에서 배포까지 사양이 있습니다.

Cartridges − 환경에서 실행하는 데 필요한 애플리케이션 유형과이 섹션에서 충족하는 모든 종속성에서 시작하여 새로운 애플리케이션을 구축하는 데 초점을 맞췄습니다.

year− 리소스, 메모리 및 CPU에 대한 특정 사양을 가진 베어 메탈 머신 또는 서버로 정의 할 수 있습니다. 응용 프로그램을 실행하기위한 기본 단위로 간주되었습니다.

Application − 이는 단순히 OpenShift 환경에서 배포 및 실행되는 애플리케이션 또는 통합 애플리케이션을 나타냅니다.

섹션을 더 자세히 살펴보면 OpenShift의 다양한 형식과 제품에 대해 논의 할 것입니다. 초기에 OpenShift에는 세 가지 주요 버전이있었습니다.

OpenShift Origin− 이것은 OpenShift의 커뮤니티 추가 또는 오픈 소스 버전이었습니다. 다른 두 버전의 업스트림 프로젝트라고도합니다.

OpenShift Online − AWS에서 호스팅되는 서비스로서의 공공 PaaS입니다.

OpenShift Enterprise − ISV 및 공급 업체 라이선스가 포함 된 OpenShift의 강화 된 버전입니다.

OpenShift 온라인

OpenShift online은 공용 클라우드에서 컨테이너화 된 애플리케이션을 빠르게 빌드, 배포 및 확장 할 수있는 OpenShift 커뮤니티의 제품입니다. Red Hat의 퍼블릭 클라우드 애플리케이션 개발 및 호스팅 플랫폼으로, 개발자가 애플리케이션 로직 작성에 집중할 수 있도록 애플리케이션의 자동화 된 프로비저닝, 관리 및 확장이 가능합니다.

Red Hat OpenShift Online에서 계정 설정

Step 1 − 브라우저로 이동하여 사이트를 방문하십시오. https://manage.openshift.com/

Step 2 − Red Hat 계정이있는 경우 다음 URL을 사용하여 Red Hat 로그인 ID와 비밀번호를 사용하여 OpenShift 계정에 로그인합니다. https://developers.redhat.com

Step 3 − Red Hat 계정 로그인이없는 경우 다음 링크를 사용하여 OpenShift 온라인 서비스에 가입하십시오.

https://developers.redhat.com/auth/realms/rhd/login-actions/registration?code=G4w-myLd3GCH_QZCqMUmIOQlU7DIf_gfIvGu38nnzZQ.cb229a9d-3cff-4c58-b7f6-7b2c9eb17926

로그인하면 다음 페이지가 표시됩니다.

모든 것이 준비되면 Red Hat은 다음 스크린 샷과 같이 몇 가지 기본 계정 세부 정보를 표시합니다.

마지막으로 로그인하면 다음 페이지가 표시됩니다.

OpenShift 컨테이너 플랫폼

OpenShift 컨테이너 플랫폼은 개발 및 IT 운영 팀과 같은 여러 팀이 컨테이너화 된 인프라를 구축하고 배포하는 데 도움이되는 엔터프라이즈 플랫폼입니다. OpenShift에 내장 된 모든 컨테이너는 공개적으로 호스팅되는 클라우드 플랫폼의 모든 데이터 센터에 배포 할 수있는 매우 안정적인 Docker 컨테이너화 기술을 사용합니다.

OpenShift 컨테이너 플랫폼은 공식적으로 OpenShift Enterprises로 알려졌습니다. 이는 Kubernetes에서 오케스트레이션 및 관리를 관리하는 Docker 기반 애플리케이션 컨테이너의 핵심 개념을 기반으로 구축 된 Red Hat 온 프레미스 프라이빗 플랫폼 서비스입니다.

즉, OpenShift는 Docker와 Kubernetes를 엔터프라이즈 수준으로 통합합니다. 엔터프라이즈 단위가 선택한 인프라에서 지원자를 배포하고 관리하기위한 컨테이너 플랫폼 소프트웨어입니다. 예를 들어 AWS 인스턴스에서 OpenShift 인스턴스를 호스팅합니다.

OpenShift 컨테이너 플랫폼은 two package levels.

OpenShift Container Local− 이것은 로컬 컴퓨터에 응용 프로그램을 배포하고 테스트하려는 개발자를위한 것입니다. 이 패키지는 주로 개발 팀에서 응용 프로그램을 개발하고 테스트하는 데 사용됩니다.

OpenShift Container Lab − 개발부터 배포, 사전 제작 환경까지 애플리케이션의 확장 된 평가를 위해 설계되었습니다.

OpenShift 전용

이것은 OpenShift 포트폴리오에 추가 된 또 다른 오퍼링으로, 고객이 선택한 퍼블릭 클라우드에서 컨테이너화 된 플랫폼을 호스팅 할 수 있습니다. 이를 통해 최종 사용자는 자신의 요구를 충족하는 모든 클라우드에서 OpenShift를 사용할 수있는 멀티 클라우드 서비스에 대한 진정한 의미를 갖게됩니다.

이는 최종 사용자가 OpenShift를 사용하여 테스트 배포를 구축하고 클라우드에서 호스팅되는 OpenShift에서 애플리케이션을 실행할 수있는 Red Hat의 최신 제품 중 하나입니다.

OpenShift Dedicated의 기능

OpenShift 전용은 퍼블릭 클라우드에서 맞춤형 솔루션 애플리케이션 플랫폼을 제공하며 OpenShift 3 기술을 계승합니다.

  • Extensible and Open − 이것은 Docker의 개방형 개념을 기반으로 구축되고 클라우드에 배포되므로 필요할 때 자체적으로 사용할 수 있습니다.

  • Portability − Docker를 사용하여 구축되었으므로 Docker에서 실행되는 애플리케이션은 Docker가 지원되는 한 곳에서 다른 곳으로 쉽게 배송 될 수 있습니다.

  • Orchestration − OpenShift 3에서는 컨테이너 오케스트레이션 및 클러스터 관리의 핵심 기능 중 하나가 OpenShift 버전 3과 함께 제공되는 Kubernetes를 사용하여 지원됩니다.

  • Automation −이 버전의 OpenShift는 소스 코드 관리, 빌드 자동화 및 배포 자동화 기능을 사용하여 플랫폼으로서 서비스 제공 업체로서 시장에서 매우 인기가 있습니다.

OpenShift의 경쟁자

Google App Engine− 웹 애플리케이션 개발 및 호스팅을위한 Google의 무료 플랫폼입니다. Google의 앱 엔진은 빠른 개발 및 배포 플랫폼을 제공합니다.

Microsoft Azure − Azure 클라우드는 데이터 센터에서 Microsoft가 호스팅합니다.

Amazon Elastic Cloud Compute − 클라우드에서 확장 가능한 웹 애플리케이션을 개발하고 호스팅하는 데 도움이되는 Amazon에서 제공하는 기본 제공 서비스입니다.

Cloud Foundry − Java, Ruby, Python 및 Node.js 애플리케이션을위한 오픈 소스 PaaS 플랫폼입니다.

CloudStack − Apache의 CloudStack은 Citrix에서 개발 한 프로젝트이며 OpenShift 및 OpenStack의 직접적인 경쟁자가되도록 설계되었습니다.

OpenStack − 클라우드 컴퓨팅을 위해 Red Hat에서 제공하는 또 다른 클라우드 기술.

Kubernetes − Docker 컨테이너를 관리하기 위해 구축 된 직접 오케스트레이션 및 클러스터 관리 기술입니다.

OpenShift는 Kubernetes 및 Docker 클러스터를 사용하여 각 계층이 다른 계층과 긴밀하게 연결되는 계층화 된 시스템입니다. OpenShift의 아키텍처는 Kubernetes를 사용하여 모든 계층에서 호스팅되는 Docker 컨테이너를 지원하고 관리 할 수 ​​있도록 설계되었습니다. 이전 버전의 OpenShift V2와 달리 새 버전의 OpenShift V3는 컨테이너화 된 인프라를 지원합니다. 이 모델에서 Docker는 경량 Linux 기반 컨테이너 생성을 지원하고 Kubernetes는 여러 호스트에서 컨테이너 조정 및 관리 작업을 지원합니다.

OpenShift의 구성 요소

OpenShift 아키텍처의 핵심 구성 요소 중 하나는 Kubernetes에서 컨테이너화 된 인프라를 관리하는 것입니다. Kubernetes는 인프라 배포 및 관리를 담당합니다. 모든 Kubernetes 클러스터에서 하나 이상의 마스터와 여러 노드를 가질 수 있으므로 설정에 실패 지점이 없습니다.

Kubernetes 마스터 머신 구성 요소

Etcd− 클러스터의 각 노드에서 사용할 수있는 구성 정보를 저장합니다. 여러 노드에 분산 될 수있는 고 가용성 키 값 저장소입니다. 민감한 정보가있을 수 있으므로 Kubernetes API 서버에서만 액세스 할 수 있어야합니다. 모든 사람이 접근 할 수있는 분산 키 값 저장소입니다.

API Server− Kubernetes는 API를 사용하여 클러스터에서 모든 작업을 제공하는 API 서버입니다. API 서버는 다른 도구와 라이브러리가 쉽게 통신 할 수있는 인터페이스를 구현합니다. kubeconfig는 통신에 사용할 수있는 서버 측 도구와 함께 패키지입니다. Kubernetes API를 노출합니다.”

Controller Manager−이 구성 요소는 클러스터 상태를 조절하고 작업을 수행하는 대부분의 수집기를 담당합니다. 비 종료 루프에서 실행되는 데몬으로 간주 할 수 있으며 정보를 수집하여 API 서버로 보내는 역할을합니다. 클러스터의 공유 상태를 가져오고 서버의 현재 상태를 원하는 상태로 가져 오도록 변경합니다. 키 컨트롤러는 복제 컨트롤러, 끝점 컨트롤러, 네임 스페이스 컨트롤러 및 서비스 계정 컨트롤러입니다. 컨트롤러 관리자는 노드, 엔드 포인트 등을 처리하기 위해 다른 종류의 컨트롤러를 실행합니다.

Scheduler− Kubernetes 마스터의 핵심 구성 요소입니다. 워크로드 분배를 담당하는 마스터의 서비스입니다. 클러스터 노드에서 작업 부하의 활용도를 추적 한 다음 리소스를 사용할 수있는 작업 부하를 배치하고 작업 부하를 수락합니다. 즉, 사용 가능한 노드에 포드를 할당하는 메커니즘입니다. 스케줄러는 워크로드 사용률과 새 노드에 포드 할당을 담당합니다.

Kubernetes 노드 구성 요소

다음은 Kubernetes 마스터와 통신하는 데 필요한 노드 서버의 주요 구성 요소입니다.

Docker − 각 노드의 첫 번째 요구 사항은 비교적 격리되어 있지만 가벼운 운영 환경에서 캡슐화 된 애플리케이션 컨테이너를 실행하는 데 도움이되는 Docker입니다.

Kubelet Service− 이것은 각 노드의 작은 서비스로, 제어 플레인 서비스와 정보를 중계하는 역할을합니다. etcd 저장소와 상호 작용하여 구성 세부 정보 및 Wright 값을 읽습니다. 이것은 명령과 작업을 수신하기 위해 마스터 구성 요소와 통신합니다. 그런 다음 kubelet 프로세스는 작업 상태 및 노드 서버를 유지 관리 할 책임이 있습니다. 네트워크 규칙, 포트 포워딩 등을 관리합니다.

Kubernetes Proxy Service− 이것은 각 노드에서 실행되는 프록시 서비스이며 외부 호스트에서 서비스를 사용할 수 있도록 도와줍니다. 컨테이너 수정 요청을 전달하는 데 도움이됩니다. Kubernetes Proxy Service는 기본 부하 분산을 수행 할 수 있습니다. 네트워킹 환경이 예측 가능하고 액세스 가능하지만 동시에 격리되어 있는지 확인합니다. 노드, 볼륨, 비밀, 새 컨테이너 상태 점검 생성 등의 포드를 관리합니다.

통합 OpenShift Container Registry

OpenShift 컨테이너 레지스트리는 Docker 이미지를 저장하는 데 사용되는 Red Hat의 내장 스토리지 단위입니다. OpenShift의 최신 통합 버전을 통해 OpenShift 내부 스토리지에서 이미지를 볼 수있는 사용자 인터페이스가 제공됩니다. 이러한 레지스트리는 나중에 컨테이너를 구축하는 데 사용되는 지정된 태그가있는 이미지를 보유 할 수 있습니다.

자주 사용되는 용어

Image− Kubernetes (Docker) 이미지는 컨테이너화 된 인프라의 핵심 구성 요소입니다. 현재 Kubernetes는 Docker 이미지 만 지원합니다. 포드의 각 컨테이너에는 내부에서 실행되는 Docker 이미지가 있습니다. 포드를 구성 할 때 구성 파일의 이미지 속성은 Docker 명령과 동일한 구문을 갖습니다.

Project − 이전 버전의 OpenShift V2에 있던 도메인의 이름이 변경된 버전으로 정의 할 수 있습니다.

Container − 쿠 버네 티스 클러스터 노드에 이미지가 배포 된 후 생성되는 것입니다.

Node− 노드는 마스터 용 미니언이라고도하는 Kubernetes 클러스터에서 작동하는 머신입니다. 물리적, VM 또는 클라우드 인스턴스가 될 수있는 작업 단위입니다.

Pod− 포드는 Kubernetes 클러스터의 노드 내부에있는 컨테이너 및 스토리지의 모음입니다. 내부에 여러 컨테이너가있는 포드를 만들 수 있습니다. 예를 들어 데이터베이스 컨테이너와 웹 서버 컨테이너를 포드 내부에 유지합니다.

이 장에서는 OpenShift의 환경 설정에 대해 알아 봅니다.

시스템 요구 사항

엔터프라이즈 OpenShift를 설정하려면 활성 Red Hat 계정이 있어야합니다. OpenShift는 Kubernetes 마스터 및 노드 아키텍처에서 작동하므로 둘 다 별도의 머신에 설정해야합니다. 여기서 한 머신은 마스터로 작동하고 다른 머신은 노드에서 작동합니다. 두 가지를 모두 설정하려면 최소 시스템 요구 사항이 있습니다.

마스터 머신 구성

다음은 마스터 컴퓨터 구성을위한 최소 시스템 요구 사항입니다.

  • 물리적, 가상 또는 모든 클라우드 환경에서 호스팅되는 기본 시스템.

  • 해당 인스턴스에 필요한 패키지가있는 Linux 7 이상.

  • 2 개의 CPU 코어.

  • 최소 8GB RAM.

  • 30GB의 내부 하드 디스크 메모리.

노드 머신 구성

  • 마스터 머신에 대해 제공된 실제 또는 가상 기본 이미지.
  • 머신에 Linux 7 이상.
  • 1.6 이하 버전으로 설치된 Docker.
  • CPU 코어 1 개.
  • 8GB RAM.
  • 이미지 호스팅 용 15GB 하드 디스크 및 이미지 저장 용 15GB.

OpenShift 설정에 대한 단계별 가이드

다음 설명에서는 나중에 더 큰 클러스터로 확장 할 수있는 OpenShift 랩 환경을 설정합니다. OpenShift에는 마스터 및 노드 설정이 필요하므로 클라우드, 물리적 또는 가상 머신에서 호스팅되는 최소 두 대의 머신이 필요합니다.

Step 1− 먼저 두 시스템 모두에 Linux를 설치하십시오. 여기서 Linux 7이 최소 버전이어야합니다. 활성 Red Hat 서브 스크립 션이있는 경우 다음 명령을 사용하여 수행 할 수 있습니다.

# subscription-manager repos --disable = "*"

# subscription-manager repos --enable = "rhel-7-server-rpms"

# subscription-manager repos --enable = "rhel-7-server-extras-rpms"

# subscription-manager repos --enable = "rhel-7-server-optional-rpms"

# subscription-manager repos --enable = "rhel-7-server-ose-3.0-rpms"

# yum install wget git net-tools bind-utils iptables-services bridge-utils

# yum install wget git net-tools bind-utils iptables-services bridge-utils

# yum install python-virtualenv

# yum install gcc

# yum install httpd-tools

# yum install docker

# yum update

위의 모든 기본 패키지가 두 컴퓨터에 모두 설치되면 다음 단계는 해당 컴퓨터에 Docker를 설정하는 것입니다.

Step 2− 로컬 네트워크에서만 안전하지 않은 통신을 허용하도록 Docker를 구성하십시오. 이를 위해 / etc / sysconfig에서 Docker 파일을 편집하십시오. 파일이 없으면 수동으로 만들어야합니다.

# vi /etc/sysconfig/docker
OPTIONS = --selinux-enabled --insecure-registry 192.168.122.0/24

마스터 머신에서 Docker를 구성한 후 두 머신간에 암호없는 통신을 설정해야합니다. 이를 위해 공개 및 개인 키 인증을 사용합니다.

Step 3 − 마스터 머신에서 키를 생성 한 다음 id_rsa.pub 키를 노드 머신의 인증 된 키 파일에 복사합니다. 다음 명령을 사용하여 수행 할 수 있습니다.

# ssh-keygen

# ssh-copy-id -i .ssh/id_rsa.pub [email protected]

위의 모든 설정이 완료되면 다음은 마스터 머신에서 OpenShift 버전 3을 설정하는 것입니다.

Step 4 − 마스터 머신에서 다음 curl 명령을 실행합니다.

# sh <(curl -s https://install.openshift.com/ose)

위의 명령은 OSV3에 대한 설정을 배치합니다. 다음 단계는 컴퓨터에서 OpenShift V3를 구성하는 것입니다.

인터넷에서 직접 다운로드 할 수없는 경우 다음에서 다운로드 할 수 있습니다. https://install.openshift.com/portable/oo-install-ose.tgz 설치 프로그램이 로컬 마스터 시스템에서 실행할 수있는 tar 패키지로.

설정이 준비되면 머신에서 OSV3의 실제 구성으로 시작해야합니다. 이 설정은 실제 프로덕션 환경을 테스트하기 위해 매우 구체적이며 LDAP 및 기타 사항이 있습니다.

Step 5 − 마스터 머신에서 /etc/openshift/master/master-config.yaml 아래에있는 다음 코드를 구성합니다.

# vi /etc/openshift/master/master-config.yaml
identityProviders:
- name: my_htpasswd_provider
challenge: true
login: true
provider:
apiVersion: v1
kind: HTPasswdPasswordIdentityProvider
file: /root/users.htpasswd
routingConfig:
subdomain: testing.com

다음으로 기본 관리를위한 표준 사용자를 만듭니다.

# htpasswd -c /root/users.htpasswd admin

Step 6− OpenShift는 이미지 구성에 Docker 레지스트리를 사용하므로 Docker 레지스트리를 구성해야합니다. 빌드 후 Docker 이미지를 만들고 저장하는 데 사용됩니다.

다음 명령을 사용하여 OpenShift 노드 시스템에 디렉토리를 만듭니다.

# mkdir /images

다음으로 레지스트리를 설정하는 동안 생성되는 기본 관리자 자격 증명을 사용하여 마스터 컴퓨터에 로그인합니다.

# oc login
Username: system:admin

기본 생성 된 프로젝트로 전환합니다.

# oc project default

Step 7 − Docker 레지스트리를 생성합니다.

#echo '{"kind":"ServiceAccount","apiVersion":"v1","metadata":{"name":"registry"}}' | oc create -f -

사용자 권한을 편집하십시오.

#oc edit scc privileged
users:
- system:serviceaccount:openshift-infra:build-controller
- system:serviceaccount:default:registry

이미지 레지스트리를 만들고 편집합니다.

#oadm registry --service-account = registry --
config = /etc/openshift/master/admin.kubeconfig --
credentials = /etc/openshift/master/openshift-registry.kubeconfig --
images = 'registry.access.redhat.com/openshift3/ose-${component}:${version}' --
mount-host = /images

Step 8 − 기본 라우팅을 생성합니다.

기본적으로 OpenShift는 OpenVswitch를 소프트웨어 네트워크로 사용합니다. 다음 명령을 사용하여 기본 라우팅을 만듭니다. 로드 균형 조정 및 프록시 라우팅에 사용됩니다. 라우터는 Docker 레지스트리와 유사하며 레지스트리에서도 실행됩니다.

# echo '{"kind":"ServiceAccount","apiVersion":"v1","metadata":{"name":"router"}}' | oc create -f -

다음으로 사용자의 권한을 편집하십시오.

#oc edit scc privileged
users:
   - system:serviceaccount:openshift-infra:build-controller
   - system:serviceaccount:default:registry
   - system:serviceaccount:default:router

#oadm router router-1 --replicas = 1 --
credentials = '/etc/openshift/master/openshift-router.kubeconfig' --
images = 'registry.access.redhat.com/openshift3/ose-${component}:${version}'

Step 9 − DNS를 구성합니다.

URL 요청을 처리하려면 OpenShift에 작동하는 DNS 환경이 필요합니다. 이 DNS 구성은 라우터를 가리키는 DNS 와일드 카드를 만드는 데 필요한 와일드 카드를 만드는 데 필요합니다.

# yum install bind-utils bind

# systemctl start named

# systemctl enable named

vi /etc/named.conf
options {listen-on port 53 { 10.123.55.111; };
forwarders {
   10.38.55.13;
   ;
};

zone "lab.com" IN {
   type master;
   file "/var/named/dynamic/test.com.zone";
   allow-update { none; };
};

Step 10− 마지막 단계는 선택 사항 인 OpenShift V3 마스터 머신에 github 서버를 설정하는 것입니다. 다음 명령 시퀀스를 사용하여 쉽게 수행 할 수 있습니다.

#yum install curl openssh-server

#systemctl enable sshd

# systemctl start sshd

# firewall-cmd --permanent --add-service = http

# systemctl reload firewalld

#curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-

#yum install gitlab-ce

# gitlab-ctl reconfigure

위의 설정이 완료되면 테스트를 통해 확인하고 응용 프로그램을 배포 할 수 있습니다. 이에 대해서는 다음 장에서 자세히 알아볼 것입니다.

애플리케이션의 실제 설정 및 배포를 시작하기 전에 OpenShift V3에서 사용되는 몇 가지 기본 용어와 개념을 이해해야합니다.

컨테이너 및 이미지

이미지

이는 Docker 이미지로 구성된 OpenShift의 기본 구성 요소입니다. OpenShift의 각 포드에는 클러스터 내부에서 실행되는 자체 이미지가 있습니다. 포드를 구성 할 때 레지스트리에서 풀링되는 필드가 있습니다. 이 구성 파일은 이미지를 가져와 클러스터 노드에 배포합니다.

apiVersion: v1
kind: pod
metadata:
   name: Tesing_for_Image_pull -----------> Name of Pod
      spec:
containers:
- name: neo4j-server ------------------------> Name of the image
image: <Name of the Docker image>----------> Image to be pulled
imagePullPolicy: Always ------------->Image pull policy
command: [“echo”, “SUCCESS”] -------------------> Massage after image pull

이미지를 가져 와서 생성하려면 다음 명령을 실행하십시오. OC는 로그인 후 OpenShift 환경과 통신하는 클라이언트입니다.

$ oc create –f Tesing_for_Image_pull

컨테이너

Docker 이미지가 OpenShift 클러스터에 배치 될 때 생성됩니다. 구성을 정의하는 동안 구성 파일에서 컨테이너 섹션을 정의합니다. 하나의 컨테이너에는 내부에서 실행되는 여러 이미지가있을 수 있으며 클러스터 노드에서 실행되는 모든 컨테이너는 OpenShift Kubernetes에 의해 관리됩니다.

spec:
   containers:
   - name: py ------------------------> Name of the container
   image: python----------> Image going to get deployed on container
   command: [“python”, “SUCCESS”]
   restartPocliy: Never --------> Restart policy of container

다음은 여러 이미지가 내부에서 실행되는 컨테이너를 정의하기위한 사양입니다.

apiVersion: v1
kind: Pod
metadata:
   name: Tomcat
spec:
   containers:
   - name: Tomcat
   image: tomcat: 8.0
   ports:
   - containerPort: 7500
      imagePullPolicy: Always
      -name: Database
      Image: mongoDB
      Ports:
      - containerPort: 7501
imagePullPolicy: Always

위의 구성에서는 내부에 Tomcat 및 MongoDB 이미지 두 개가 포함 된 다중 컨테이너 포드를 정의했습니다.

포드 및 서비스

포드

포드는 OpenShift (Kubernetes) 클러스터 노드 내부의 컨테이너 및 스토리지 모음으로 정의 할 수 있습니다. 일반적으로 단일 컨테이너 포드에서 다중 컨테이너 포드까지 두 가지 유형의 포드가 있습니다.

Single Container Pod − OC 명령 또는 기본 구성 yml 파일로 쉽게 생성 할 수 있습니다.

$ oc run <name of pod> --image = <name of the image from registry>

다음과 같이 간단한 yaml 파일로 만듭니다.

apiVersion: v1
kind: Pod
metadata:
   name: apache
spec:
   containers:
   - name: apache
   image: apache: 8.0
   ports:
      - containerPort: 7500
imagePullPolicy: Always

위 파일이 생성되면 다음 명령을 사용하여 포드를 생성합니다.

$ oc create –f apache.yml

Multi-Container Pod− 다중 컨테이너 포드는 내부에서 실행중인 컨테이너가 두 개 이상있는 포드입니다. 다음과 같이 yaml 파일을 사용하여 생성됩니다.

apiVersion: v1
kind: Pod
metadata:
   name: Tomcat
spec:
   containers:
   - name: Tomcat
   image: tomcat: 8.0
   ports:
      - containerPort: 7500
imagePullPolicy: Always
   -name: Database
   Image: mongoDB
   Ports:
      - containerPort: 7501
imagePullPolicy: Always

이러한 파일을 만든 후 위와 동일한 방법을 사용하여 컨테이너를 만들 수 있습니다.

Service− 포드 내부에서 실행되는 컨테이너 집합이 있으므로 동일한 방식으로 논리적 포드 집합으로 정의 할 수있는 서비스가 있습니다. 포드에 액세스 할 수있는 단일 IP 및 DNS 이름을 제공하는 포드 상단의 추상화 된 레이어입니다. 서비스는 부하 분산 구성을 관리하고 포드를 매우 쉽게 확장하는 데 도움이됩니다. OpenShift에서 서비스는 새 인스턴스를 생성하기 위해 OpenShift 마스터의 apiService에 설명을 게시 할 수있는 REST 객체입니다.

apiVersion: v1
kind: Service
metadata:
   name: Tutorial_point_service
spec:
   ports:
      - port: 8080
         targetPort: 31999

빌드 및 스트림

빌드

OpenShift에서 빌드는 이미지를 컨테이너로 변환하는 프로세스입니다. 소스 코드를 이미지로 변환하는 처리입니다. 이 빌드 프로세스는 소스 코드를 이미지로 빌드하는 사전 정의 된 전략에 따라 작동합니다.

빌드는 여러 전략과 소스를 처리합니다.

전략 구축

  • Source to Image− 이것은 기본적으로 재현 가능한 이미지를 만드는 데 도움이되는 도구입니다. 이러한 이미지는 항상 Docker run 명령을 사용하여 실행할 준비가 된 단계에 있습니다.

  • Docker Build − 간단한 Docker 빌드 명령을 실행하여 Docker 파일을 이용하여 이미지를 빌드하는 과정입니다.

  • Custom Build − 이들은 기본 Docker 이미지를 생성하는 데 사용되는 빌드입니다.

소스 빌드

Git−이 소스는 git 저장소가 이미지 빌드에 사용될 때 사용됩니다. Dockerfile은 선택 사항입니다. 소스 코드의 구성은 다음과 같습니다.

source:
type: "Git"
git:
   uri: "https://github.com/vipin/testing.git"
   ref: "master"
contextDir: "app/dir"
dockerfile: "FROM openshift/ruby-22-centos7\nUSER example"

Dockerfile − Dockerfile은 구성 파일의 입력으로 사용됩니다.

source:
   type: "Dockerfile"
   dockerfile: "FROM ubuntu: latest
   RUN yum install -y httpd"

Image Streams− 이미지를 가져온 후 이미지 스트림이 생성됩니다. 이미지 스트림의 장점은 이미지의 새 버전에서 업데이트를 찾는 것입니다. 이는 태그로 식별되는 Docker 형식의 컨테이너 이미지 수를 비교하는 데 사용됩니다.

이미지 스트림은 새 이미지가 생성 될 때 자동으로 작업을 수행 할 수 있습니다. 모든 빌드 및 배포는 이미지 작업을 감시하고 그에 따라 작업을 수행 할 수 있습니다. 다음은 스트림 빌드를 정의하는 방법입니다.

apiVersion: v1
kind: ImageStream
metadata:
   annotations:
      openshift.io/generated-by: OpenShiftNewApp
   generation: 1
   labels:
      app: ruby-sample-build
   selflink: /oapi/v1/namespaces/test/imagestreams/origin-ruby-sample
   uid: ee2b9405-c68c-11e5-8a99-525400f25e34
spec: {}
status:
   dockerImageRepository: 172.30.56.218:5000/test/origin-ruby-sample
   tags:
   - items:
      - created: 2016-01-29T13:40:11Z
      dockerImageReference: 172.30.56.218:5000/test/origin-apache-sample
      generation: 1
      image: vklnld908.int.clsa.com/vipin/test
   tag: latest

경로 및 템플릿

노선

OpenShift에서 라우팅은 외부에서 연결할 수있는 호스트 이름을 만들고 구성하여 서비스를 외부에 노출하는 방법입니다. 경로와 끝점은 사용자가 이름 연결 (DNS)을 사용하여 정의 된 애플리케이션에 액세스 할 수있는 외부 세계에 서비스를 노출하는 데 사용됩니다.

OpenShift에서 경로는 클러스터에서 OpenShift 관리자가 배포 한 라우터를 사용하여 생성됩니다. 라우터는 HTTP (80) 및 https (443) 포트를 외부 애플리케이션에 바인딩하는 데 사용됩니다.

다음은 경로가 지원하는 다양한 종류의 프로토콜입니다.

  • HTTP
  • HTTPS
  • TSL 및 웹 소켓

서비스를 구성 할 때 선택기는 서비스를 구성하고 해당 서비스를 사용하는 엔드 포인트를 찾는 데 사용됩니다. 다음은 적절한 프로토콜을 사용하여 서비스 및 해당 서비스에 대한 라우팅을 만드는 방법의 예입니다.

{
   "kind": "Service",
   "apiVersion": "v1",
   "metadata": {"name": "Openshift-Rservice"},
   "spec": {
      "selector": {"name":"RService-openshift"},
      "ports": [
         {
            "protocol": "TCP",
            "port": 8888,
            "targetPort": 8080
         }
      ]
   }
}

다음으로 다음 명령을 실행하면 서비스가 생성됩니다.

$ oc create -f ~/training/content/Openshift-Rservice.json

이것은 생성 후 서비스의 모습입니다.

$ oc describe service Openshift-Rservice

Name:              Openshift-Rservice
Labels:            <none>
Selector:          name = RService-openshift
Type:              ClusterIP
IP:                172.30.42.80
Port:              <unnamed> 8080/TCP
Endpoints:         <none>
Session Affinity:  None
No events.

다음 코드를 사용하여 서비스에 대한 라우팅을 만듭니다.

{
   "kind": "Route",
   "apiVersion": "v1",
   "metadata": {"name": "Openshift-service-route"},
   "spec": {
      "host": "hello-openshift.cloudapps.example.com",
      "to": {
         "kind": "Service",
         "name": "OpenShift-route-service"
      },
      "tls": {"termination": "edge"}
   }
}

OC 명령을 사용하여 경로를 생성하면 경로 리소스의 새 인스턴스가 생성됩니다.

템플릿

템플릿은 여러 번 사용할 수있는 OpenShift의 표준 개체로 정의됩니다. 여러 개체를 만드는 데 사용되는 자리 표시 자 목록으로 매개 변수화됩니다. 이는 포드에서 네트워킹에 이르기까지 사용자에게 생성 권한이있는 모든 것을 생성하는 데 사용할 수 있습니다. 이미지의 CLI 또는 GUI 인터페이스의 템플릿이 프로젝트 디렉토리에 업로드되면 객체 목록을 만들 수 있습니다.

apiVersion: v1
kind: Template
metadata:
   name: <Name of template>
   annotations:
      description: <Description of Tag>
      iconClass: "icon-redis"
      tags: <Tages of image>
objects:
   - apiVersion: v1
   kind: Pod
   metadata:
      name: <Object Specification>
spec:
   containers:
      image: <Image Name>
      name: master
      ports:
      - containerPort: <Container port number>
         protocol: <Protocol>
labels:
   redis: <Communication Type>

인증 및 승인

입증

OpenShift에서 마스터 및 클라이언트 구조를 구성하는 동안 마스터는 OAuth 서버의 내장 기능을 제공합니다. OAuth 서버는 API 인증에 사용되는 토큰 생성에 사용됩니다. OAuth는 마스터의 기본 설정으로 제공되므로 기본적으로 모든 ID 공급자 허용이 사용됩니다. 구성 할 수있는 다른 ID 공급자가 있습니다./etc/openshift/master/master-config.yaml.

OAuth에는 다양한 유형의 ID 공급자가 있습니다.

  • 모두 허용
  • 모두 거부
  • HTPasswd
  • LDAP
  • 기본 인증

모두 허용

apiVersion: v1
   kind: Pod
   metadata:
      name: redis-master
   spec:
      containers:
         image: dockerfile/redis
         name: master
      ports:
      - containerPort: 6379
         protocol: TCP
      oauthConfig:
      identityProviders:
      - name: my_allow_provider
         challenge: true
         login: true
      provider:
         apiVersion: v1
         kind: AllowAllPasswordIdentityProvider

모두 거부

apiVersion: v1
kind: Pod
metadata:
   name: redis-master
spec:
   containers:
      image: dockerfile/redis
   name: master
   ports:
   - containerPort: 6379
      protocol: TCP
   oauthConfig:
   identityProviders:
   - name: my_allow_provider
      challenge: true
      login: true
   provider:
      apiVersion: v1
      kind: DenyAllPasswordIdentityProvider

HTPasswd

HTPasswd를 사용하려면 먼저 마스터 시스템에 Httpd-tools를 설정 한 다음 다른 사용자와 동일한 방식으로 구성해야합니다.

identityProviders:
   - name: my_htpasswd_provider
      challenge: true
      login: true
      provider:
         apiVersion: v1
         kind: HTPasswdPasswordIdentityProvider

권한 부여

권한 부여는 사용자 유효성을 검사하는 데 사용되는 OpenShift 마스터의 기능입니다. 즉, 특정 프로젝트에서 해당 작업을 수행 할 권한이 사용자에게 있는지 확인하기 위해 작업을 수행하려는 사용자를 확인합니다. 이를 통해 관리자는 프로젝트에 대한 액세스를 제어 할 수 있습니다.

권한 부여 정책은 다음을 사용하여 제어됩니다.

  • Rules
  • Roles
  • Bindings

승인 평가는 다음을 사용하여 수행됩니다.

  • Identity
  • Action
  • Bindings

정책 사용-

  • 클러스터 정책
  • 지역 정책

OpenShift는 GUI 또는 CLI를 통해 애플리케이션을 만들고 배포하는 두 가지 유형의 중앙값으로 구성됩니다. 이 장에서는 CLI를 사용하여 새 응용 프로그램을 만듭니다. OpenShift 환경과 통신하기 위해 OC 클라이언트를 사용할 것입니다.

새 응용 프로그램 만들기

OpenShift에는 새 애플리케이션을 만드는 세 가지 방법이 있습니다.

  • 소스 코드에서
  • 이미지에서
  • 템플릿에서

소스 코드에서

소스 코드에서 애플리케이션을 만들려고 할 때 OpenShift는 애플리케이션 빌드 흐름을 정의하는 저장소 내부에 있어야하는 Docker 파일을 찾습니다. oc new-app을 사용하여 애플리케이션을 만들 것입니다.

저장소를 사용하는 동안 가장 먼저 명심해야 할 것은 OpenShift가 코드를 가져와 빌드 할 저장소의 출처를 가리켜 야한다는 것입니다.

저장소가 OC 클라이언트가 설치된 Docker 머신에 복제되고 사용자가 동일한 디렉토리에있는 경우 다음 명령을 사용하여 생성 할 수 있습니다.

$ oc new-app . <Hear. Denotes current working directory>

다음은 특정 분기에 대한 원격 저장소에서 빌드를 시도하는 예입니다.

$ oc new-app https://github.com/openshift/Testing-deployment.git#test1

여기서 test1은 OpenShift에서 새 응용 프로그램을 만들려는 지점입니다.

저장소에 Docker 파일을 지정할 때 아래와 같이 빌드 전략을 정의해야합니다.

$ oc new-app OpenShift/OpenShift-test~https://github.com/openshift/Testingdeployment.git

이미지에서

이미지를 사용하여 애플리케이션을 빌드하는 동안 이미지는 로컬 Docker 서버, 사내 호스팅 Docker 저장소 또는 Docker 허브에 있습니다. 사용자가 확인해야하는 유일한 사항은 문제없이 허브에서 이미지를 가져올 수 있다는 것입니다.

OpenShift에는 Docker 이미지이든 소스 스트림이든 사용 된 소스를 확인할 수있는 기능이 있습니다. 그러나 사용자가 원하는 경우 이미지 스트림인지 Docker 이미지인지 명시 적으로 정의 할 수 있습니다.

$ oc new-app - - docker-image tomcat

이미지 스트림 사용-

$ oc new-app tomcat:v1

템플릿에서

새 응용 프로그램을 만드는 데 템플릿을 사용할 수 있습니다. 이미 존재하는 템플릿이거나 새 템플릿을 만들 수 있습니다.

다음 yaml 파일은 기본적으로 배포에 사용할 수있는 템플릿입니다.

apiVersion: v1
kind: Template
metadata:
   name: <Name of template>
   annotations:
      description: <Description of Tag>
      iconClass: "icon-redis"
      tags: <Tages of image>
objects:
   - apiVersion: v1
   kind: Pod
   metadata:
      name: <Object Specification>
spec:
   containers:
      image: <Image Name>
      name: master
      ports:
      - containerPort: <Container port number>
         protocol: <Protocol>
labels:
   redis: <Communication Type>

웹 애플리케이션 개발 및 배포

OpenShift에서 새 애플리케이션 개발

OpenShift에서 새 애플리케이션을 생성하려면 새 애플리케이션 코드를 작성하고 OpenShift OC 빌드 명령을 사용하여 빌드해야합니다. 설명했듯이 새 이미지를 만드는 방법에는 여러 가지가 있습니다. 여기서는 템플릿을 사용하여 애플리케이션을 구축합니다. 이 템플릿은 oc new-app 명령으로 실행될 때 새 애플리케이션을 빌드합니다.

다음 템플릿이 생성됩니다-두 개의 프런트 엔드 응용 프로그램과 하나의 데이터베이스. 이와 함께 두 개의 새로운 서비스가 생성되고 해당 애플리케이션이 OpenShift 클러스터에 배포됩니다. 애플리케이션을 빌드하고 배포하는 동안 처음에는 OpenShift에서 네임 스페이스를 만들고 해당 네임 스페이스 아래에 애플리케이션을 배포해야합니다.

Create a new namespace

$ oc new-project openshift-test --display-name = "OpenShift 3 Sample" --
description = "This is an example project to demonstrate OpenShift v3"

주형

{
   "kind": "Template",
   "apiVersion": "v1",
   "metadata": {
      "name": "openshift-helloworld-sample",
      "creationTimestamp": null,
         "annotations": {
         "description": "This example shows how to create a simple openshift
         application in openshift origin v3",
         "iconClass": "icon-openshift",
         "tags": "instant-app,openshift,mysql"
      }
   }
},

개체 정의

Secret definition in a template

"objects": [
{
   "kind": "Secret",
   "apiVersion": "v1",
   "metadata": {"name": "dbsecret"},
   "stringData" : {
      "mysql-user" : "${MYSQL_USER}",
      "mysql-password" : "${MYSQL_PASSWORD}"
   }
},

Service definition in a template

{
   "kind": "Service",
   "apiVersion": "v1",
   "metadata": {
      "name": "frontend",
      "creationTimestamp": null
   },
   "spec": {
      "ports": [
         {
            "name": "web",
            "protocol": "TCP",
            "port": 5432,
            "targetPort": 8080,
            "nodePort": 0
         }
      ],
      "selector": {"name": "frontend"},
      "type": "ClusterIP",
      "sessionAffinity": "None"
   },
   "status": {
      "loadBalancer": {}
   }
},

Route definition in a template

{
   "kind": "Route",
   "apiVersion": "v1",
   "metadata": {
      "name": "route-edge",
      "creationTimestamp": null,
      "annotations": {
         "template.openshift.io/expose-uri": "http://{.spec.host}{.spec.path}"
      }
   },
   "spec": {
      "host": "www.example.com",
      "to": {
         "kind": "Service",
         "name": "frontend"
      },
      "tls": {
         "termination": "edge"
      }
   },
   "status": {}
},
{ 
   "kind": "ImageStream",
   "apiVersion": "v1",
   "metadata": {
      "name": "origin-openshift-sample",
      "creationTimestamp": null
   },
   "spec": {},
   "status": {
      "dockerImageRepository": ""
   }
},
{ 
   "kind": "ImageStream",
   "apiVersion": "v1",
   "metadata": {
      "name": "openshift-22-ubuntu7",
      "creationTimestamp": null 
   },
   "spec": {
      "dockerImageRepository": "ubuntu/openshift-22-ubuntu7"
   },
   "status": {
      "dockerImageRepository": ""
   }
},

Build config definition in a template

{
   "kind": "BuildConfig",
   "apiVersion": "v1",
   "metadata": {
      "name": "openshift-sample-build",
      "creationTimestamp": null,
      "labels": {name": "openshift-sample-build"}
   },
   "spec": {
      "triggers": [
         { "type": "GitHub",
            "github": {
            "secret": "secret101" } 
         },
         {
            "type": "Generic",
            "generic": {
               "secret": "secret101",
               "allowEnv": true } 
         },
         { 
            "type": "ImageChange",
            "imageChange": {} 
         },
         { "type": "ConfigChange”}
      ],
      "source": {
         "type": "Git",
         "git": {
            "uri": https://github.com/openshift/openshift-hello-world.git } 
      },
      "strategy": {
         "type": "Docker",
         "dockerStrategy": {
            "from": {
               "kind": "ImageStreamTag",
               "name": "openshift-22-ubuntu7:latest” 
            },
            "env": [
               {
                  "name": "EXAMPLE",
                  "value": "sample-app"
               } 
            ]
         }
      },
      "output": {
         "to": {
            "kind": "ImageStreamTag",
            "name": "origin-openshift-sample:latest"
         }
      },
      "postCommit": {
         "args": ["bundle", "exec", "rake", "test"]
      },
      "status": {
         "lastVersion": 0
      }
   }
},

Deployment config in a template

"status": {
   "lastVersion": 0
}
{
   "kind": "DeploymentConfig",
   "apiVersion": "v1",
   "metadata": {
      "name": "frontend",
      "creationTimestamp": null
   }
}, 
"spec": {
   "strategy": {
      "type": "Rolling",
      "rollingParams": {
         "updatePeriodSeconds": 1,
         "intervalSeconds": 1,
         "timeoutSeconds": 120,
         "pre": {
            "failurePolicy": "Abort",
            "execNewPod": {
               "command": [
                  "/bin/true"
               ],
               "env": [
                  { 
                     "name": "CUSTOM_VAR1",
                     "value": "custom_value1"
                  }
               ]
            }
         }
      }
   }
}
"triggers": [
   {
      "type": "ImageChange",
      "imageChangeParams": {
         "automatic": true,
         "containerNames": [
            "openshift-helloworld"
         ],
         "from": {
            "kind": "ImageStreamTag",
            "name": "origin-openshift-sample:latest"
         }
      }
   },
   {
      "type": "ConfigChange"
   }
],
"replicas": 2,
"selector": {
   "name": "frontend"
},
"template": {
   "metadata": {
      "creationTimestamp": null,
      "labels": {
         "name": "frontend"
      }
   },
   "spec": {
      "containers": [
         {
            "name": "openshift-helloworld",
            "image": "origin-openshift-sample",
            "ports": [
               { 
                  "containerPort": 8080,
                  "protocol": "TCP” 
               }
            ],
            "env": [
               {
                  "name": "MYSQL_USER",
                  "valueFrom": {
                     "secretKeyRef" : {
                        "name" : "dbsecret",
                        "key" : "mysql-user"
                     }
                  }
               },
               {
                  "name": "MYSQL_PASSWORD",
                  "valueFrom": {
                     "secretKeyRef" : {
                        "name" : "dbsecret",
                        "key" : "mysql-password"
                     }
                  }
               },
               {
                  "name": "MYSQL_DATABASE",
                  "value": "${MYSQL_DATABASE}"
               }
            ],
            "resources": {},
            "terminationMessagePath": "/dev/termination-log",
            "imagePullPolicy": "IfNotPresent",
            "securityContext": {
               "capabilities": {},
               "privileged": false
            }
         }
      ],
      "restartPolicy": "Always",
      "dnsPolicy": "ClusterFirst"
   },
   "status": {}
},

Service definition in a template

{
   "kind": "Service",
   "apiVersion": "v1",
   "metadata": {
      "name": "database",
      "creationTimestamp": null 
   },
   "spec": {
   "ports": [
      {
         "name": "db",
         "protocol": "TCP",
         "port": 5434,
         "targetPort": 3306,
         "nodePort": 0
      } 
   ],
   "selector": {
      "name": "database 
   },
   "type": "ClusterIP",
   "sessionAffinity": "None" },
   "status": {
      "loadBalancer": {}
   }
},

Deployment config definition in a template

{
   "kind": "DeploymentConfig",
   "apiVersion": "v1",
   "metadata": {
      "name": "database",
      "creationTimestamp": null
   },
   "spec": {
      "strategy": {
         "type": "Recreate",
         "resources": {}
      },
      "triggers": [
         {
            "type": "ConfigChange"
         }
      ],
      "replicas": 1,
      "selector": {"name": "database"},
      "template": {
         "metadata": {
            "creationTimestamp": null,
            "labels": {"name": "database"}
         },
         "template": {
            "metadata": {
               "creationTimestamp": null,
               "labels": {
                  "name": "database"
               } 
            },
            "spec": {
               "containers": [
                  {
                     "name": "openshift-helloworld-database",
                     "image": "ubuntu/mysql-57-ubuntu7:latest",
                     "ports": [
                        {
                           "containerPort": 3306,
                           "protocol": "TCP" 
                        }
                     ],
                     "env": [
                        {
                           "name": "MYSQL_USER",
                           "valueFrom": {
                              "secretKeyRef" : {
                                 "name" : "dbsecret",
                                 "key" : "mysql-user"
                              }
                           }
                        },
                        {
                           "name": "MYSQL_PASSWORD",
                           "valueFrom": {
                              "secretKeyRef" : {
                                 "name" : "dbsecret",
                                 "key" : "mysql-password"
                              }
                           }
                        },
                        {
                           "name": "MYSQL_DATABASE",
                           "value": "${MYSQL_DATABASE}" 
                        } 
                     ],
                     "resources": {},
                     "volumeMounts": [
                        {
                           "name": "openshift-helloworld-data",
                           "mountPath": "/var/lib/mysql/data"
                        }
                     ],
                     "terminationMessagePath": "/dev/termination-log",
                     "imagePullPolicy": "Always",
                     "securityContext": {
                        "capabilities": {},
                        "privileged": false
                     } 
                  }
               ],
               "volumes": [
                  { 
                     "name": "openshift-helloworld-data",
                     "emptyDir": {"medium": ""} 
                  } 
               ],
               "restartPolicy": "Always",
               "dnsPolicy": "ClusterFirst” 
            } 
         }
      },
      "status": {} 
   },
   "parameters": [
      { 
         "name": "MYSQL_USER",
         "description": "database username",
         "generate": "expression",
         "from": "user[A-Z0-9]{3}",
         "required": true 
      },
      {
         "name": "MYSQL_PASSWORD",
         "description": "database password",
         "generate": "expression",
         "from": "[a-zA-Z0-9]{8}",
         "required": true
      }, 
      {
         "name": "MYSQL_DATABASE",
         "description": "database name",
         "value": "root",
         "required": true 
      } 
   ],
   "labels": {
      "template": "application-template-dockerbuild" 
   } 
}

위의 템플릿 파일은 한 번에 컴파일해야합니다. 먼저 모든 콘텐츠를 단일 파일로 복사하고 완료되면 이름을 yaml 파일로 지정해야합니다.

애플리케이션을 생성하려면 다음 명령을 실행해야합니다.

$ oc new-app application-template-stibuild.json
--> Deploying template openshift-helloworld-sample for "application-template-stibuild.json"

   openshift-helloworld-sample
   ---------
   This example shows how to create a simple ruby application in openshift origin v3
   * With parameters:
      * MYSQL_USER = userPJJ # generated
      * MYSQL_PASSWORD = cJHNK3se # generated
      * MYSQL_DATABASE = root

--> Creating resources with label app = ruby-helloworld-sample ...
   service "frontend" created
   route "route-edge" created
   imagestream "origin-ruby-sample" created
   imagestream "ruby-22-centos7" created
   buildconfig "ruby-sample-build" created
   deploymentconfig "frontend" created
   service "database" created
   deploymentconfig "database" created
   
--> Success
   Build scheduled, use 'oc logs -f bc/ruby-sample-build' to track its progress.
   Run 'oc status' to view your app.

빌드를 모니터링하려면 다음을 사용하여 수행 할 수 있습니다.

$ oc get builds

NAME                        TYPE      FROM          STATUS     STARTED         DURATION
openshift-sample-build-1    Source   Git@bd94cbb    Running    7 seconds ago   7s

OpenShift에 배포 된 애플리케이션은 다음을 사용하여 확인할 수 있습니다.

$ oc get pods
NAME                            READY   STATUS      RESTARTS   AGE
database-1-le4wx                1/1     Running     0          1m
frontend-1-e572n                1/1     Running     0          27s
frontend-1-votq4                1/1     Running     0          31s
opeshift-sample-build-1-build   0/1     Completed   0          1m

응용 프로그램 서비스가 서비스 정의에 따라 생성되었는지 확인할 수 있습니다.

$ oc get services
NAME        CLUSTER-IP      EXTERNAL-IP     PORT(S)      SELECTOR          AGE
database    172.30.80.39    <none>         5434/TCP     name=database      1m
frontend    172.30.17.4     <none>         5432/TCP     name=frontend      1m

OpenShift에는 빌드 파이프 라인을 자동화하는 여러 방법이 있습니다. 이를 위해 빌드 흐름을 설명하는 BuildConfig 리소스를 만들어야합니다. BuildConfig의 흐름은 Jenkins 작업 정의의 작업 정의와 비교할 수 있습니다. 빌드 흐름을 만드는 동안 빌드 전략을 선택해야합니다.

BuildConfig 파일

OpenShift에서 BuildConfig는 API에 연결 한 다음 새 인스턴스를 만드는 데 사용되는 나머지 개체입니다.

kind: "BuildConfig"
apiVersion: "v1"
metadata:
   name: "<Name of build config file>"
spec:
   runPolicy: "Serial"
   triggers:
   -
      type: "GitHub"
      github:
         secret: "<Secrete file name>"
   - type: "Generic"
   generic:
      secret: "secret101"
   -
   type: "ImageChange"
   source:
      type: "<Source of code>"
      git:
   uri: "https://github.com/openshift/openshift-hello-world"
   dockerfile: "FROM openshift/openshift-22-centos7\nUSER example"
   strategy:
      type: "Source"
      
sourceStrategy:
   from:
      kind: "ImageStreamTag"
      name: "openshift-20-centos7:latest"
   output:
      to:
         kind: "ImageStreamTag"
         name: "origin-openshift-sample:latest"
   postCommit:
      script: "bundle exec rake test"

OpenShift에는 네 가지 유형의 빌드 전략이 있습니다.

  • 소스-이미지 전략
  • Docker 전략
  • 맞춤형 전략
  • 파이프 라인 전략

소스-이미지 전략

소스 코드에서 시작하는 컨테이너 이미지를 만들 수 있습니다. 이 흐름에서 실제 코드는 먼저 컨테이너에 다운로드 된 다음 내부에서 컴파일됩니다. 컴파일 된 코드는 동일한 컨테이너에 배포되고 이미지는 해당 코드에서 빌드됩니다.

strategy:
   type: "Source"
   sourceStrategy:
      from:
         kind: "ImageStreamTag"
         name: "builder-image:latest"
      forcePull: true

여러 전략 정책이 있습니다.

  • Forcepull
  • 증분 빌드
  • 외부 빌드

Docker 전략

이 흐름에서 OpenShift는 Dockerfile을 사용하여 이미지를 빌드 한 다음 생성 된 이미지를 Docker 레지스트리에 업로드합니다.

strategy:
   type: Docker
   dockerStrategy:
      from:
         kind: "ImageStreamTag"
         name: "ubuntu:latest"

Docker 파일 옵션은 파일 경로부터 시작하여 캐시없이 강제로 끌어 오기를 여러 위치에서 사용할 수 있습니다.

  • 이미지에서
  • Dockerfile 경로
  • 캐시 없음
  • 힘 당기기

맞춤형 전략

이것은 다른 종류의 빌드 전략 중 하나이며 빌드의 출력이 이미지가 될 것 같은 강박이 없습니다. Jenkins의 무료 스타일 작업과 비교할 수 있습니다. 이를 통해 Jar, rpm 및 기타 패키지를 만들 수 있습니다.

strategy:
   type: "Custom"
   customStrategy:
      from:
         kind: "DockerImage"
         name: "openshift/sti-image-builder"

여러 빌드 전략으로 구성됩니다.

  • Docker 소켓 노출
  • Secrets
  • 힘 당기기

파이프 라인 전략

파이프 라인 전략은 사용자 지정 빌드 파이프 라인을 만드는 데 사용됩니다. 이것은 기본적으로 파이프 라인에서 워크 플로를 구현하는 데 사용됩니다. 이 빌드 흐름은 Groovy DSL 언어를 사용하는 사용자 지정 빌드 파이프 라인 흐름을 사용합니다. OpenShift는 Jenkins에서 파이프 라인 작업을 생성하고 실행합니다. 이 파이프 라인 흐름은 Jenkins에서도 사용할 수 있습니다. 이 전략에서는 Jenkinsfile을 사용하고이를 buildconfig 정의에 추가합니다.

Strategy:
   type: "JenkinsPipeline"
   jenkinsPipelineStrategy:
   jenkinsfile: "node('agent') {\nstage 'build'\nopenshiftBuild(buildConfig: 'OpenShift-build', showBuildLogs: 'true')\nstage 'deploy'\nopenshiftDeploy(deploymentConfig: 'backend')\n}"

Using build pipeline

kind: "BuildConfig"
apiVersion: "v1"
metadata:
   name: "test-pipeline"
spec:
   source:
      type: "Git"
      git:
         uri: "https://github.com/openshift/openshift-hello-world"
   strategy:
      type: "JenkinsPipeline"
      jenkinsPipelineStrategy:
         jenkinsfilePath: <file path repository>

OpenShift CLI는 명령 줄에서 OpenShift 애플리케이션을 관리하는 데 사용됩니다. OpenShift CLI에는 종단 간 애플리케이션 수명주기를 관리하는 기능이 있습니다. 일반적으로 OpenShift와 통신하기 위해 OpenShift 클라이언트 인 OC를 사용합니다.

OpenShift CLI 설정

다른 운영 체제에서 OC 클라이언트를 설정하려면 여러 단계를 거쳐야합니다.

Windows 용 OC 클라이언트

Step 1 − 다음 링크에서 oc cli를 다운로드하십시오. https://github.com/openshift/origin/releases/tag/v3.6.0-alpha.2

Step 2 − 머신의 대상 경로에서 패키지 압축을 풉니 다.

Step 3 − 시스템의 경로 환경 변수를 편집합니다.

C:\Users\xxxxxxxx\xxxxxxxx>echo %PATH%

C:\oraclexe\app\oracle\product\10.2.0\server\bin;C:\Program Files 
(x86)\Intel\iCLS Client\;C:\Program Files\Intel\iCLS Client\;C:\Program Files 
(x86)\AMD APP\bin\x86_64;C:\Program Files (x86)\AMD APP\bin\x86;

C:\Windows\system32;C:\Windows;C:\Windows\System32\Wbem;C:\Windows\System32\WindowsPowerShell\
v1.0\;C:\Program Files (x86)\Windows Live\Shared;C:\Program Files 
(x86)\ATI Technologies\ATI.ACE\C

ore-Static;C:\Program Files\Intel\Intel(R) Management Engine 
Components\DAL;C:\Program Files\Intel\Intel(R) Management Engine 
Components\IPT;C:\Program Files (x86)\Intel\Intel(R) Management Engine Components\DAL;

Step 4 − Windows에서 OC 설정을 확인합니다.

C:\openshift-origin-client-tools-v3.6.0-alpha.2-3c221d5-windows>oc version
oc v3.6.0-alpha.2+3c221d5
kubernetes v1.6.1+5115d708d7
features: Basic-Auth

Mac OS X 용 OC 클라이언트

Windows와 동일한 위치에 대한 Mac OS 설치 바이너리를 다운로드하고 나중에 해당 위치에서 압축을 풀고 환경 PATH 변수 아래에 실행 파일의 경로를 설정할 수 있습니다.

Alternatively

Home brew를 사용하고 다음 명령을 사용하여 설정할 수 있습니다.

$ brew install openshift-cli

Linux 용 OC 클라이언트

같은 페이지 아래에는 설치에 사용할 수있는 Linux 설치용 tar 파일이 있습니다. 나중에 특정 실행 위치를 가리키는 경로 변수를 설정할 수 있습니다.

https://github.com/openshift/origin/releases/tag/v3.6.0-alpha.2

다음 명령을 사용하여 tar 파일의 압축을 풉니 다.

$ tar –xf < path to the OC setup tar file >

다음 명령을 실행하여 인증을 확인하십시오.

C:\openshift-origin-client-tools-v3.6.0-alpha.2-3c221d5-windows>oc login
Server [https://localhost:8443]:

CLI 구성 파일

OC CLI 구성 파일은 여러 OpenShift 서버 연결 및 인증 메커니즘을 관리하는 데 사용됩니다. 이 구성 파일은 여러 프로필을 저장 및 관리하고 프로필간에 전환하는데도 사용됩니다. 일반 구성 파일은 다음과 같습니다.

$ oc config view
apiVersion: v1
clusters:
   - cluster:
      server: https://vklnld908.int.example.com
   name: openshift
   
contexts:
- context:
   cluster: openshift
   namespace: testproject
   user: alice
   name: alice
current-context: alice
kind: Config
preferences: {}
users:
- name: vipin
   user:
      token: ZCJKML2365jhdfafsdj797GkjgjGKJKJGjkg232

CLI 클라이언트 설정

사용자 자격 증명 설정

$ oc config set-credentials <user_nickname>
[--client-certificate = <path/to/certfile>] [--client-key=<path/to/keyfile>]
[--token = <bearer_token>] [--username = <basic_user>] [--password = <basic_password>]

클러스터 설정 용

$ oc config set-cluster <cluster_nickname> [--server = <master_ip_or_fqdn>]
[--certificate-authority = <path/to/certificate/authority>]
[--api-version = <apiversion>] [--insecure-skip-tls-verify = true]

$ oc config set-credentials vipin --token = ZCJKML2365jhdfafsdj797GkjgjGKJKJGjkg232

컨텍스트 설정 용

$ oc config set-context <context_nickname> [--cluster = <cluster_nickname>]
[--user = <user_nickname>] [--namespace = <namespace>]

CLI 프로필

단일 CLI 구성 파일에 여러 프로필이있을 수 있으며 각 프로필에는 다른 OpenShift 서버 구성이 있으며 나중에 다른 CLI 프로필간에 전환하는 데 사용할 수 있습니다.

apiVersion: v1
clusters: --→ 1
- cluster:
   insecure-skip-tls-verify: true
   server: https://vklnld908.int.example.com:8443
   name: vklnld908.int.example.com:8443
- cluster:
   insecure-skip-tls-verify: true
   server: https://vklnld1446.int.example.com:8443
   name: vklnld1446.int.example.com:8443
contexts: ---→ 2
- context:
   cluster: vklnld908.int.example.com:8443
   namespace: openshift-project
   user: vipin/vklnld908.int.example.com:8443
   name: openshift-project/vklnld908.int.example.com:8443/vipin
- context:
   cluster: vklnld908.int.example.com:8443
   namespace: testing-project
   user: alim/vklnld908.int.example.com:8443
   name: testproject-project/openshift1/alim
current-context: testing-project/vklnld908.int.example.com:8443/vipin - 3
kind: Config
preferences: {}

users:
- name: vipin/vklnld908.int.example.com:8443
user: ---→ 4
   token: ZCJKML2365jhdfafsdj797GkjgjGKJKJGjkg232

위의 구성에서 OpenShift 마스터 머신의 두 인스턴스를 정의하는 클러스터에서 시작하여 4 개의 주요 섹션으로 나뉘어져 있음을 알 수 있습니다. 두 번째 컨텍스트 섹션은 vipin 및 alim이라는 두 컨텍스트를 정의합니다. 현재 컨텍스트는 현재 사용중인 컨텍스트를 정의합니다. 여기서 정의를 변경하면 다른 컨텍스트 또는 프로필로 변경할 수 있습니다. 마지막으로 사용자 정의 및 인증 토큰이 정의되며, 우리의 경우에는 vipin입니다.

현재 사용중인 프로파일을 확인하려면 −

$ oc status oc status In project testing Project (testing-project) $ oc project
Using project "testing-project" from context named "testing-
project/vklnld908.int.example.com:8443/vipin" on server "https://vklnld908.int.example.com:8443".

다른 CLI로 전환하려면 다음 명령을 사용하여 명령 줄에서 수행 할 수 있습니다.

$ oc project openshift-project
Now using project "Openshift-project" on server "
https://vklnld908.int.example.com:8443".

위의 명령을 사용하여 프로필간에 전환 할 수 있습니다. 언제든지 구성을 보려면 $ oc config view 명령을 사용할 수 있습니다.

OpenShift CLI는 애플리케이션의 모든 기본 및 고급 구성, 관리, 추가 및 배포를 수행 할 수 있습니다.

OC 명령을 사용하여 다양한 종류의 작업을 수행 할 수 있습니다. 이 클라이언트는 OpenShift 또는 Kubernetes 호환 플랫폼에서 애플리케이션을 개발, 빌드, 배포 및 실행할 수 있도록 도와줍니다. 또한 'adm'하위 명령 아래에 클러스터를 관리하기위한 관리 명령이 포함되어 있습니다.

기본 명령

다음 표에는 기본 OC 명령이 나열되어 있습니다.

Sr. 아니. 명령 및 설명
1

Types

개념 및 유형 소개

2

Login

서버에 로그인

new-project

새 프로젝트 요청

4

new-app

새 응용 프로그램 만들기

5

Status

현재 프로젝트의 개요보기

6

Project

다른 프로젝트로 전환

7

Projects

기존 프로젝트 표시

8

Explain

자원 문서

9

Cluster

OpenShift 클러스터 시작 및 중지

로그인

서버에 로그인하고 나중에 사용할 수 있도록 로그인을 저장하십시오. 클라이언트를 처음 사용하는 사용자는이 명령을 실행하여 서버에 연결하고 인증 된 세션을 설정하고 구성 파일에 대한 연결을 저장해야합니다. 기본 구성은 ".kube / config"아래의 홈 디렉토리에 저장됩니다.

로그인에 필요한 정보 (예 : 사용자 이름 및 암호, 세션 토큰 또는 서버 세부 정보)는 플래그를 통해 제공 될 수 있습니다. 제공되지 않은 경우 명령은 필요에 따라 사용자 입력을 요청합니다.

Usage

oc login [URL] [options]

Example

# Log in interactively
oc login

# Log in to the given server with the given certificate authority file
oc login localhost:8443 --certificate-authority = /path/to/cert.crt

# Log in to the given server with the given credentials (will not prompt interactively)
oc login localhost:8443 --username = myuser --password=mypass

옵션-

-p, --password = " − 암호, 제공되지 않은 경우 프롬프트

-u, --username = " − 사용자 이름, 제공되지 않은 경우 프롬프트

--certificate-authority = "− 인증서 경로. 인증 기관용 파일

--insecure-skip-tls-verify = false− 참이면 서버 인증서의 유효성을 확인하지 않습니다. 이렇게하면 HTTPS 연결이 안전하지 않게됩니다.

--token = " − API 서버 인증을위한 Bearer 토큰

모든 명령에 대한 전체 세부 정보를 얻으려면 oc <Command Name> --help 명령.

명령 빌드 및 배포

다음 표에는 빌드 및 배포 명령이 나열되어 있습니다.

Sr. 아니. 명령 및 설명
1

Rollout

Kubernetes 배포 또는 OpenShift 배포 관리

2

Deploy

배포보기, 시작, 취소 또는 재시도

Rollback

응용 프로그램의 일부를 이전 상태로 되돌립니다.

4

new-build

새 빌드 구성 만들기

5

start-build

새 빌드 시작

6

cancel-build

실행 중, 보류 중 또는 새 빌드 취소

7

import-image

Docker 레지스트리에서 이미지를 가져옵니다.

8

Tag

기존 이미지를 이미지 스트림에 태그 지정

응용 프로그램 관리 명령

다음 표에는 응용 프로그램 관리 명령이 나열되어 있습니다.

Sr. 아니. 명령 및 설명
1

Get

하나 이상의 리소스 표시

2

Describe

특정 리소스 또는 리소스 그룹에 대한 세부 정보 표시

Edit

서버에서 리소스 편집

4

Set

개체에 특정 기능을 설정하는 데 도움이되는 명령

5

Label

리소스의 라벨 업데이트

6

Annotate

리소스에 대한 주석 업데이트

7

Expose

복제 된 애플리케이션을 서비스 또는 경로로 노출

8

Delete

하나 이상의 리소스 삭제

9

Scale

배포에서 포드 수 변경

10

Autoscale

배포 구성, 배포, 복제, 컨트롤러 또는 복제 세트 자동 확장

11

Secrets

비밀 관리

12

Serviceaccounts

프로젝트에서 서비스 계정 관리

문제 해결 및 디버깅 명령

다음 표에는 문제 해결 및 디버깅 명령이 나열되어 있습니다.

Sr. 아니. 명령 및 설명
1

logs

리소스에 대한 로그 인쇄

2

Rsh

포드에서 셸 세션 시작

Rsync

로컬 파일 시스템과 포드간에 파일 복사

4

port-forward

하나 이상의 로컬 포트를 포드로 전달

5

Debug

디버깅을 위해 포드의 새 인스턴스 시작

6

Exec

컨테이너에서 명령 실행

7

Procy

Kubernetes API 서버에 대한 프록시 실행

9

Attach

실행중인 컨테이너에 연결

10

Run

클러스터에서 특정 이미지 실행

11

Cp

컨테이너간에 파일 및 디렉터리 복사

고급 명령

다음 표에는 고급 명령이 나열되어 있습니다.

Sr. 아니. 명령 및 설명
1

adm

클러스터 관리 도구

2

create

파일 이름 또는 표준 입력으로 리소스 만들기

replace

리소스를 파일 이름 또는 표준 입력으로 교체

4

apply

파일 이름 또는 표준 입력으로 리소스에 구성 적용

5

patch

전략적 병합 패치를 사용하여 리소스 필드 업데이트

6

process

템플릿을 리소스 목록으로 처리

7

export

다른 곳에서 사용할 수 있도록 리소스 내보내기

8

extract

비밀 또는 구성 맵을 디스크로 추출

9

idle

유휴 확장 가능한 리소스

10

observe

자원의 변경 사항을 관찰하고 이에 대응 (실험적)

11

policy

권한 부여 정책 관리

12

auth

승인 검사

13

convert

다른 API 버전간에 구성 파일 변환

14

import

응용 프로그램을 가져 오는 명령

설정 명령

다음 표는 설정 명령을 나열합니다.

Sr. 아니. 명령 및 설명
1

Logout

현재 서버 세션 종료

2

Config

클라이언트에 대한 구성 파일 변경

Whoami

현재 세션에 대한 정보 반환

4

Completion

지정된 셸 (bash 또는 zsh)에 대한 출력 셸 완성 코드

OpenShift는 OpenShift 클러스터를 설정하는 두 가지 설치 방법을 사용합니다.

  • 빠른 설치 방법
  • 고급 구성 방법

클러스터 설정

빠른 설치 방법

이 방법은 얻을 수없는 빠른 클러스터 설정 구성을 실행하는 데 사용됩니다. 이 방법을 사용하려면 먼저 설치 프로그램을 설치해야합니다. 다음 명령을 실행하여 수행 할 수 있습니다.

Interactive method

$ atomic-openshift-installer install

이것은 대화 형 설정을 실행하고자 할 때 유용합니다.

Unattended installation method

이 방법은 무인 설치 방법을 설정하고자 할 때 사용되며, 사용자가 구성 yaml 파일을 정의하고 아래에 배치 할 수 있습니다. ~/.config/openshift/installer.cfg.yml의 이름으로. 그런 다음 다음 명령을 실행하여–u tag.

$ atomic-openshift-installer –u install

기본적으로 아래에있는 구성 파일을 사용합니다. ~/.config/openshift/. 반면 Ansible은 설치 백업으로 사용됩니다.

version: v2
variant: openshift-enterprise
variant_version: 3.1
ansible_log_path: /tmp/ansible.log

deployment:
   ansible_ssh_user: root
   hosts:
   - ip: 172.10.10.1
   hostname: vklnld908.int.example.com
   public_ip: 24.222.0.1
   public_hostname: master.example.com
   roles:
      - master
      - node
   containerized: true
   connect_to: 24.222.0.1
   
   - ip: 172.10.10.2
   hostname: vklnld1446.int.example.com
   public_ip: 24.222.0.2
   public_hostname: node1.example.com
   roles:
      - node
   connect_to: 10.0.0.2
   
   - ip: 172.10.10.3
   hostname: vklnld1447.int.example.com
   public_ip: 10..22.2.3
   public_hostname: node2.example.com
   roles:
      - node
   connect_to: 10.0.0.3

roles:
   master:
      <variable_name1>: "<value1>"
      <variable_name2>: "<value2>"
   node:
      <variable_name1>: "<value1>"

여기에는 특정 변수를 설정하려는 경우 정의 할 수있는 역할 별 변수가 있습니다.

완료되면 다음 명령을 사용하여 설치를 확인할 수 있습니다.

$ oc get nodes
NAME                    STATUS    AGE
master.example.com      Ready     10d
node1.example.com       Ready     10d
node2.example.com       Ready     10d

고급 설치

고급 설치는 마스터 및 노드 구성과 관련된 전체 호스트 구성 및 변수 정의가있는 Ansible 구성을 완전히 기반으로합니다. 여기에는 구성에 대한 모든 세부 정보가 포함됩니다.

설정이 완료되고 플레이 북이 준비되면 다음 명령을 실행하여 클러스터를 설정할 수 있습니다.

$ ansible-playbook -i inventry/hosts ~/openshift-ansible/playbooks/byo/config.yml

클러스터에 호스트 추가

다음을 사용하여 클러스터에 호스트를 추가 할 수 있습니다.

  • 빠른 설치 도구
  • 고급 구성 방법

Quick installation tool대화 형 및 비대화 형 모드 모두에서 작동합니다. 다음 명령을 사용하십시오.

$ atomic-openshift-installer -u -c </path/to/file> scaleup

애플리케이션 구성 파일 모양의 확장 형식은 마스터와 노드를 모두 추가하는 데 사용할 수 있습니다.

고급 구성 방법

이 방법에서는 Ansible의 호스트 파일을 업데이트 한 다음이 파일에 새 노드 또는 서버 세부 정보를 추가합니다. 구성 파일은 다음과 같습니다.

[OSEv3:children]
masters
nodes
new_nodes
new_master

동일한 Ansible 호스트 파일에서 아래와 같이 새 노드에 대한 변수 세부 정보를 추가합니다.

[new_nodes]
vklnld1448.int.example.com openshift_node_labels = "{'region': 'primary', 'zone': 'east'}"

마지막으로 업데이트 된 호스트 파일을 사용하여 새 구성을 실행하고 구성 파일을 호출하여 다음 명령을 사용하여 설정을 완료합니다.

$ ansible-playbook -i /inventory/hosts /usr/share/ansible/openshift-ansible/playbooks/test/openshift-node/scaleup.yml

클러스터 로그 관리

OpenShift 클러스터 로그는 클러스터의 마스터 및 노드 시스템에서 생성되는 로그에 불과합니다. 이들은 서버 로그, 마스터 로그, 컨테이너 로그, 포드 로그 등에서 시작하여 모든 종류의 로그를 관리 할 수 ​​있습니다. 컨테이너 로그 관리를위한 여러 기술과 애플리케이션이 있습니다.

로그 관리를 위해 구현할 수있는 도구는 목록에 거의 없습니다.

  • Fluentd
  • ELK
  • Kabna
  • Nagios
  • Splunk

ELK stack−이 스택은 모든 노드에서 로그를 수집하여 체계적인 형식으로 표시하는 데 유용합니다. ELK 스택은 주로 세 가지 주요 범주로 나뉩니다.

ElasticSearch − 주로 모든 컨테이너에서 정보를 수집하여 중앙 위치에 보관할 책임이 있습니다.

Fluentd − 수집 된 로그를 Elasticsearch 컨테이너 엔진에 공급하는 데 사용됩니다.

Kibana − 수집 된 데이터를 그래픽 인터페이스에서 유용한 정보로 표시하는 데 사용되는 그래픽 인터페이스.

한 가지 중요한 점은이 시스템이 클러스터에 배포되면 모든 노드에서 로그 수집을 시작한다는 것입니다.

로그 진단

OpenShift에는 oc adm dignostics여러 오류 상황을 분석하는 데 사용할 수있는 OC가있는 명령. 이 도구는 마스터에서 클러스터 관리자로 사용할 수 있습니다. 이 유틸리티는 알려진 문제를 해결하고 진단하는 데 매우 유용합니다. 이것은 마스터 클라이언트와 노드에서 실행됩니다.

agruments 또는 플래그없이 실행하면 클라이언트, 서버 및 노드 시스템의 구성 파일을 찾아 진단에 사용합니다. 다음 인수를 전달하여 개별적으로 진단을 실행할 수 있습니다.

  • AggregatedLogging
  • AnalyzeLogs
  • ClusterRegistry
  • ClusterRoleBindings
  • ClusterRoles
  • ClusterRouter
  • ConfigContexts
  • DiagnosticPod
  • MasterConfigCheck
  • MasterNode
  • MetricsApiProxy
  • NetworkCheck
  • NodeConfigCheck
  • NodeDefinitions
  • ServiceExternalIPs
  • UnitStatus

다음 명령으로 간단히 실행할 수 있습니다.

$ oc adm diagnostics <DiagnosticName>

클러스터 업그레이드

클러스터 업그레이드에는 클러스터 내의 여러 항목을 업그레이드하고 새 구성 요소 및 업그레이드로 클러스터를 업데이트하는 작업이 포함됩니다. 여기에는-

  • 마스터 구성 요소의 업그레이드
  • 노드 구성 요소의 업그레이드
  • 정책 업그레이드
  • 노선 업그레이드
  • 이미지 스트림 업그레이드

이러한 모든 업그레이드를 수행하려면 먼저 빠른 설치 프로그램이나 유틸리티를 준비해야합니다. 이를 위해 다음 유틸리티를 업데이트해야합니다.

  • atomic-openshift-utils
  • atomic-openshift-excluder
  • atomic-openshift-docker-excluder
  • etcd 패키지

업그레이드를 시작하기 전에 마스터 머신에 etcd를 백업해야합니다. 다음 명령을 사용하여 수행 할 수 있습니다.

$ ETCD_DATA_DIR = /var/lib/origin/openshift.local.etcd
$ etcdctl backup \ --data-dir $ETCD_DATA_DIR \
   --backup-dir $ETCD_DATA_DIR.bak.<date>

마스터 구성 요소의 업그레이드

OpenShift 마스터에서는 etcd 파일을 업데이트 한 다음 Docker로 이동하여 업그레이드를 시작합니다. 마지막으로 자동화 된 실행기를 실행하여 클러스터를 필요한 위치로 가져옵니다. 그러나 업그레이드를 시작하기 전에 먼저 각 마스터에서 atomic openshift 패키지를 활성화해야합니다. 다음 명령을 사용하여 수행 할 수 있습니다.

Step 1 − atomic-openshift 패키지 제거

$ atomic-openshift-excluder unexclude

Step 2 − 모든 마스터에서 etcd를 업그레이드합니다.

$ yum update etcd

Step 3 − etcd의 서비스를 다시 시작하고 성공적으로 시작되었는지 확인하십시오.

$ systemctl restart etcd
$ journalctl -r -u etcd

Step 4 − Docker 패키지를 업그레이드하십시오.

$ yum update docker

Step 5 − Docker 서비스를 다시 시작하고 올바르게 작동하는지 확인하십시오.

$ systemctl restart docker $ journalctl -r -u docker

Step 6 − 완료되면 다음 명령으로 시스템을 재부팅하십시오.

$ systemctl reboot $ journalctl -r -u docker

Step 7 − 마지막으로 atomic-executer를 실행하여 패키지를 yum excludes 목록으로 되돌립니다.

$ atomic-openshift-excluder exclude

정책 업그레이드에 대한 이러한 강제는 없으며 권장되는 경우에만 업그레이드해야하며 다음 명령으로 확인할 수 있습니다.

$ oadm policy reconcile-cluster-roles

대부분의 경우 정책 정의를 업데이트 할 필요가 없습니다.

노드 구성 요소의 업그레이드

마스터 업데이트가 완료되면 노드 업그레이드를 시작할 수 있습니다. 명심해야 할 한 가지는 클러스터에서 어떤 종류의 문제도 방지하기 위해 업그레이드 기간이 짧아야한다는 것입니다.

Step 1 − 업그레이드를 수행하려는 모든 노드에서 모든 원자 적 OpenShift 패키지를 제거합니다.

$ atomic-openshift-excluder unexclude

Step 2 − 다음으로 업그레이드 전에 노드 스케줄링을 비활성화합니다.

$ oadm manage-node <node name> --schedulable = false

Step 3 − 현재 호스트의 모든 노드를 다른 호스트로 복제합니다.

$ oadm drain <node name> --force --delete-local-data --ignore-daemonsets

Step 4 − 호스트에서 Docker 설정을 업그레이드합니다.

$ yum update docker

Step 5 − Docker 서비스를 다시 시작한 다음 Docker 서비스 노드를 시작합니다.

$systemctl restart docker $ systemctl restart atomic-openshift-node

Step 6 − 둘 다 올바르게 시작되었는지 확인하십시오.

$ journalctl -r -u atomic-openshift-node

Step 7 − 업그레이드가 완료된 후 노드 머신을 재부팅합니다.

$ systemctl reboot
$ journalctl -r -u docker

Step 8 − 노드에서 스케줄링을 다시 활성화합니다.

$ oadm manage-node <node> --schedulable.

Step 9 − atomic-openshift 실행기를 실행하여 OpenShift 패키지를 다시 노드로 가져옵니다.

$ atomic-openshift-excluder exclude

Step 10 − 마지막으로 모든 노드를 사용할 수 있는지 확인합니다.

$ oc get nodes

NAME                 STATUS   AGE
master.example.com   Ready    12d
node1.example.com    Ready    12d
node2.example.com    Ready    12d

자동 확장은 배포 된 애플리케이션이 특정 사양에 따라 필요할 때 확장 및 싱크 할 수있는 OpenShift의 기능입니다. OpenShift 애플리케이션에서 자동 확장은 포드 자동 확장이라고도합니다. 두 가지가있다types of application scaling 다음과 같이.

수직 확장

수직 확장은 단일 시스템에 더 많은 전력을 추가하는 것입니다. 즉, 더 많은 CPU와 하드 디스크를 추가해야합니다. 는 OpenShift 릴리스에서 지원되지 않는 이전 OpenShift 방법입니다.

수평 확장

이러한 유형의 확장은 머신 수를 늘려 더 많은 요청을 처리해야 할 때 유용합니다.

OpenShift에는 two methods to enable the scaling feature.

  • 배포 구성 파일 사용
  • 이미지를 실행하는 동안

배포 구성 파일 사용

이 방법에서 확장 기능은 deploymant 구성 yaml 파일을 통해 활성화됩니다. 이를 위해 OC autoscale 명령은 최소 및 최대 복제본 수와 함께 사용되며 이는 클러스터의 특정 시점에서 실행되어야합니다. 자동 확장 처리를 만들려면 개체 정의가 필요합니다. 다음은 포드 자동 확장 처리 정의 파일의 예입니다.

apiVersion: extensions/v1beta1
kind: HorizontalPodAutoscaler
metadata:
   name: database
spec:
   scaleRef:
      kind: DeploymentConfig
      name: database
      apiVersion: v1
      subresource: scale
   minReplicas: 1
   maxReplicas: 10
   cpuUtilization:
      targetPercentage: 80

파일이 준비되면 yaml 형식으로 저장하고 배포를 위해 다음 명령을 실행해야합니다.

$ oc create –f <file name>.yaml

이미지를 실행하는 동안

다음을 사용하여 yaml 파일없이 자동 확장 할 수도 있습니다. oc autoscale oc 명령 줄의 명령.

$ oc autoscale dc/database --min 1 --max 5 --cpu-percent = 75
deploymentconfig "database" autoscaled

이 명령은 나중에 참조 용으로 사용할 수있는 유사한 종류의 파일도 생성합니다.

OpenShift의 배포 전략

OpenShift의 배포 전략은 사용 가능한 다양한 방법으로 배포 흐름을 정의합니다. OpenShift에서 다음은important types of deployment strategies.

  • 롤링 전략
  • 전략 재생성
  • 맞춤형 전략

다음은 주로 OpenShift 노드에 배포하는 데 사용되는 배포 구성 파일의 예입니다.

kind: "DeploymentConfig"
apiVersion: "v1"
metadata:
   name: "database"
spec:
   template:
      metadata:
         labels:
            name: "Database1"
spec:
   containers:
      - name: "vipinopenshifttest"
         image: "openshift/mongoDB"
         ports:
            - containerPort: 8080
               protocol: "TCP"
replicas: 5
selector:
   name: "database"
triggers:
- type: "ConfigChange"
- type: "ImageChange"
   imageChangeParams:
      automatic: true
      containerNames:
         - "vipinopenshifttest"
      from:
         kind: "ImageStreamTag"
         name: "mongoDB:latest"
   strategy:
      type: "Rolling"

위의 Deploymentconfig 파일에는 Rolling이라는 전략이 있습니다.

배포를 위해 다음 OC 명령을 사용할 수 있습니다.

$ oc deploy <deployment_config> --latest

롤링 전략

롤링 전략은 롤링 업데이트 또는 배포에 사용됩니다. 이 프로세스는 모든 배포 프로세스에 코드를 삽입하는 데 사용되는 수명주기 후크도 지원합니다.

strategy:
   type: Rolling
   rollingParams:
      timeoutSeconds: <time in seconds>
      maxSurge: "<definition in %>"
      maxUnavailable: "<Defintion in %>"
      pre: {}
      post: {}

전략 재창조

이 배포 전략에는 롤링 배포 전략의 몇 가지 기본 기능이 있으며 수명주기 후크도 지원합니다.

strategy:
   type: Recreate
   recreateParams:
      pre: {}
      mid: {}
      post: {}

맞춤형 전략

이는 자신의 배포 프로세스 또는 흐름을 제공하고자 할 때 매우 유용합니다. 모든 사용자 지정은 요구 사항에 따라 수행 할 수 있습니다.

strategy:
   type: Custom
   customParams:
      image: organization/mongoDB
      command: [ "ls -l", "$HOME" ]
      environment:
         - name: VipinOpenshiftteat
         value: Dev1

이 장에서는 노드 관리 방법, 서비스 계정 구성 방법 등과 같은 주제를 다룹니다.

마스터 및 노드 구성

OpenShift에서는 새 서버를 부팅하기 위해 OC와 함께 시작 명령을 사용해야합니다. 새 마스터를 시작하는 동안에는 시작 명령과 함께 마스터를 사용해야하고 새 노드를 시작하는 동안 시작 명령과 함께 노드를 사용해야합니다. 이를 위해 마스터와 노드에 대한 구성 파일을 만들어야합니다. 다음 명령을 사용하여 마스터 및 노드에 대한 기본 구성 파일을 만들 수 있습니다.

마스터 구성 파일의 경우

$ openshift start master --write-config = /openshift.local.config/master

노드 구성 파일의 경우

$ oadm create-node-config --node-dir = /openshift.local.config/node-<node_hostname> --node = <node_hostname> --hostnames = <hostname>,<ip_address>

다음 명령을 실행하면 구성의 시작점으로 사용할 수있는 기본 구성 파일을 얻을 수 있습니다. 나중에 동일한 파일을 사용하여 새 서버를 부팅 할 수 있습니다.

apiLevels:
- v1beta3
- v1
apiVersion: v1
assetConfig:
   logoutURL: ""
   masterPublicURL: https://172.10.12.1:7449
   publicURL: https://172.10.2.2:7449/console/
      servingInfo:
         bindAddress: 0.0.0.0:7449
         certFile: master.server.crt
         clientCA: ""
keyFile: master.server.key
   maxRequestsInFlight: 0
   requestTimeoutSeconds: 0
controllers: '*'
corsAllowedOrigins:
- 172.10.2.2:7449
- 127.0.0.1
- localhost
dnsConfig:
   bindAddress: 0.0.0.0:53
etcdClientInfo:
   ca: ca.crt
   certFile: master.etcd-client.crt
   keyFile: master.etcd-client.key
   urls:
   - https://10.0.2.15:4001
etcdConfig:
   address: 10.0.2.15:4001
   peerAddress: 10.0.2.15:7001
   peerServingInfo:
      bindAddress: 0.0.0.0:7001
      certFile: etcd.server.crt
      clientCA: ca.crt
      keyFile: etcd.server.key
   servingInfo:
      bindAddress: 0.0.0.0:4001
      certFile: etcd.server.crt
      clientCA: ca.crt
      keyFile: etcd.server.key
   storageDirectory: /root/openshift.local.etcd
etcdStorageConfig:
   kubernetesStoragePrefix: kubernetes.io
   kubernetesStorageVersion: v1
   openShiftStoragePrefix: openshift.io
   openShiftStorageVersion: v1
imageConfig:
   format: openshift/origin-${component}:${version}
   latest: false
kind: MasterConfig
kubeletClientInfo:
   ca: ca.crt
   certFile: master.kubelet-client.crt
   keyFile: master.kubelet-client.key
   port: 10250
kubernetesMasterConfig:
   apiLevels:
   - v1beta3
   - v1
   apiServerArguments: null
   controllerArguments: null
   masterCount: 1
   masterIP: 10.0.2.15
   podEvictionTimeout: 5m
   schedulerConfigFile: ""
   servicesNodePortRange: 30000-32767
   servicesSubnet: 172.30.0.0/16
   staticNodeNames: []
masterClients:
   externalKubernetesKubeConfig: ""
   openshiftLoopbackKubeConfig: openshift-master.kubeconfig
masterPublicURL: https://172.10.2.2:7449
networkConfig:
   clusterNetworkCIDR: 10.1.0.0/16
   hostSubnetLength: 8
   networkPluginName: ""
   serviceNetworkCIDR: 172.30.0.0/16
oauthConfig:
   assetPublicURL: https://172.10.2.2:7449/console/
   grantConfig:
      method: auto
   identityProviders:
   - challenge: true
   login: true
   name: anypassword
   provider:
      apiVersion: v1
      kind: AllowAllPasswordIdentityProvider
   masterPublicURL: https://172.10.2.2:7449/
   masterURL: https://172.10.2.2:7449/
   sessionConfig:
      sessionMaxAgeSeconds: 300
      sessionName: ssn
      sessionSecretsFile: ""
   tokenConfig:
      accessTokenMaxAgeSeconds: 86400
      authorizeTokenMaxAgeSeconds: 300
policyConfig:
   bootstrapPolicyFile: policy.json
   openshiftInfrastructureNamespace: openshift-infra
   openshiftSharedResourcesNamespace: openshift
projectConfig:
   defaultNodeSelector: ""
   projectRequestMessage: ""
   projectRequestTemplate: ""
   securityAllocator:
      mcsAllocatorRange: s0:/2
      mcsLabelsPerProject: 5
      uidAllocatorRange: 1000000000-1999999999/10000
routingConfig:
   subdomain: router.default.svc.cluster.local
serviceAccountConfig:
   managedNames:
   - default
   - builder
   - deployer
   
masterCA: ca.crt
   privateKeyFile: serviceaccounts.private.key
   privateKeyFile: serviceaccounts.private.key
   publicKeyFiles:
   - serviceaccounts.public.key
servingInfo:
   bindAddress: 0.0.0.0:8443
   certFile: master.server.crt
   clientCA: ca.crt
   keyFile: master.server.key
   maxRequestsInFlight: 0
   requestTimeoutSeconds: 3600

노드 구성 파일

allowDisabledDocker: true
apiVersion: v1
dnsDomain: cluster.local
dnsIP: 172.10.2.2
dockerConfig:
   execHandlerName: native
imageConfig:
   format: openshift/origin-${component}:${version}
   latest: false
kind: NodeConfig
masterKubeConfig: node.kubeconfig
networkConfig:
   mtu: 1450
   networkPluginName: ""
nodeIP: ""
nodeName: node1.example.com

podManifestConfig:
   path: "/path/to/pod-manifest-file"
   fileCheckIntervalSeconds: 30
servingInfo:
   bindAddress: 0.0.0.0:10250
   certFile: server.crt
   clientCA: node-client-ca.crt
   keyFile: server.key
volumeDirectory: /root/openshift.local.volumes

이것이 노드 구성 파일의 모습입니다. 이러한 구성 파일이 준비되면 다음 명령을 실행하여 마스터 및 노드 서버를 만들 수 있습니다.

$ openshift start --master-config = /openshift.local.config/master/master-
config.yaml --node-config = /openshift.local.config/node-<node_hostname>/node-
config.yaml

노드 관리

OpenShift에는 OpenShift의 모든 작업을 수행하는 데 주로 사용되는 OC 명령 줄 유틸리티가 있습니다. 다음 명령을 사용하여 노드를 관리 할 수 ​​있습니다.

노드 나열

$ oc get nodes
NAME                             LABELS
node1.example.com     kubernetes.io/hostname = vklnld1446.int.example.com
node2.example.com     kubernetes.io/hostname = vklnld1447.int.example.com

노드에 대한 세부 사항 설명

$ oc describe node <node name>

노드 삭제

$ oc delete node <node name>

노드에 포드 나열

$ oadm manage-node <node1> <node2> --list-pods [--pod-selector=<pod_selector>] [-o json|yaml]

노드에서 포드 평가

$ oadm manage-node <node1> <node2> --evacuate --dry-run [--pod-selector=<pod_selector>]

구성 인증

OpenShift 마스터에는 인증 관리에 사용할 수있는 내장 OAuth 서버가 있습니다. 모든 OpenShift 사용자는이 서버에서 토큰을 가져 오므로 OpenShift API와 통신하는 데 도움이됩니다.

OpenShift에는 여러 종류의 인증 수준이 있으며 기본 구성 파일과 함께 구성 할 수 있습니다.

  • 모두 허용
  • 모두 거부
  • HTPasswd
  • LDAP
  • 기본 인증
  • 요청 헤더

마스터 구성을 정의하는 동안 사용할 정책 유형을 정의 할 수있는 식별 정책을 정의 할 수 있습니다.

모두 허용

모두 허용

oauthConfig:
   ...
   identityProviders:
   - name: Allow_Authontication
      challenge: true
      login: true
      provider:
         apiVersion: v1
         kind: AllowAllPasswordIdentityProvider

모두 거부

이렇게하면 모든 사용자 이름과 암호에 대한 액세스가 거부됩니다.

oauthConfig:
   ...
   identityProviders:
   - name: deny_Authontication
      challenge: true
      login: true
      provider:
         apiVersion: v1
         kind: DenyAllPasswordIdentityProvider

HTPasswd

HTPasswd는 암호화 된 파일 암호에 대해 사용자 이름과 암호를 확인하는 데 사용됩니다.

암호화 된 파일을 생성하기위한 명령은 다음과 같습니다.

$ htpasswd </path/to/users.htpasswd> <user_name>

암호화 된 파일 사용.

oauthConfig:
   ...
   identityProviders:
   - name: htpasswd_authontication
      challenge: true
      login: true
      provider:
         apiVersion: v1
         kind: HTPasswdPasswordIdentityProvider
         file: /path/to/users.htpasswd

LDAP ID 공급자

이는 LDAP 서버가 인증에서 중요한 역할을하는 LDAP 인증에 사용됩니다.

oauthConfig:
   ...
   identityProviders:
   - name: "ldap_authontication"
      challenge: true
      login: true
      provider:
         apiVersion: v1
         kind: LDAPPasswordIdentityProvider
         attributes:
            id:
            - dn
            email:
            - mail
            name:
            - cn
            preferredUsername:
            - uid
         bindDN: ""
         bindPassword: ""
         ca: my-ldap-ca-bundle.crt
         insecure: false
         url: "ldap://ldap.example.com/ou=users,dc=acme,dc=com?uid"

기본 인증

이것은 서버 간 인증에 대해 사용자 이름과 암호의 유효성 검사를 수행 할 때 사용됩니다. 인증은 기본 URL에서 보호되며 JSON 형식으로 제공됩니다.

oauthConfig:
   ...
   identityProviders:
   - name: my_remote_basic_auth_provider
      challenge: true
      login: true
      provider:
         apiVersion: v1
         kind: BasicAuthPasswordIdentityProvider
         url: https://www.vklnld908.int.example.com/remote-idp
         ca: /path/to/ca.file
         certFile: /path/to/client.crt
         keyFile: /path/to/client.key

서비스 계정 구성

서비스 계정은 인증을 위해 사용자 이름과 비밀번호를 노출하는 OpenShift API에 액세스하는 유연한 방법을 제공합니다.

서비스 계정 활성화

서비스 계정은 인증을 위해 공개 및 비공개 키의 키 쌍을 사용합니다. API에 대한 인증은 개인 키를 사용하여 수행되며 공개 키에 대해 유효성을 검사합니다.

ServiceAccountConfig:
   ...
   masterCA: ca.crt
   privateKeyFile: serviceaccounts.private.key
   publicKeyFiles:
   - serviceaccounts.public.key
   - ...

서비스 계정 생성

다음 명령어를 사용하여 서비스 계정을 만듭니다.

$ Openshift cli create service account <name of server account>

HTTP 프록시 작업

대부분의 프로덕션 환경에서 인터넷에 대한 직접 액세스가 제한됩니다. 인터넷에 노출되지 않거나 HTTP 또는 HTTPS 프록시를 통해 노출됩니다. OpenShift 환경에서이 프록시 시스템 정의는 환경 변수로 설정됩니다.

이는 아래에있는 마스터 및 노드 파일에 프록시 정의를 추가하여 수행 할 수 있습니다. /etc/sysconfig. 이는 다른 응용 프로그램과 유사합니다.

마스터 머신

/ etc / sysconfig / openshift-master

HTTP_PROXY=http://USERNAME:[email protected]:8080/
HTTPS_PROXY=https://USERNAME:[email protected]:8080/
NO_PROXY=master.vklnld908.int.example.com

노드 머신

/ etc / sysconfig / openshift-node

HTTP_PROXY=http://USERNAME:[email protected]:8080/
HTTPS_PROXY=https://USERNAME:[email protected]:8080/
NO_PROXY=master.vklnld908.int.example.com

완료되면 마스터 및 노드 머신을 다시 시작해야합니다.

Docker Pull의 경우

/ etc / sysconfig / docker

HTTP_PROXY = http://USERNAME:[email protected]:8080/
HTTPS_PROXY = https://USERNAME:[email protected]:8080/
NO_PROXY = master.vklnld1446.int.example.com

포드를 프록시 환경에서 실행하려면 다음을 사용하여 수행 할 수 있습니다.

containers:
- env:
   - name: "HTTP_PROXY"
      value: "http://USER:PASSWORD@:10.0.1.1:8080"

OC 환경 명령을 사용하여 기존 환경을 업데이트 할 수 있습니다.

NFS를 사용하는 OpenShift 스토리지

OpenShift에서 영구 볼륨 및 영구 볼륨 클레임의 개념은 영구 스토리지를 형성합니다. 이것은 첫 번째 영구 볼륨이 생성되고 나중에 동일한 볼륨이 청구되는 주요 개념 중 하나입니다. 이를 위해서는 기본 하드웨어에 충분한 용량과 디스크 공간이 있어야합니다.

apiVersion: v1
kind: PersistentVolume
metadata:
   name: storage-unit1
spec:
   capacity:
      storage: 10Gi
   accessModes:
   - ReadWriteOnce
   nfs:
      path: /opt
      server: 10.12.2.2
   persistentVolumeReclaimPolicy: Recycle

다음으로 OC create 명령을 사용하여 영구 볼륨을 만듭니다.

$ oc create -f storage-unit1.yaml

persistentvolume " storage-unit1 " created

생성 된 볼륨 청구.

apiVersion: v1
kind: PersistentVolumeClaim
metadata:
   name: Storage-clame1
spec:
   accessModes:
      - ReadWriteOnce
   resources:
      requests:
         storage: 5Gi

클레임을 생성합니다.

$ oc create -f Storage-claim1.yaml
persistentvolume " Storage-clame1 " created

사용자 및 역할 관리

사용자 및 역할 관리는 다른 프로젝트에 대한 사용자, 액세스 및 제어를 관리하는 데 사용됩니다.

사용자 생성

미리 정의 된 템플릿을 사용하여 OpenShift에서 새 사용자를 만들 수 있습니다.

kind: "Template"
apiVersion: "v1"
parameters:
   - name: vipin
   required: true
objects:
   - kind: "User"
   apiVersion: "v1"
   metadata:
   name: "${email}" - kind: "Identity" apiVersion: "v1" metadata: name: "vipin:${email}"
   providerName: "SAML"
   providerUserName: "${email}" - kind: "UserIdentityMapping" apiVersion: "v1" identity: name: "vipin:${email}"
user:
   name: "${email}"

oc create –f <파일 이름>을 사용하여 사용자를 만듭니다.

$ oc create –f vipin.yaml

다음 명령을 사용하여 OpenShift에서 사용자를 삭제합니다.

$ oc delete user <user name>

사용자 액세스 제한

ResourceQuotas 및 LimitRanges는 사용자 액세스 수준을 제한하는 데 사용됩니다. 클러스터에서 포드 및 컨테이너를 제한하는 데 사용됩니다.

apiVersion: v1
kind: ResourceQuota
metadata:
   name: resources-utilization
spec:
   hard:
      pods: "10"

위의 구성을 사용하여 견적 생성

$ oc create -f resource-quota.yaml –n –Openshift-sample

리소스 견적 설명

$ oc describe quota resource-quota  -n  Openshift-sample
Name:              resource-quota
Namespace:                              Openshift-sample
Resource           Used                  Hard
--------           ----                  ----
pods                3                    10

컨테이너 제한 정의는 배포 된 컨테이너에서 사용할 리소스를 제한하는 데 사용할 수 있습니다. 특정 개체의 최대 및 최소 제한을 정의하는 데 사용됩니다.

사용자 프로젝트 제한

이것은 기본적으로 사용자가 언제든지 가질 수있는 프로젝트 수에 사용됩니다. 기본적으로 사용자 레벨을 청동,은 및 금 범주로 정의하여 수행됩니다.

먼저 브론즈, 실버, 골드 카테고리가 가질 수있는 프로젝트 수의 가치를 보유하는 객체를 정의해야합니다. 이는 master-confif.yaml 파일에서 수행되어야합니다.

admissionConfig:
   pluginConfig:
      ProjectRequestLimit:
         configuration:
            apiVersion: v1
            kind: ProjectRequestLimitConfig
            limits:
            - selector:
               level: platinum
            - selector:
               level: gold
            maxProjects: 15
            - selector:
               level: silver
            maxProjects: 10
            - selector:
               level: bronze
            maxProjects: 5

마스터 서버를 다시 시작하십시오.

특정 수준에 사용자 할당.

$ oc label user vipin level = gold

필요한 경우 사용자를 레이블 밖으로 이동합니다.

$ oc label user <user_name> level-

사용자에게 역할 추가.

$ oadm policy add-role-to-user 
      
        <user_name> 
      

사용자로부터 역할 제거.

$ oadm policy remove-role-from-user 
      
        <user_name> 
      

사용자에게 클러스터 역할 추가.

$ oadm policy add-cluster-role-to-user 
      
        <user_name> 
      

사용자로부터 클러스터 역할 제거.

$ oadm policy remove-cluster-role-from-user 
      
        <user_name> 
      

그룹에 역할 추가.

$ oadm policy add-role-to-user 
      
        <user_name> 
      

그룹에서 역할 제거.

$ oadm policy remove-cluster-role-from-user 
      
        <user_name> 
      

그룹에 클러스터 역할 추가.

$ oadm policy add-cluster-role-to-group 
      
        <groupname> 
      

그룹에서 클러스터 역할 제거.

$ oadm policy remove-cluster-role-from-group <role> <groupname>

클러스터 관리 용 사용자

이것은 사용자가 클러스터 생성부터 삭제까지 전체 클러스터를 관리 할 수있는 가장 강력한 역할 중 하나입니다.

$ oadm policy add-role-to-user admin <user_name> -n <project_name>

궁극의 힘을 가진 사용자

$ oadm policy add-cluster-role-to-user cluster-admin <user_name>

OpenShift는 Docker 및 Kubernetes를 기반으로 구축되었습니다. 모든 컨테이너는 Kubernetes 오케스트레이션 기능을 사용하여 기본적으로 Linux 시스템의 Kubernetes 서비스 인 Docker 클러스터 위에 빌드됩니다.

이 프로세스에서는 모든 노드를 제어하고 컨테이너를 모든 노드에 배포하는 Kubernetes 마스터를 빌드합니다. Kubernetes의 주요 기능은 다른 종류의 구성 파일을 사용하여 OpenShift 클러스터 및 배포 흐름을 제어하는 ​​것입니다. Kubernetes에서와 마찬가지로 OC 명령 줄 유틸리티를 사용하여 클러스터 노드에 컨테이너를 빌드하고 배포하는 것과 동일한 방식으로 kubctl을 사용합니다.

다음은 클러스터에서 다른 종류의 개체를 만드는 데 사용되는 다양한 종류의 구성 파일입니다.

  • Images
  • POD
  • Service
  • 복제 컨트롤러
  • 복제 세트
  • Deployment

이미지

Kubernetes (Docker) 이미지는 컨테이너화 된 인프라의 핵심 구성 요소입니다. 현재 Kubernetes는Docker이미지. 포드의 각 컨테이너에는 내부에서 실행되는 Docker 이미지가 있습니다.

apiVersion: v1
kind: pod
metadata:
   name: Tesing_for_Image_pull -----------> 1
   spec:
   containers:
- name: neo4j-server ------------------------> 2
image: <Name of the Docker image>----------> 3
imagePullPolicy: Always ------------->4
command: [“echo”, “SUCCESS”] -------------------> 5

현물 상환 지불

포드는 Kubernetes 클러스터의 노드 내부에있는 컨테이너 및 스토리지의 모음입니다. 내부에 여러 컨테이너가있는 포드를 만들 수 있습니다. 다음은 데이터베이스 컨테이너와 웹 인터페이스 컨테이너를 동일한 포드에 유지하는 예입니다.

apiVersion: v1
kind: Pod
metadata:
   name: Tomcat
spec:
   containers:
   - name: Tomcat
      image: tomcat: 8.0
      ports:
- containerPort: 7500
imagePullPolicy: Always

서비스

서비스는 논리적 포드 집합으로 정의 할 수 있습니다. 포드에 액세스 할 수있는 단일 IP 주소 및 DNS 이름을 제공하는 포드 위에 추상화로 정의 할 수 있습니다. Service를 사용하면로드 밸런싱 구성을 매우 쉽게 관리 할 수 ​​있습니다. POD를 매우 쉽게 확장 할 수 있습니다.

apiVersion: v1
kind: Service
metadata:
   name: Tutorial_point_service
spec:
   ports:
   - port: 8080
      targetPort: 31999

복제 컨트롤러

복제 컨트롤러는 포드 수명주기를 관리하는 Kubernetes의 주요 기능 중 하나입니다. 특정 시점에 지정된 수의 포드 복제본이 실행되고 있는지 확인해야합니다.

apiVersion: v1
kind: ReplicationController
metadata:
   name: Tomcat-ReplicationController
spec:
   replicas: 3
   template:
   metadata:
      name: Tomcat-ReplicationController
   labels:
      app: App
      component: neo4j
   spec:
      containers:
      - name: Tomcat
      image: tomcat: 8.0
      ports:
      - containerPort: 7474

복제 세트

복제본 세트는 실행해야하는 포드 복제본 수를 보장합니다. 복제 컨트롤러의 교체로 간주 할 수 있습니다.

apiVersion: extensions/v1beta1
kind: ReplicaSet
metadata:
   name: Tomcat-ReplicaSet
spec:
   replicas: 3
   selector:
      matchLables:
      tier: Backend
   matchExpression:
      - { key: tier, operation: In, values: [Backend]}
   
   app: App
   component: neo4j
spec:
   containers:
   - name: Tomcat-
image: tomcat: 8.0
   ports:
containerPort: 7474

전개

배포가 업그레이드되고 더 높은 버전의 복제 컨트롤러가 있습니다. 복제 컨트롤러의 업그레이드 된 버전이기도 한 복제 세트의 배포를 관리합니다. 복제본 세트를 업데이트하는 기능이 있으며 이전 버전으로 롤백 할 수도 있습니다.

apiVersion: extensions/v1beta1 --------------------->1
kind: Deployment --------------------------> 2
metadata:
   name: Tomcat-ReplicaSet
spec:
   replicas: 3
   template:
      metadata:
lables:
   app: Tomcat-ReplicaSet
   tier: Backend
spec:
   containers:
name: Tomcat-
   image: tomcat: 8.0
   ports:
   - containerPort: 7474

모든 구성 파일을 사용하여 각각의 Kubernetes 개체를 만들 수 있습니다.

$ Kubectl create –f <file name>.yaml

다음 명령을 사용하여 Kubernetes 개체의 세부 정보와 설명을 알 수 있습니다.

For POD

$ Kubectl get pod <pod name> $ kubectl delete pod <pod name>
$ kubectl describe pod <pod name>

For Replication Controller

$ Kubectl get rc <rc name>
$ kubectl delete rc <rc name> $ kubectl describe rc <rc name>

For Service

$ Kubectl get svc <svc name> $ kubectl delete svc <svc name>
$ kubectl describe svc <svc name>

Docker 및 Kubernetes 작업 방법에 대한 자세한 내용은 다음 링크 kubernetes를 사용하여 Kubernetes 자습서를 참조하십시오 .

OpenShift 보안은 주로 보안 제약을 주로 처리하는 두 가지 구성 요소의 조합입니다.

  • 보안 컨텍스트 제약 (SCC)
  • 서비스 계정

보안 컨텍스트 제약 (SCC)

기본적으로 포드 제한에 사용됩니다. 즉, 수행 할 수있는 작업과 클러스터에서 액세스 할 수있는 모든 항목과 같이 포드에 대한 제한을 정의합니다.

OpenShift는 관리자가 사용, 수정 및 확장 할 수있는 사전 정의 된 SCC 세트를 제공합니다.

$ oc get scc
NAME              PRIV   CAPS  HOSTDIR  SELINUX    RUNASUSER         FSGROUP   SUPGROUP  PRIORITY
anyuid            false   []   false    MustRunAs  RunAsAny          RunAsAny  RunAsAny  10
hostaccess        false   []   true     MustRunAs  MustRunAsRange    RunAsAny  RunAsAny  <none>
hostmount-anyuid  false   []   true     MustRunAs  RunAsAny          RunAsAny  RunAsAny  <none>
nonroot           false   []   false    MustRunAs  MustRunAsNonRoot  RunAsAny  RunAsAny  <none>
privileged        true    []   true     RunAsAny   RunAsAny          RunAsAny  RunAsAny  <none>
restricted        false   []   false    MustRunAs  MustRunAsRange    RunAsAny  RunAsAny  <none>

미리 정의 된 scc를 사용하려면 scc 그룹에 사용자 또는 그룹을 추가하기 만하면됩니다.

$ oadm policy add-user-to-scc <scc_name> <user_name> $ oadm policy add-group-to-scc <scc_name> <group_name>

서비스 계정

서비스 계정은 기본적으로 마스터 또는 노드 머신에서 명령이나 요청이 실행될 때 호출되는 OpenShift 마스터 API에 대한 액세스를 제어하는 ​​데 사용됩니다.

응용 프로그램 또는 프로세스에 제한된 SCC에서 부여하지 않은 기능이 필요할 때마다 특정 서비스 계정을 만들고 각 SCC에 계정을 추가해야합니다. 그러나 SCC가 요구 사항에 적합하지 않은 경우 가장 적합한 SCC를 사용하는 것보다 요구 사항에 맞는 새 SCC를 만드는 것이 좋습니다. 결국 배포 구성에 대해 설정하십시오.

$ oc create serviceaccount Cadmin $ oc adm policy add-scc-to-user vipin -z Cadmin

컨테이너 보안

OpenShift에서 컨테이너의 보안은 컨테이너 플랫폼의 보안 수준과 컨테이너가 실행되는 위치에 대한 개념을 기반으로합니다. 컨테이너 보안과 처리해야 할 사항에 대해 이야기 할 때 여러 가지가 떠 오릅니다.

Image Provenance − 생산 환경에서 실행되는 컨테이너의 출처를 정확하고 논란의 여지없이 정확히 식별하는 보안 라벨링 시스템이 마련되어 있습니다.

Security Scanning − 이미지 스캐너는 모든 이미지에서 알려진 취약점을 자동으로 확인합니다.

Auditing − 모든 컨테이너가 최신 컨테이너를 기반으로하고 호스트와 컨테이너가 모두 안전하게 구성되었는지 확인하기 위해 프로덕션 환경을 정기적으로 감사합니다.

Isolation and Least Privilege− 컨테이너는 효과적으로 작동하는 데 필요한 최소한의 리소스와 권한으로 실행됩니다. 그들은 호스트 또는 다른 컨테이너를 부당하게 방해 할 수 없습니다.

Runtime Threat Detection − 런타임에 컨테이너화 된 애플리케이션에 대한 활성 위협을 감지하고 이에 자동으로 대응하는 기능.

Access Controls − AppArmor 또는 SELinux와 같은 Linux 보안 모듈은 액세스 제어를 시행하는 데 사용됩니다.

컨테이너 보안을 보관하는 주요 방법은 거의 없습니다.

  • oAuth를 통한 액세스 제어
  • 셀프 서비스 웹 콘솔을 통해
  • 플랫폼 인증서 별

OAuth를 통한 액세스 제어

이 방법에서는 API 제어 액세스에 대한 인증이 보관되어 OpenShift 마스터 머신에 내장 된 OAuth 서버를 통해 인증을위한 보안 토큰을 얻습니다. 관리자는 OAuth 서버 구성의 구성을 수정할 수 있습니다.

OAuth 서버 구성에 대한 자세한 내용은이 자습서의 5 장을 참조하십시오.

셀프 서비스 웹 콘솔을 통해

이 웹 콘솔 보안 기능은 OpenShift 웹 콘솔에 내장되어 있습니다. 이 콘솔은 함께 작업하는 모든 팀이 인증없이 다른 환경에 액세스 할 수 없도록합니다. OpenShift의 다중 텔넷 마스터에는 다음과 같은 보안 기능이 있습니다.

  • TCL 레이어가 활성화 됨
  • 인증을 위해 x.509 인증서 사용
  • 마스터 시스템에서 etcd 구성을 보호합니다.

플랫폼 인증서 별

이 방법에서 각 호스트에 대한 인증서는 Ansible을 통해 설치 중에 구성됩니다. Rest API를 통해 HTTPS 통신 프로토콜을 사용하므로 다른 구성 요소 및 개체에 대한 TCL 보안 연결이 필요합니다. 이들은 미리 정의 된 인증서이지만 액세스를 위해 마스터 클러스터에 사용자 지정 인증서를 설치할 수도 있습니다. 마스터의 초기 설정 중에 사용자 지정 인증서는 다음을 사용하여 기존 인증서를 재정 의하여 구성 할 수 있습니다.openshift_master_overwrite_named_certificates 매개 변수.

Example

openshift_master_named_certificates = [{"certfile": "/path/on/host/to/master.crt", 
"keyfile": "/path/on/host/to/master.key", 
"cafile": "/path/on/host/to/mastercert.crt"}]

사용자 지정 인증서를 생성하는 방법에 대한 자세한 내용은 다음 링크를 방문하십시오.

https://www.linux.com/learn/creating-self-signed-ssl-certificates-apache-linux

네트워크 보안

OpenShift에서는 SDN (소프트웨어 정의 네트워킹)이 통신에 사용됩니다. 네트워크 네임 스페이스는 클러스터의 각 포드에 사용되며, 각 포드는 자체 IP와 포트 범위를 가져와 네트워크 트래픽을 가져옵니다. 이 방법을 사용하면 다른 프로젝트의 포드와 통신 할 수없는 포드를 분리 할 수 ​​있습니다.

프로젝트 분리

이것은 클러스터 관리자가 다음을 사용하여 수행 할 수 있습니다. oadm command CLI에서.

$ oadm pod-network isolate-projects <project name 1> <project name 2>

이는 위에 정의 된 프로젝트가 클러스터의 다른 프로젝트와 통신 할 수 없음을 의미합니다.

볼륨 보안

볼륨 보안은 OpenShift 클러스터에서 프로젝트의 PV 및 PVC를 보호하는 것을 의미합니다. OpenShift에서 볼륨에 대한 액세스를 제어하기위한 주로 4 개의 섹션이 있습니다.

  • 보충 그룹
  • fsGroup
  • runAsUser
  • seLinuxOptions

보충 그룹-보충 그룹은 일반 Linux 그룹입니다. 프로세스가 시스템에서 실행되면 사용자 ID 및 그룹 ID로 실행됩니다. 이 그룹은 공유 스토리지에 대한 액세스를 제어하는 ​​데 사용됩니다.

다음 명령을 사용하여 NFS 마운트를 확인하십시오.

# showmount -e <nfs-server-ip-or-hostname>
Export list for f21-nfs.vm:
/opt/nfs *

다음 명령을 사용하여 마운트 서버에서 NFS 세부 정보를 확인합니다.

# cat /etc/exports
/opt/nfs *(rw,sync,no_root_squash)
...
# ls -lZ /opt/nfs -d
drwxrws---. nfsnobody 2325 unconfined_u:object_r:usr_t:s0 /opt/nfs
# id nfsnobody
uid = 65534(nfsnobody) gid = 454265(nfsnobody) groups = 454265(nfsnobody)

/ 옵션 / NFS / 수출 UID에서 액세스 할 수454265 그리고 그룹 2325.

apiVersion: v1
kind: Pod
...
spec:
   containers:
   - name: ...
      volumeMounts:
      - name: nfs
         mountPath: /usr/share/...
   securityContext:
      supplementalGroups: [2325]
   volumes:
   - name: nfs
      nfs:
      server: <nfs_server_ip_or_host>
      path: /opt/nfs

fsGroup

fsGroup은 컨테이너 보충 그룹을 추가하는 데 사용되는 파일 시스템 그룹을 나타냅니다. 보조 그룹 ID는 공유 스토리지에 사용되며 fsGroup은 블록 스토리지에 사용됩니다.

kind: Pod
spec:
   containers:
   - name: ...
   securityContext:
      fsGroup: 2325

runAsUser

runAsUser는 통신에 사용자 ID를 사용합니다. 포드 정의에서 컨테이너 이미지를 정의하는 데 사용됩니다. 필요한 경우 모든 컨테이너에서 단일 ID 사용자를 사용할 수 있습니다.

컨테이너를 실행하는 동안 정의 된 ID는 내보내기의 소유자 ID와 일치합니다. 지정된 ID가 외부에 정의 된 경우 포드의 모든 컨테이너에 대해 전역이됩니다. 특정 포드로 정의 된 경우 단일 컨테이너에만 적용됩니다.

spec:
   containers:
   - name: ...
      securityContext:
         runAsUser: 454265