5.13. 설치 구성 파일 만들기
VMware vSphere에 설치하는 OpenShift Container Platform 클러스터를 사용자 지정할 수 있습니다.
사전 요구 사항
- OpenShift Container Platform 설치 프로그램과 클러스터의 풀 시크릿을 받습니다. 제한된 네트워크 설치의 경우, 해당 파일은 미러 호스트에 있습니다.
-
미러 레지스트리 작성 중에 생성된
imageContentSources
값이 있어야 합니다. - 미러 레지스트리에 대한 인증서의 내용을 가져옵니다.
- RHCOS (Red Hat Enterprise Linux CoreOS) 이미지를 검색하여 액세스 가능한 위치에 업로드합니다.
- 서브스크립션 수준에서 서비스 권한을 확보합니다.
프로세스
install-config.yaml
파일을 생성합니다.설치 프로그램이 포함된 디렉터리로 변경하고 다음 명령을 실행합니다.
$ ./openshift-install create install-config --dir <installation_directory> 1
- 1
<installation_directory>
는 설치 프로그램이 생성하는 파일을 저장할 디렉터리 이름을 지정합니다.
디렉터리를 지정할 때 다음을 수행합니다.
-
디렉터리에
실행
권한이 있는지 확인합니다. 설치 디렉토리에서 Terraform 바이너리를 실행하려면 이 권한이 필요합니다. 빈 디렉터리를 사용합니다. 부트스트랩 X.509 인증서와 같은 일부 설치 자산은 단기간에 만료되므로 설치 디렉터리를 재사용해서는 안 됩니다. 다른 클러스터 설치의 개별 파일을 재사용하려면 해당 파일을 사용자 디렉터리에 복사하면 됩니다. 그러나 설치 자산의 파일 이름은 릴리스간에 변경될 수 있습니다. 따라서 이전 OpenShift Container Platform 버전에서 설치 파일을 복사할 때는 주의하십시오.
참고항상
~/.powervs
디렉터리를 삭제하여 오래된 구성을 재사용하지 않도록 합니다. 다음 명령을 실행합니다.$ rm -rf ~/.powervs
화면에 나타나는 지시에 따라 클라우드에 대한 구성 세부 사항을 입력합니다.
선택사항: 클러스터 시스템에 액세스하는 데 사용할 SSH 키를 선택합니다.
참고설치 디버깅 또는 재해 복구를 수행하려는 프로덕션 OpenShift Container Platform 클러스터의 경우
ssh-agent
프로세스가 사용하는 SSH 키를 지정합니다.- 대상 플랫폼으로 vsphere를 선택합니다.
- vCenter 인스턴스의 이름을 지정합니다.
클러스터를 생성하는 데 필요한 권한이 있는 vCenter 계정의 사용자 이름과 암호를 지정합니다.
설치 프로그램이 vCenter 인스턴스에 연결됩니다.
연결할 vCenter 인스턴스에서 데이터 센터를 선택합니다.
참고설치 구성 파일을 생성한 후 파일을 수정하여 여러 vSphere 데이터 센터 환경을 생성할 수 있습니다. 즉, 단일 VMware vCenter에서 실행되는 여러 vSphere 데이터 센터에 OpenShift Container Platform 클러스터를 배포할 수 있습니다. 이 환경 생성에 대한 자세한 내용은 VMware vSphere 리전 및 영역 활성화 섹션을 참조하십시오.
- 사용할 기본 vCenter 데이터 저장소를 선택합니다.
- OpenShift Container Platform 클러스터를 설치할 vCenter 클러스터를 선택합니다. 설치 프로그램은 vSphere 클러스터의 루트 리소스 풀을 기본 리소스 풀로 사용합니다.
- vCenter 인스턴스에서 구성한 가상 IP 주소 및 DNS 레코드가 포함된 네트워크를 선택합니다.
- 컨트롤 플레인 API 액세스를 위해 구성한 가상 IP 주소를 입력합니다.
- 클러스터 인그레스용으로 구성한 가상 IP 주소를 입력합니다.
- 기본 도메인을 입력합니다. 이 기본 도메인은 구성한 DNS 레코드에서 사용한 것과 동일해야 합니다.
- 클러스터를 설명할 수 있는 이름을 입력합니다. 입력한 클러스터 이름은 DNS 레코드를 구성할 때 지정한 클러스터 이름과 일치해야 합니다.
- Red Hat OpenShift Cluster Manager에서 풀 시크릿 을 붙여넣습니다.
install-config.yaml
파일에서platform.vsphere.clusterOSImage
값을 이미지 위치 또는 이름으로 설정합니다. 예를 들면 다음과 같습니다.platform: vsphere: clusterOSImage: http://mirror.example.com/images/rhcos-43.81.201912131630.0-vmware.x86_64.ova?sha256=ffebbd68e8a1f2a245ca19522c16c86f67f9ac8e4e0c1f0a812b068b16f7265d
install-config.yaml
파일을 편집하여 제한된 네트워크에 설치하는 데 필요한 추가 정보를 제공합니다.레지스트리의 인증 정보를 포함하도록
pullSecret
값을 업데이트합니다.pullSecret: '{"auths":{"<mirror_host_name>:5000": {"auth": "<credentials>","email": "you@example.com"}}}'
<mirror_host_name>
의 경우 미러 레지스트리의 인증서에 지정한 레지스트리 도메인 이름을 지정하고<credentials>
의 경우 미러 레지스트리에 base64로 인코딩된 사용자 이름 및 암호를 지정합니다.additionalTrustBundle
매개변수와 값을 추가합니다.additionalTrustBundle: | -----BEGIN CERTIFICATE----- ZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZ -----END CERTIFICATE-----
값은 미러 레지스트리에 사용한 인증서 파일의 내용이어야 합니다. 인증서 파일은 신뢰할 수 있는 기존 인증 기관 또는 미러 레지스트리에 대해 생성한 자체 서명 인증서일 수 있습니다.
다음 YAML 발췌와 유사한 이미지 콘텐츠 리소스를 추가합니다.
imageContentSources: - mirrors: - <mirror_host_name>:5000/<repo_name>/release source: quay.io/openshift-release-dev/ocp-release - mirrors: - <mirror_host_name>:5000/<repo_name>/release source: registry.redhat.io/ocp/release
이러한 값은 미러 레지스트리 생성 중에 기록한
imageContentSources
를 사용합니다.
-
필요한
install-config.yaml
파일을 수정합니다. 사용 가능한 매개변수에 대한 자세한 정보는 Installation configuration parameters 섹션에서 확인할 수 있습니다. 여러 클러스터를 설치하는 데 사용할 수 있도록
install-config.yaml
파일을 백업합니다.중요install-config.yaml
파일은 설치 과정에서 사용됩니다. 이 파일을 재사용하려면 지금 백업해야 합니다.
5.13.1. 설치 구성 매개변수
OpenShift Container Platform 클러스터를 배포하기 전에 매개변수 값을 제공하여 클러스터를 호스팅할 클라우드 플랫폼에서 사용자 계정을 설명하고 선택사항으로 클러스터의 플랫폼을 사용자 지정합니다. install-config.yaml
설치 구성 파일을 생성할 때 명령줄을 통해 필요한 매개변수 값을 제공합니다. 클러스터를 사용자 지정하면 install-config.yaml
파일을 수정하여 플랫폼에 대한 세부 정보를 제공할 수 있습니다.
설치한 후에는 install-config.yaml
파일에서 이러한 매개변수를 수정할 수 없습니다.
5.13.1.1. 필수 구성 매개변수
필수 설치 구성 매개변수는 다음 표에 설명되어 있습니다.
매개변수 | 설명 | 값 |
---|---|---|
|
| 문자열 |
|
클라우드 공급자의 기본 도메인입니다. 기본 도메인은 OpenShift Container Platform 클러스터 구성 요소에 대한 경로를 생성하는 데 사용됩니다. 클러스터의 전체 DNS 이름은 |
정규화된 도메인 또는 하위 도메인 이름(예: |
|
Kubernetes 리소스 | 개체 |
|
클러스터의 이름입니다. 클러스터의 DNS 레코드는 |
소문자 및 하이픈( |
|
설치를 수행할 특정 플랫폼에 대한 구성: | 개체 |
| Red Hat OpenShift Cluster Manager에서 풀 시크릿을 가져와서 Quay.io와 같은 서비스에서 OpenShift Container Platform 구성 요소의 컨테이너 이미지 다운로드를 인증합니다. |
{ "auths":{ "cloud.openshift.com":{ "auth":"b3Blb=", "email":"you@example.com" }, "quay.io":{ "auth":"b3Blb=", "email":"you@example.com" } } } |
5.13.1.2. 네트워크 구성 매개변수
기존 네트워크 인프라의 요구 사항에 따라 설치 구성을 사용자 지정할 수 있습니다. 예를 들어 클러스터 네트워크의 IP 주소 블록을 확장하거나 기본값과 다른 IP 주소 블록을 제공할 수 있습니다.
IPv4 주소만 지원됩니다.
Red Hat OpenShift Data Foundation 재해 복구 솔루션에서는 Globalnet이 지원되지 않습니다. 지역 재해 복구 시나리오의 경우 각 클러스터의 클러스터 및 서비스 네트워크에 대해 겹치지 않는 개인 IP 주소를 사용해야 합니다.
매개변수 | 설명 | 값 |
---|---|---|
| 클러스터의 네트워크의 구성입니다. | 개체 참고
설치한 후에는 |
| 설치할 Red Hat OpenShift Networking 네트워크 플러그인입니다. |
|
| Pod의 IP 주소 블록입니다.
기본값은 여러 IP 주소 블록을 지정하는 경우 블록이 겹치지 않아야 합니다. | 개체의 배열입니다. 예를 들면 다음과 같습니다. networking: clusterNetwork: - cidr: 10.128.0.0/14 hostPrefix: 23 |
|
IPv4 네트워크입니다. |
CIDR(Classless Inter-Domain Routing) 표기법의 IP 주소 블록입니다. IPv4 블록의 접두사 길이는 |
|
개별 노드 각각에 할당할 서브넷 접두사 길이입니다. 예를 들어 | 서브넷 접두사입니다.
기본값은 |
|
서비스의 IP 주소 블록입니다. 기본값은 OpenShift SDN 및 OVN-Kubernetes 네트워크 플러그인은 서비스 네트워크에 대한 단일 IP 주소 블록만 지원합니다. | CIDR 형식의 IP 주소 블록이 있는 어레이입니다. 예를 들면 다음과 같습니다. networking: serviceNetwork: - 172.30.0.0/16 |
| 시스템의 IP 주소 블록입니다. 여러 IP 주소 블록을 지정하는 경우 블록이 겹치지 않아야 합니다. | 개체의 배열입니다. 예를 들면 다음과 같습니다. networking: machineNetwork: - cidr: 10.0.0.0/16 |
|
| CIDR 표기법의 IP 네트워크 블록입니다.
예: 참고
기본 NIC가 상주하는 CIDR과 일치하도록 |
5.13.1.3. 선택적 구성 매개변수
선택적 설치 구성 매개변수는 다음 표에 설명되어 있습니다.
매개변수 | 설명 | 값 |
---|---|---|
| 노드의 신뢰할 수 있는 인증서 스토리지에 추가되는 PEM 인코딩 X.509 인증서 번들입니다. 이 신뢰할 수 있는 번들은 프록시가 구성되었을 때에도 사용할 수 있습니다. | 문자열 |
| 선택적 핵심 클러스터 구성 요소의 설치를 제어합니다. 선택적 구성 요소를 비활성화하여 OpenShift Container Platform 클러스터의 설치 공간을 줄일 수 있습니다. 자세한 내용은 설치 의 "클러스터 기능" 페이지를 참조하십시오. | 문자열 배열 |
|
활성화할 선택적 기능 세트를 선택합니다. 유효한 값은 | 문자열 |
|
| 문자열 배열 |
| 워크로드 파티셔닝을 통해 OpenShift Container Platform 서비스, 클러스터 관리 워크로드 및 인프라 Pod를 분리하여 예약된 CPU 세트에서 실행할 수 있습니다. 워크로드 파티셔닝은 설치 중에만 활성화할 수 있으며 설치 후에는 비활성화할 수 없습니다. 이 필드를 사용하면 워크로드 파티셔닝을 사용할 수 있지만 특정 CPU를 사용하도록 워크로드를 구성하지 않습니다. 자세한 내용은 확장 및 성능 섹션의 워크로드 파티션 페이지를 참조하십시오. |
|
| 컴퓨팅 노드를 구성하는 시스템의 구성입니다. |
|
|
풀에 있는 시스템의 명령어 집합 아키텍처를 결정합니다. 현재 다양한 아키텍처가 있는 클러스터는 지원되지 않습니다. 모든 풀은 동일한 아키텍처를 지정해야 합니다. 유효한 값은 | 문자열 |
Compute: hyperthreading: |
컴퓨팅 시스템에서 동시 멀티스레딩 또는 중요 동시 멀티스레딩을 비활성화하는 경우 용량 계획에서 시스템 성능이 크게 저하될 수 있는 문제를 고려해야 합니다. |
|
|
|
|
|
|
|
| 프로비저닝할 컴퓨팅 시스템(작업자 시스템이라고도 함) 수입니다. |
|
| 기능 세트를 위한 클러스터를 활성화합니다. 기능 세트는 기본적으로 활성화되어 있지 않은 OpenShift Container Platform 기능 컬렉션입니다. 설치 중에 기능 세트를 활성화하는 방법에 대한 자세한 내용은 "기능 게이트를 사용하여 기능 활성화"를 참조하십시오. |
문자열. |
| 컨트롤 플레인을 구성하는 시스템들의 구성입니다. |
|
|
풀에 있는 시스템의 명령어 집합 아키텍처를 결정합니다. 현재 다양한 아키텍처가 있는 클러스터는 지원되지 않습니다. 모든 풀은 동일한 아키텍처를 지정해야 합니다. 유효한 값은 | 문자열 |
controlPlane: hyperthreading: |
컨트롤 플레인 시스템에서 동시 멀티스레딩 또는 중요 동시 멀티스레딩을 비활성화하는 경우 용량 계획에서 시스템 성능이 크게 저하될 수 있는 문제를 고려해야 합니다. |
|
|
|
|
|
|
|
| 프로비저닝하는 컨트롤 플레인 시스템의 수입니다. |
지원되는 유일한 값은 기본값인 |
| Cloud Credential Operator (CCO) 모드입니다. 모드가 지정되지 않은 경우 CCO는 여러 모드가 지원되는 플랫폼에서 Mint 모드가 우선으로 되어 지정된 인증 정보의 기능을 동적으로 확인하려고합니다. 참고 모든 클라우드 공급자에서 모든 CCO 모드가 지원되는 것은 아닙니다. CCO 모드에 대한 자세한 내용은 Cluster Operators 참조 콘텐츠의 Cloud Credential Operator 항목을 참조하십시오. 참고
AWS 계정에 서비스 제어 정책(SCP)이 활성화된 경우 |
|
| 릴리스 이미지 내용의 소스 및 리포지토리입니다. |
개체의 배열입니다. 이 표의 다음 행에 설명된 대로 |
|
| 문자열 |
| 동일한 이미지를 포함할 수도 있는 하나 이상의 리포지토리를 지정합니다. | 문자열 배열 |
| Kubernetes API, OpenShift 경로와 같이 클러스터의 사용자 끝점을 게시하거나 노출하는 방법입니다. |
이 필드를 중요
필드 값을 |
| 클러스터 시스템에 대한 액세스를 인증하는 SSH 키입니다. 참고
설치 디버깅 또는 재해 복구를 수행하려는 프로덕션 OpenShift Container Platform 클러스터의 경우 |
예를 들어 |
- 모든 클라우드 공급자에서 모든 CCO 모드가 지원되는 것은 아닙니다. CCO 모드에 대한 자세한 내용은 인증 및 권한 부여 콘텐츠의 "클라우드 공급자 인증 정보 관리" 항목을 참조하십시오.
5.13.1.4. 추가 VMware vSphere 구성 매개변수
추가 VMware vSphere 구성 매개변수는 다음 표에 설명되어 있습니다.
platform.vsphere
매개변수는 표에 나열된 각 매개변수를 접두사로 지정합니다.
매개변수 | 설명 | 값 |
---|---|---|
platform: vsphere: | 클러스터를 호스팅하는 클라우드 플랫폼의 계정을 설명합니다. 매개 변수를 사용하여 플랫폼을 사용자 지정할 수 있습니다. 머신 풀에서 컴퓨팅 및 컨트롤 플레인 시스템에 대한 추가 구성 설정을 제공하는 경우 매개변수가 필요하지 않습니다. OpenShift Container Platform 클러스터에 대해 하나의 vCenter 서버만 지정할 수 있습니다. | vSphere 구성 오브젝트 사전 |
platform: vsphere: apiVIPs: | 컨트롤 플레인 API 액세스를 위해 구성한 가상 IP(VIP) 주소입니다. 참고 이 매개변수는 외부 로드 밸런서가 구성되지 않은 설치 관리자 프로비저닝 인프라에만 적용됩니다. 이 매개변수는 사용자 프로비저닝 인프라에서 지정할 수 없습니다. | 여러 IP 주소 |
platform: vsphere: diskType: | 선택사항: 디스크 프로비저닝 방법입니다. 이 값은 설정되지 않은 경우 기본적으로 vSphere 기본 스토리지 정책으로 설정됩니다. |
유효한 값은 |
platform: vsphere: failureDomains: region: |
클러스터의 장애 도메인을 여러 개 정의하는 경우 태그를 각 vCenter 데이터 센터에 연결해야 합니다. 리전을 정의하려면 | 문자열 |
platform: vsphere: failureDomains: server: |
클라이언트가 장애 도메인 리소스에 액세스할 수 있도록 VMware vCenter 서버의 정규화된 호스트 이름 또는 IP 주소를 지정합니다. vSphere vCenter | 문자열 |
platform: vsphere: failureDomains: zone: |
클러스터의 장애 도메인을 여러 개 정의하는 경우 태그를 각 vCenter 클러스터에 연결해야 합니다. 영역을 정의하려면 | 문자열 |
platform: vsphere: failureDomains: topology: datacenter: |
OpenShift Container Platform VM(가상 머신)이 작동하는 데이터센터를 나열하고 정의합니다. 데이터센터 목록은 | 문자열 |
platform: vsphere: failureDomains: topology: datastore: |
실패 도메인의 가상 머신 파일을 저장하는 vSphere 데이터 저장소의 경로를 지정합니다. vSphere vCenter 데이터 저장소 위치에 | 문자열 |
platform: vsphere: failureDomains: topology: folder: |
선택 사항: 사용자가 가상 머신을 생성하는 기존 폴더의 절대 경로입니다(예: /< | 문자열 |
platform: vsphere: failureDomains: topology: networks: | vCenter 인스턴스에서 구성한 가상 IP 주소 및 DNS 레코드가 포함된 모든 네트워크를 나열합니다. | 문자열 |
platform: vsphere: failureDomains: topology: resourcePool: |
선택 사항: 설치 프로그램이 가상 머신을 생성하는 기존 리소스 풀의 절대 경로입니다(예: /< | 문자열 |
platform: vsphere: ingressVIPs: | 클러스터 Ingress용으로 구성한 가상 IP(VIP) 주소입니다. 참고 이 매개변수는 외부 로드 밸런서가 구성되지 않은 설치 관리자 프로비저닝 인프라에만 적용됩니다. 이 매개변수는 사용자 프로비저닝 인프라에서 지정할 수 없습니다. | 여러 IP 주소 |
platform: vsphere: vcenters: | 서비스가 vCenter 서버와 통신할 수 있도록 연결 세부 정보를 구성합니다. 현재 단일 vCenter 서버만 지원됩니다. | vCenter 구성 오브젝트의 배열입니다. |
platform: vsphere: vcenters: datacenters: |
OpenShift Container Platform VM(가상 머신)이 작동하는 데이터센터를 나열하고 정의합니다. 데이터 센터 목록은 | 문자열 |
platform: vsphere: vcenters: password: | vSphere 사용자와 연결된 암호입니다. | 문자열 |
platform: vsphere: vcenters: port: | vCenter 서버와 통신하는 데 사용되는 포트 번호입니다. | 정수 |
platform: vsphere: vcenters: server: | vCenter 서버의 정규화된 호스트 이름(FQHN) 또는 IP 주소입니다. | 문자열 |
platform: vsphere: vcenters: user: | vSphere 사용자와 연결된 사용자 이름입니다. | 문자열 |
5.13.1.5. 더 이상 사용되지 않는 VMware vSphere 구성 매개변수
OpenShift Container Platform 4.13에서는 다음 vSphere 구성 매개변수가 더 이상 사용되지 않습니다. 이러한 매개변수를 계속 사용할 수 있지만 설치 프로그램은 install-config.yaml
파일에 이러한 매개변수를 자동으로 지정하지 않습니다.
다음 표에는 더 이상 사용되지 않는 각 vSphere 구성 매개변수가 나열되어 있습니다.
platform.vsphere
매개변수는 표에 나열된 각 매개변수를 접두사로 지정합니다.
매개변수 | 설명 | 값 |
---|---|---|
platform: vsphere: apiVIP: | 컨트롤 플레인 API 액세스를 위해 구성한 가상 IP(VIP) 주소입니다. 참고
OpenShift Container Platform 4.12 이상에서는 |
IP 주소 (예: |
platform: vsphere: cluster: | OpenShift Container Platform 클러스터를 설치할 vCenter 클러스터입니다. | 문자열 |
platform: vsphere: datacenter: | OpenShift Container Platform VM(가상 머신)이 작동하는 데이터 센터를 정의합니다. | 문자열 |
platform: vsphere: defaultDatastore: | 프로비저닝 볼륨에 사용할 기본 데이터 저장소의 이름입니다. | 문자열 |
platform: vsphere: folder: | 선택 사항: 설치 프로그램이 가상 머신을 생성하는 기존 폴더의 절대 경로입니다. 이 값을 지정하지 않으면 설치 프로그램은 데이터 센터 가상 머신 폴더에 인프라 ID로 이름이 지정된 폴더를 생성합니다. |
문자열(예: |
platform: vsphere: ingressVIP: | 클러스터 Ingress용으로 구성한 가상 IP(VIP) 주소입니다. 참고
OpenShift Container Platform 4.12 이상에서는 |
IP 주소 (예: |
platform: vsphere: network: | vCenter 인스턴스에서 구성한 가상 IP 주소 및 DNS 레코드가 포함된 네트워크입니다. | 문자열 |
platform: vsphere: password: | vCenter 사용자 이름의 암호입니다. | 문자열 |
platform: vsphere: resourcePool: |
선택 사항: 설치 프로그램이 가상 머신을 생성하는 기존 리소스 풀의 절대 경로입니다. 값을 지정하지 않으면 설치 프로그램은 /< |
문자열(예: |
platform: vsphere: username: | vCenter 인스턴스에 연결하는 데 사용할 사용자 이름입니다. 이 사용자에게는 최소한 vSphere에서 정적 또는 동적 영구 볼륨 프로비저닝 에 필요한 역할과 권한이 있어야 합니다. | 문자열 |
platform: vsphere: vCenter: | vCenter 서버의 정규화된 호스트 이름 또는 IP 주소입니다. | 문자열 |
5.13.1.6. 선택적 VMware vSphere 시스템 풀 구성 매개변수
선택적 VMware vSphere 시스템 풀 구성 매개변수는 다음 표에 설명되어 있습니다.
platform.vsphere
매개변수는 표에 나열된 각 매개변수를 접두사로 지정합니다.
매개변수 | 설명 | 값 |
---|---|---|
| 설치 프로그램이 RHCOS 이미지를 다운로드하는 위치입니다. 네트워크가 제한된 환경에서 설치를 수행하려면이 매개 변수를 설정해야 합니다. |
HTTP 또는 HTTPS URL (선택 옵션으로 SHA-256 형식의 체크섬을 사용) 예: |
| 디스크 크기(GB)입니다. | 정수 |
|
가상 머신을 할당할 총 가상 프로세서 코어 수입니다. | 정수 |
|
가상 머신의 소켓당 코어 수입니다. 가상 머신의 가상 소켓 수는 | 정수 |
| 가상 머신의 메모리 크기(MB)입니다. | 정수 |
5.13.2. 설치 관리자 프로비저닝 VMware vSphere 클러스터의 샘플 install-config.yaml 파일
install-config.yaml
파일을 사용자 지정하여 OpenShift Container Platform 클러스터 플랫폼에 대한 자세한 정보를 지정하거나 필수 매개변수 값을 수정할 수 있습니다.
apiVersion: v1 baseDomain: example.com 1 compute: 2 - architecture: amd64 name: <worker_node> platform: {} replicas: 3 controlPlane: 3 architecture: amd64 name: <parent_node> platform: {} replicas: 3 metadata: creationTimestamp: null name: test 4 platform: vsphere: 5 apiVIPs: - 10.0.0.1 failureDomains: 6 - name: <failure_domain_name> region: <default_region_name> server: <fully_qualified_domain_name> topology: computeCluster: "/<datacenter>/host/<cluster>" datacenter: <datacenter> datastore: "/<datacenter>/datastore/<datastore>" 7 networks: - <VM_Network_name> resourcePool: "/<datacenter>/host/<cluster>/Resources/<resourcePool>" 8 folder: "/<datacenter_name>/vm/<folder_name>/<subfolder_name>" zone: <default_zone_name> ingressVIPs: - 10.0.0.2 vcenters: - datacenters: - <datacenter> password: <password> port: 443 server: <fully_qualified_domain_name> user: administrator@vsphere.local diskType: thin 9 clusterOSImage: http://mirror.example.com/images/rhcos-47.83.202103221318-0-vmware.x86_64.ova 10 fips: false pullSecret: '{"auths":{"<local_registry>": {"auth": "<credentials>","email": "you@example.com"}}}' 11 sshKey: 'ssh-ed25519 AAAA...' additionalTrustBundle: | 12 -----BEGIN CERTIFICATE----- ZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZ -----END CERTIFICATE----- imageContentSources: 13 - mirrors: - <mirror_host_name>:<mirror_port>/<repo_name>/release source: <source_image_1> - mirrors: - <mirror_host_name>:<mirror_port>/<repo_name>/release-images source: <source_image_2>
- 1
- 클러스터의 기본 도메인입니다. 모든 DNS 레코드는 이 기본 도메인의 하위 도메인이어야 하며 클러스터 이름을 포함해야 합니다.
- 2 3
controlPlane
섹션은 단일 매핑이지만compute
섹션은 일련의 매핑입니다. 서로 다른 데이터 구조의 요구사항을 충족하도록compute
섹션의 첫 번째 줄은 하이픈(-
)으로 시작해야 하며controlPlane
섹션의 첫 번째 줄은 하이픈으로 시작할 수 없습니다. 하나의 컨트롤 플레인 풀만 사용됩니다.- 4
- DNS 레코드에 지정한 클러스터 이름입니다.
- 5
- 선택 사항: 컴퓨팅 및 컨트롤 플레인 시스템의 머신 풀 매개변수에 대한 추가 구성을 제공합니다.
- 6
- 지역과 영역 간의 관계를 설정합니다.
datastore
오브젝트와 같은 vCenter 오브젝트를 사용하여 실패 도메인을 정의합니다. 장애 도메인은 OpenShift Container Platform 클러스터 노드의 vCenter 위치를 정의합니다. - 7
- 가상 머신 파일, 템플릿 및 ISO 이미지를 보유하는 vSphere 데이터 저장소의 경로입니다.중요
데이터 저장소 클러스터에 존재하는 모든 데이터 저장소의 경로를 지정할 수 있습니다. 기본적으로 데이터 저장소 클러스터에 대해 스토리지 vMotion이 자동으로 활성화됩니다. Red Hat은 스토리지 vMotion을 지원하지 않으므로 OpenShift Container Platform 클러스터의 데이터 손실 문제를 방지하려면 스토리지 vMotion을 비활성화해야 합니다.
여러 데이터 저장소에서 VM을 지정해야 하는 경우
datastore
오브젝트를 사용하여 클러스터의install-config.yaml
구성 파일에 실패 도메인을 지정합니다. 자세한 내용은 "VMware vSphere 리전 및 영역 활성화"를 참조하십시오. - 8
- 선택 사항: 머신 생성을 위한 기존 리소스 풀을 제공합니다. 값을 지정하지 않으면 설치 프로그램은 vSphere 클러스터의 루트 리소스 풀을 사용합니다.
- 9
- vSphere 디스크 프로비저닝 방법입니다.
- 10
- bastion 서버에서 액세스할 수 있는 RHCOS(Red Hat Enterprise Linux CoreOS) 이미지의 위치입니다.
- 11
<local_registry>
는 미러 레지스트리가 해당 내용을 제공하는 데 사용하는 레지스트리 도메인 이름과 포트(선택사항)를 지정합니다. 예:registry.example.com
또는registry.example.com:5000
.<credentials>
는 미러 레지스트리의 base64 인코딩 사용자 이름과 암호를 지정합니다.- 12
- 미러 레지스트리에 사용한 인증서 파일의 내용을 제공하십시오.
- 13
- 명령 출력에서
imageContentSources
섹션을 제공하여 리포지토리를 미러링하십시오.
OpenShift Container Platform 4.12 이상에서는 apiVIP
및 ingressVIP
구성 설정이 더 이상 사용되지 않습니다. 대신 목록 형식을 사용하여 apiVIPs
및 ingressVIPs
구성 설정에 값을 입력합니다.
5.13.3. 설치 중 클러스터 단위 프록시 구성
프로덕션 환경에서는 인터넷에 대한 직접 액세스를 거부하고 대신 HTTP 또는 HTTPS 프록시를 사용할 수 있습니다. install-config.yaml
파일에서 프록시 설정을 구성하여 프록시가 사용되도록 새 OpenShift Container Platform 클러스터를 구성할 수 있습니다.
사전 요구 사항
-
기존
install-config.yaml
파일이 있습니다. 클러스터에서 액세스해야 하는 사이트를 검토하고 프록시를 바이패스해야 하는지 확인했습니다. 기본적으로 호스팅 클라우드 공급자 API에 대한 호출을 포함하여 모든 클러스터 발신(Egress) 트래픽이 프록시됩니다. 필요한 경우 프록시를 바이패스하기 위해
Proxy
오브젝트의spec.noProxy
필드에 사이트를 추가했습니다.참고Proxy
오브젝트의status.noProxy
필드는 설치 구성에 있는networking.machineNetwork[].cidr
,networking.clusterNetwork[].cidr
,networking.serviceNetwork[]
필드의 값으로 채워집니다.Amazon Web Services (AWS), Google Cloud Platform (GCP), Microsoft Azure 및 Red Hat OpenStack Platform (RHOSP)에 설치하는 경우
Proxy
오브젝트status.noProxy
필드도 인스턴스 메타데이터 끝점(169.254.169.254
)로 채워집니다.
프로세스
install-config.yaml
파일을 편집하고 프록시 설정을 추가합니다. 예를 들면 다음과 같습니다.apiVersion: v1 baseDomain: my.domain.com proxy: httpProxy: http://<username>:<pswd>@<ip>:<port> 1 httpsProxy: https://<username>:<pswd>@<ip>:<port> 2 noProxy: example.com 3 additionalTrustBundle: | 4 -----BEGIN CERTIFICATE----- <MY_TRUSTED_CA_CERT> -----END CERTIFICATE----- additionalTrustBundlePolicy: <policy_to_add_additionalTrustBundle> 5
- 1
- 클러스터 외부에서 HTTP 연결을 구축하는 데 사용할 프록시 URL입니다. URL 스키마는
http
여야 합니다. - 2
- 클러스터 외부에서 HTTPS 연결을 구축하는 데 사용할 프록시 URL입니다.
- 3
- 대상 도메인 이름, IP 주소 또는 프록시에서 제외할 기타 네트워크 CIDR로 이루어진 쉼표로 구분된 목록입니다. 하위 도메인과 일치하려면 도메인 앞에
.
을 입력합니다. 예를 들어,.y.com
은x.y.com
과 일치하지만y.com
은 일치하지 않습니다.*
를 사용하여 모든 대상에 대해 프록시를 바이패스합니다. vCenter의 IP 주소와 해당 시스템에 사용하는 IP 범위를 포함해야 합니다. - 4
- 이 값을 제공하면 설치 프로그램에서 HTTPS 연결을 프록시하는 데 필요한 추가 CA 인증서가 하나 이상 포함된
openshift-config
네임스페이스에user-ca-bundle
이라는 이름으로 구성 맵을 생성합니다. 그러면 CNO(Cluster Network Operator)에서 이러한 콘텐츠를 RHCOS(Red Hat Enterprise Linux CoreOS) 신뢰 번들과 병합하는trusted-ca-bundle
구성 맵을 생성합니다. 이 구성 맵은Proxy
오브젝트의trustedCA
필드에서 참조됩니다. 프록시의 ID 인증서를 RHCOS 트러스트 번들에 있는 기관에서 서명하지 않은 경우additionalTrustBundle
필드가 있어야 합니다. - 5
- 선택 사항:
trustedCA
필드에서user-ca-bundle
구성 맵을 참조할프록시
오브젝트의 구성을 결정하는 정책입니다. 허용되는 값은Proxyonly
및Always
입니다.http/https
프록시가 구성된 경우에만user-ca-bundle
구성 맵을 참조하려면Proxyonly
를 사용합니다.Always
를 사용하여user-ca-bundle
구성 맵을 항상 참조합니다. 기본값은Proxyonly
입니다.
참고설치 프로그램에서 프록시
adinessEndpoints
필드를 지원하지 않습니다.참고설치 프로그램이 시간 초과되면 설치 프로그램의
wait-for
명령을 사용하여 배포를 다시 시작한 다음 완료합니다. 예를 들면 다음과 같습니다.$ ./openshift-install wait-for install-complete --log-level debug
- 파일을 저장해 놓고 OpenShift Container Platform을 설치할 때 참조하십시오.
제공되는 install-config.yaml
파일의 프록시 설정을 사용하는 cluster
라는 이름의 클러스터 전체 프록시가 설치 프로그램에 의해 생성됩니다. 프록시 설정을 제공하지 않아도 cluster
Proxy
오브젝트는 계속 생성되지만 spec
은 nil이 됩니다.
cluster
라는 Proxy
오브젝트만 지원되며 추가 프록시는 생성할 수 없습니다.
5.13.4. VMware vCenter의 지역 및 영역 구성
단일 VMware vCenter에서 실행되는 여러 vSphere 데이터 센터에 OpenShift Container Platform 클러스터를 배포할 수 있도록 기본 설치 구성 파일을 수정할 수 있습니다.
이전 릴리스의 기본 install-config.yaml
파일 구성은 더 이상 사용되지 않습니다. 더 이상 사용되지 않는 기본 구성을 계속 사용할 수 있지만 openshift-installer
는 구성 파일에서 더 이상 사용되지 않는 필드 사용을 나타내는 경고 메시지를 표시합니다.
이 예제에서는 govc
명령을 사용합니다. govc
명령은 VMware에서 사용할 수 있는 오픈 소스 명령이며 Red Hat에서 사용할 수 없습니다. Red Hat 지원 팀은 govc
명령을 유지 관리하지 않습니다. govc
다운로드 및 설치 지침은 VMware 설명서 웹 사이트에서 확인할 수 있습니다.
사전 요구 사항
기존
install-config.yaml
설치 구성 파일이 있습니다.중요VMware vCenter 서버의 데이터 센터 오브젝트를 프로비저닝할 수 있도록 OpenShift Container Platform 클러스터에 대해 하나 이상의 실패 도메인을 지정해야 합니다. 다른 데이터 센터, 클러스터, 데이터 저장소 및 기타 구성 요소에서 가상 머신 노드를 프로비저닝해야 하는 경우 여러 장애 도메인을 지정하는 것이 좋습니다. 리전 및 영역을 활성화하려면 OpenShift Container Platform 클러스터에 대해 여러 장애 도메인을 정의해야 합니다.
프로세스
다음
govc
명령줄 툴 명령을 입력하여openshift-region
및openshift-zone
vCenter 태그 범주를 생성합니다.중요openshift-region
및openshift-zone
vCenter 태그 카테고리에 다른 이름을 지정하면 OpenShift Container Platform 클러스터 설치가 실패합니다.$ govc tags.category.create -d "OpenShift region" openshift-region
$ govc tags.category.create -d "OpenShift zone" openshift-zone
클러스터를 배포하려는 각 리전 vSphere 데이터 센터의 리전 태그를 생성하려면 터미널에 다음 명령을 입력합니다.
$ govc tags.create -c <region_tag_category> <region_tag>
클러스터를 배포하려는 각 vSphere 클러스터에 대한 영역 태그를 생성하려면 다음 명령을 입력합니다.
$ govc tags.create -c <zone_tag_category> <zone_tag>
다음 명령을 입력하여 각 vCenter 데이터 센터 오브젝트에 리전 태그를 연결합니다.
$ govc tags.attach -c <region_tag_category> <region_tag_1> /<datacenter_1>
다음 명령을 입력하여 각 vCenter 데이터 센터 오브젝트에 영역 태그를 연결합니다.
$ govc tags.attach -c <zone_tag_category> <zone_tag_1> /<datacenter_1>/host/vcs-mdcnc-workload-1
- 설치 프로그램이 포함된 디렉터리로 변경하고 선택한 설치 요구 사항에 따라 클러스터 배포를 초기화합니다.
vSphere 센터에 정의된 여러 데이터 센터가 있는 샘플 install-config.yaml
파일
--- compute: --- vsphere: zones: - "<machine_pool_zone_1>" - "<machine_pool_zone_2>" --- controlPlane: --- vsphere: zones: - "<machine_pool_zone_1>" - "<machine_pool_zone_2>" --- platform: vsphere: vcenters: --- datacenters: - <datacenter1_name> - <datacenter2_name> failureDomains: - name: <machine_pool_zone_1> region: <region_tag_1> zone: <zone_tag_1> server: <fully_qualified_domain_name> topology: datacenter: <datacenter1> computeCluster: "/<datacenter1>/host/<cluster1>" networks: - <VM_Network1_name> datastore: "/<datacenter1>/datastore/<datastore1>" resourcePool: "/<datacenter1>/host/<cluster1>/Resources/<resourcePool1>" folder: "/<datacenter1>/vm/<folder1>" - name: <machine_pool_zone_2> region: <region_tag_2> zone: <zone_tag_2> server: <fully_qualified_domain_name> topology: datacenter: <datacenter2> computeCluster: "/<datacenter2>/host/<cluster2>" networks: - <VM_Network2_name> datastore: "/<datacenter2>/datastore/<datastore2>" resourcePool: "/<datacenter2>/host/<cluster2>/Resources/<resourcePool2>" folder: "/<datacenter2>/vm/<folder2>" ---