그룹 클러스터 API (인증서 기반) (사용 중단)

Tier: Free, Premium, Ultimate Offering: GitLab.com, Self-managed, GitLab Dedicated
caution
이 기능은 사용 중단되었습니다 GitLab 14.5에서.

프로젝트 수준
인스턴스 수준 Kubernetes 클러스터와 유사하게,
그룹 수준 Kubernetes 클러스터를 사용하면 Kubernetes 클러스터를 그룹에 연결하여
여러 프로젝트에서 동일한 클러스터를 사용할 수 있습니다.

사용자는 이러한 엔드포인트를 사용하기 위해 그룹에 대해 최소한 Maintainer 역할이 필요합니다.

그룹 클러스터 목록

그룹 클러스터 목록을 반환합니다.

GET /groups/:id/clusters  

매개변수:

속성 유형 필수 설명
id 정수/문자열 그룹의 ID 또는 URL 인코딩된 경로

예시 요청:

curl --header "Private-Token: <your_access_token>" "https://gitlab.example.com/api/v4/groups/26/clusters"  

예시 응답:

[  
  {  
    "id":18,  
    "name":"cluster-1",  
    "domain":"example.com",  
    "created_at":"2019-01-02T20:18:12.563Z",  
    "managed": true,  
    "enabled": true,  
    "provider_type":"user",  
    "platform_type":"kubernetes",  
    "environment_scope":"*",  
    "cluster_type":"group_type",  
    "user":  
    {  
      "id":1,  
      "name":"Administrator",  
      "username":"root",  
      "state":"active",  
      "avatar_url":"https://www.gravatar.com/avatar/4249f4df72b..",  
      "web_url":"https://gitlab.example.com/root"  
    },  
    "platform_kubernetes":  
    {  
      "api_url":"https://104.197.68.152",  
      "authorization_type":"rbac",  
      "ca_cert":"-----BEGIN CERTIFICATE-----\r\nhFiK1L61owwDQYJKoZIhvcNAQELBQAw\r\nLzEtMCsGA1UEAxMkZDA1YzQ1YjctNzdiMS00NDY0LThjNmEtMTQ0ZDJkZjM4ZDBj\r\nMB4XDTE4MTIyNzIwMDM1MVoXDTIzMTIyNjIxMDM1MVowLzEtMCsGA1UEAxMkZDA1\r\nYzQ1YjctNzdiMS00NDY0LThjNmEtMTQ0ZDJkZjM.......-----END CERTIFICATE-----"  
    },  
    "management_project":  
    {  
      "id":2,  
      "description":null,  
      "name":"project2",  
      "name_with_namespace":"John Doe8 / project2",  
      "path":"project2",  
      "path_with_namespace":"namespace2/project2",  
      "created_at":"2019-10-11T02:55:54.138Z"  
    }  
  },  
  {  
    "id":19,  
    "name":"cluster-2",  
    ...  
  }  
]  

단일 그룹 클러스터 가져오기

단일 그룹 클러스터를 가져옵니다.

GET /groups/:id/clusters/:cluster_id

Parameters:

속성 유형 필수 설명
id integer/string 그룹의 ID 또는 URL-인코딩된 경로
cluster_id integer 클러스터의 ID

예시 요청:

curl --header "Private-Token: <your_access_token>" "https://gitlab.example.com/api/v4/groups/26/clusters/18"

예시 응답:

{
  "id":18,
  "name":"cluster-1",
  "domain":"example.com",
  "created_at":"2019-01-02T20:18:12.563Z",
  "managed": true,
  "enabled": true,
  "provider_type":"user",
  "platform_type":"kubernetes",
  "environment_scope":"*",
  "cluster_type":"group_type",
  "user":
  {
    "id":1,
    "name":"Administrator",
    "username":"root",
    "state":"active",
    "avatar_url":"https://www.gravatar.com/avatar/4249f4df72b..",
    "web_url":"https://gitlab.example.com/root"
  },
  "platform_kubernetes":
  {
    "api_url":"https://104.197.68.152",
    "authorization_type":"rbac",
    "ca_cert":"-----BEGIN CERTIFICATE-----\r\nhFiK1L61owwDQYJKoZIhvcNAQELBQAw\r\nLzEtMCsGA1UEAxMkZDA1YzQ1YjctNzdiMS00NDY0LThjNmEtMTQ0ZDJkZjM4ZDBj\r\nMB4XDTE4MTIyNzIwMDM1MVoXDTIzMTIyNjIxMDM1MVowLzEtMCsGA1UEAxMkZDA1\r\nYzQ1YjctNzdiMS00NDY0LThjNmEtMTQ0ZDJkZjM.......-----END CERTIFICATE-----"
  },
  "management_project":
  {
    "id":2,
    "description":null,
    "name":"project2",
    "name_with_namespace":"John Doe8 / project2",
    "path":"project2",
    "path_with_namespace":"namespace2/project2",
    "created_at":"2019-10-11T02:55:54.138Z"
  },
  "group":
  {
    "id":26,
    "name":"group-with-clusters-api",
    "web_url":"https://gitlab.example.com/group-with-clusters-api"
  }
}

기존 클러스터를 그룹에 추가

기존 Kubernetes 클러스터를 그룹에 추가합니다.

POST /groups/:id/clusters/user

Parameters:

속성 유형 필수 설명
id integer/string 그룹의 ID 또는 URL-인코딩된 경로
name string 클러스터의 이름
domain string 아니요 클러스터의 기본 도메인
management_project_id integer 아니요 클러스터의 관리 프로젝트 ID
enabled boolean 아니요 클러스터가 활성화되어 있는지 여부를 결정하며, 기본값은 true입니다.
managed boolean 아니요 GitLab가 이 클러스터의 네임스페이스와 서비스 계정을 관리하는지 여부를 결정합니다. 기본값은 true입니다.
platform_kubernetes_attributes[api_url] string Kubernetes API에 액세스할 URL
platform_kubernetes_attributes[token] string Kubernetes에 대한 인증을 위한 토큰
platform_kubernetes_attributes[ca_cert] string 아니요 TLS 인증서. API가 자체 서명된 TLS 인증서를 사용하는 경우 필수입니다.
platform_kubernetes_attributes[authorization_type] string 아니요 클러스터 인증 유형: rbac, abac 또는 unknown_authorization. 기본값은 rbac입니다.
environment_scope string 아니요 클러스터에 연결된 환경. 기본값은 *입니다. Premium 및 Ultimate 전용입니다.

예시 요청:

curl --header "Private-Token: <your_access_token>" "https://gitlab.example.com/api/v4/groups/26/clusters/user" \
-H "Accept: application/json" \
-H "Content-Type:application/json" \
--request POST --data '{"name":"cluster-5", "platform_kubernetes_attributes":{"api_url":"https://35.111.51.20","token":"12345","ca_cert":"-----BEGIN CERTIFICATE-----\r\nhFiK1L61owwDQYJKoZIhvcNAQELBQAw\r\nLzEtMCsGA1UEAxMkZDA1YzQ1YjctNzdiMS00NDY0LThjNmEtMTQ0ZDJkZjM4ZDBj\r\nMB4XDTE4MTIyNzIwMDM1MVoXDTIzMTIyNjIxMDM1MVowLzEtMCsGA1UEAxMkZDA1\r\nYzQ1YjctNzdiMS00NDY0LThjNmEtMTQ0ZDJkZjM.......-----END CERTIFICATE-----"}}'

예시 응답:

{
  "id":24,
  "name":"cluster-5",
  "created_at":"2019-01-03T21:53:40.610Z",
  "managed": true,
  "enabled": true,
  "provider_type":"user",
  "platform_type":"kubernetes",
  "environment_scope":"*",
  "cluster_type":"group_type",
  "user":
  {
    "id":1,
    "name":"Administrator",
    "username":"root",
    "state":"active",
    "avatar_url":"https://www.gravatar.com/avatar/4249f4df72b..",
    "web_url":"https://gitlab.example.com/root"
  },
  "platform_kubernetes":
  {
    "api_url":"https://35.111.51.20",
    "authorization_type":"rbac",
    "ca_cert":"-----BEGIN CERTIFICATE-----\r\nhFiK1L61owwDQYJKoZIhvcNAQELBQAw\r\nLzEtMCsGA1UEAxMkZDA1YzQ1YjctNzdiMS00NDY0LThjNmEtMTQ0ZDJkZjM4ZDBj\r\nMB4XDTE4MTIyNzIwMDM1MVoXDTIzMTIyNjIxMDM1MVowLzEtMCsGA1UEAxMkZDA1\r\nYzQ1YjctNzdiMS00NDY0LThjNmEtMTQ0ZDJkZjM.......-----END CERTIFICATE-----"
  },
  "management_project":null,
  "group":
  {
    "id":26,
    "name":"group-with-clusters-api",
    "web_url":"https://gitlab.example.com/root/group-with-clusters-api"
  }
}

그룹 클러스터 편집

기존 그룹 클러스터를 업데이트합니다.

PUT /groups/:id/clusters/:cluster_id

매개변수:

속성 유형 필수 설명
id 정수/문자열 그룹의 ID 또는 URL 인코딩된 경로
cluster_id 정수 클러스터의 ID
name 문자열 아니오 클러스터의 이름
domain 문자열 아니오 클러스터의 기본 도메인
management_project_id 정수 아니오 클러스터의 관리 프로젝트 ID
enabled 부울 아니오 클러스터가 활성화되어 있는지 여부
managed 부울 아니오 GitLab이 이 클러스터의 네임스페이스 및 서비스 계정을 관리하는지 여부
platform_kubernetes_attributes[api_url] 문자열 아니오 Kubernetes API에 접근하는 URL
platform_kubernetes_attributes[token] 문자열 아니오 Kubernetes에 대한 인증 토큰
platform_kubernetes_attributes[ca_cert] 문자열 아니오 TLS 인증서. API가 자체 서명된 TLS 인증서를 사용하는 경우 필요합니다.
environment_scope 문자열 아니오 클러스터와 연결된 환경. Premium 및 Ultimate 전용.

참고: name, api_url, ca_cert, token은 클러스터가 “기존 Kubernetes 클러스터 추가” 옵션을 통해 추가된 경우에만 업데이트할 수 있습니다. 또는 “클러스터를 그룹에 추가” 엔드포인트를 통해서도 가능합니다.

예시 요청:

curl --header "Private-Token: <your_access_token>" "https://gitlab.example.com/api/v4/groups/26/clusters/24" \
-H "Content-Type:application/json" \
--request PUT --data '{"name":"new-cluster-name","domain":"new-domain.com","platform_kubernetes_attributes":{"api_url":"https://10.10.101.1:6433"}}'

예시 응답:

{
  "id":24,
  "name":"new-cluster-name",
  "domain":"new-domain.com",
  "created_at":"2019-01-03T21:53:40.610Z",
  "managed": true,
  "enabled": true,
  "provider_type":"user",
  "platform_type":"kubernetes",
  "environment_scope":"*",
  "cluster_type":"group_type",
  "user":
  {
    "id":1,
    "name":"Administrator",
    "username":"root",
    "state":"active",
    "avatar_url":"https://www.gravatar.com/avatar/4249f4df72b..",
    "web_url":"https://gitlab.example.com/root"
  },
  "platform_kubernetes":
  {
    "api_url":"https://new-api-url.com",
    "authorization_type":"rbac",
    "ca_cert":null
  },
  "management_project":
  {
    "id":2,
    "description":null,
    "name":"project2",
    "name_with_namespace":"John Doe8 / project2",
    "path":"project2",
    "path_with_namespace":"namespace2/project2",
    "created_at":"2019-10-11T02:55:54.138Z"
  },
  "group":
  {
    "id":26,
    "name":"group-with-clusters-api",
    "web_url":"https://gitlab.example.com/group-with-clusters-api"
  }
}

그룹 클러스터 삭제

기존 그룹 클러스터를 삭제합니다. 연결된 Kubernetes 클러스터 내의 기존 리소스는 제거하지 않습니다.

DELETE /groups/:id/clusters/:cluster_id

매개변수:

속성 유형 필수 설명
id 정수/문자열 그룹의 ID 또는 URL 인코딩 경로
cluster_id 정수 클러스터의 ID

예제 요청:

curl --request DELETE --header "Private-Token: <your_access_token>" "https://gitlab.example.com/api/v4/groups/26/clusters/23"