- 새 Geo 노드 생성
- 모든 Geo 노드에 대한 구성 내용 검색
- 특정 Geo 노드에 대한 구성 검색
- Geo 노드 편집
- Geo 노드 삭제
- Geo 노드 복원
- 특정 Geo 노드에 대한 상태 검색
Geo Nodes API (deprecated)
Tier: 프리미엄, 얼티메이트
Offering: Self-managed
경고: Geo Nodes API는 GitLab 16.0에서 deprecated되었으며 API v5에서 제거될 예정입니다. 대신 Geo Sites API를 사용하십시오. 이 변경은 파괴적인 변화입니다.
Geo 노드 엔드포인트와 상호작용하려면 관리자로 인증해야 합니다.
새 Geo 노드 생성
새 Geo 노드를 생성합니다.
POST /geo_nodes
curl --header "PRIVATE-TOKEN: <your_access_token>" "https://primary.example.com/api/v4/geo_nodes" \
--request POST \
-d "name=himynameissomething" \
-d "url=https://another-node.example.com/"
속성 | 유형 | 필수여부 | 설명 |
---|---|---|---|
primary
| boolean | no | 이 노드를 프라이머리로 설정할지 여부를 지정합니다. 기본값은 false입니다. |
enabled
| boolean | no | Geo 노드가 활성화되어 있는지를 나타내는 플래그입니다. 기본값은 true입니다. |
name
| string | yes | Geo 노드의 고유 식별자입니다. gitlab.rb 에서 geo_node_name 으로 설정되어 있으면 해당 값과 일치해야 하며, 그렇지 않으면 external_url 과 일치해야 합니다.
|
url
| string | yes | Geo 노드의 사용자 지향 URL입니다. |
internal_url
| string | no | 보조 노드가 접촉하는 기본 노드에서 정의된 URL입니다. 설정되어 있지 않으면 url 을 반환합니다.
|
files_max_capacity
| integer | no | 이 보조 노드의 LFS/첨부 파일 백필의 최대 동시성을 제어합니다. 기본값은 10입니다. |
repos_max_capacity
| integer | no | 이 보조 노드의 저장소 백필의 최대 동시성을 제어합니다. 기본값은 25입니다. |
verification_max_capacity
| integer | no | 해당 노드의 저장소 검증의 최대 동시성을 제어합니다. 기본값은 100입니다. |
container_repositories_max_capacity
| integer | no | 해당 노드의 컨테이너 저장소 동기화의 최대 동시성을 제어합니다. 기본값은 10입니다. |
sync_object_storage
| boolean | no | 보조 Geo 노드가 Object Storage에서 블롭을 복제해야 하는지 여부를 나타내는 플래그입니다. 기본값은 false입니다. |
selective_sync_type
| string | no | 특정 그룹이나 샤드에 대해서만 동기화를 제한합니다. 유효한 값: "namespaces" , "shards" , 또는 null
|
selective_sync_shards
| array | no |
selective_sync_type 이 shards 인 경우 동기화되는 프로젝트의 저장소 저장소입니다.
|
selective_sync_namespace_ids
| array | no |
selective_sync_type 이 namespaces 인 경우 동기화해야 하는 그룹의 ID입니다.
|
minimum_reverification_interval
| integer | no | 저장소 검증이 유효한 간격(일 단위)입니다. 만료되면 다시 확인됩니다. 보조 노드에서 설정된 값은 영향을 미치지 않습니다. |
응답 예시:
{
"id": 3,
"name": "Test Node 1",
"url": "https://secondary.example.com/",
"internal_url": "https://secondary.example.com/",
"primary": false,
"enabled": true,
"current": false,
"files_max_capacity": 10,
"repos_max_capacity": 25,
"verification_max_capacity": 100,
"selective_sync_type": "namespaces",
"selective_sync_shards": [],
"selective_sync_namespace_ids": [1, 25],
"minimum_reverification_interval": 7,
"container_repositories_max_capacity": 10,
"sync_object_storage": false,
"clone_protocol": "http",
"web_edit_url": "https://primary.example.com/admin/geo/sites/3/edit",
"web_geo_replication_details_url": "https://secondary.example.com/admin/geo/sites/3/replication/lfs_objects",
"_links": {
"self": "https://primary.example.com/api/v4/geo_nodes/3",
"status": "https://primary.example.com/api/v4/geo_nodes/3/status",
"repair": "https://primary.example.com/api/v4/geo_nodes/3/repair"
}
}
모든 Geo 노드에 대한 구성 내용 검색
GET /geo_nodes
curl --header "PRIVATE-TOKEN: <your_access_token>" "https://primary.example.com/api/v4/geo_nodes"
응답 예시:
[
{
"id": 1,
"name": "us-node",
"url": "https://primary.example.com/",
"internal_url": "https://internal.example.com/",
"primary": true,
"enabled": true,
"current": true,
"files_max_capacity": 10,
"repos_max_capacity": 25,
"container_repositories_max_capacity": 10,
"verification_max_capacity": 100,
"selective_sync_type": "namespaces",
"selective_sync_shards": [],
"selective_sync_namespace_ids": [1, 25],
"minimum_reverification_interval": 7,
"clone_protocol": "http",
"web_edit_url": "https://primary.example.com/admin/geo/sites/1/edit",
"_links": {
"self": "https://primary.example.com/api/v4/geo_nodes/1",
"status":"https://primary.example.com/api/v4/geo_nodes/1/status",
"repair":"https://primary.example.com/api/v4/geo_nodes/1/repair"
}
},
{
"id": 2,
"name": "cn-node",
"url": "https://secondary.example.com/",
"internal_url": "https://secondary.example.com/",
"primary": false,
"enabled": true,
"current": false,
"files_max_capacity": 10,
"repos_max_capacity": 25,
"container_repositories_max_capacity": 10,
"verification_max_capacity": 100,
"selective_sync_type": "namespaces",
"selective_sync_shards": [],
"selective_sync_namespace_ids": [1, 25],
"minimum_reverification_interval": 7,
"sync_object_storage": true,
"clone_protocol": "http",
"web_edit_url": "https://primary.example.com/admin/geo/sites/2/edit",
"web_geo_replication_details_url": "https://secondary.example.com/admin/geo/sites/2/replication/lfs_objects",
"_links": {
"self":"https://primary.example.com/api/v4/geo_nodes/2",
"status":"https://primary.example.com/api/v4/geo_nodes/2/status",
"repair":"https://primary.example.com/api/v4/geo_nodes/2/repair"
}
}
]
특정 Geo 노드에 대한 구성 검색
GET /geo_nodes/:id
curl --header "PRIVATE-TOKEN: <your_access_token>" "https://primary.example.com/api/v4/geo_nodes/1"
예시 응답:
{
"id": 1,
"name": "us-node",
"url": "https://primary.example.com/",
"internal_url": "https://primary.example.com/",
"primary": true,
"enabled": true,
"current": true,
"files_max_capacity": 10,
"repos_max_capacity": 25,
"container_repositories_max_capacity": 10,
"verification_max_capacity": 100,
"selective_sync_type": "namespaces",
"selective_sync_shards": [],
"selective_sync_namespace_ids": [1, 25],
"minimum_reverification_interval": 7,
"clone_protocol": "http",
"web_edit_url": "https://primary.example.com/admin/geo/sites/1/edit",
"_links": {
"self": "https://primary.example.com/api/v4/geo_nodes/1",
"status":"https://primary.example.com/api/v4/geo_nodes/1/status",
"repair":"https://primary.example.com/api/v4/geo_nodes/1/repair"
}
}
Geo 노드 편집
기존 Geo 노드의 설정을 업데이트합니다.
PUT /geo_nodes/:id
속성 | 유형 | 필수 | 설명 |
---|---|---|---|
id
| 정수 | 예 | Geo 노드의 ID입니다. |
enabled
| 부울 | 아니요 | Geo 노드가 활성화되었는지 여부를 나타내는 플래그입니다. |
name
| 문자열 | 아니요 | Geo 노드의 고유 식별자입니다. gitlab.rb 에서 설정된 경우 geo_node_name 과 일치해야 하며, 그렇지 않은 경우 external_url 과 일치해야 합니다.
|
url
| 문자열 | 아니요 | Geo 노드의 사용자용 URL입니다. |
internal_url
| 문자열 | 아니요 | 보조 노드가 연락해야 하는 주 노드에서 정의된 URL입니다. 설정되지 않으면 url 을 반환합니다.
|
files_max_capacity
| 정수 | 아니요 | 이 보조 노드의 LFS/첨부 파일 백필 작업의 최대 동시성을 제어합니다. |
repos_max_capacity
| 정수 | 아니요 | 이 보조 노드의 저장소 백필 작업의 최대 동시성을 제어합니다. |
verification_max_capacity
| 정수 | 아니요 | 이 노드의 검증 작업의 최대 동시성을 제어합니다. |
container_repositories_max_capacity
| 정수 | 아니요 | 이 노드의 컨테이너 저장소 동기화 작업의 최대 동시성을 제어합니다. |
sync_object_storage
| 부울 | 아니요 | 보조 Geo 노드가 객체 저장소에서 블롭을 복제해야 하는지 여부를 나타내는 플래그입니다. |
selective_sync_type
| 문자열 | 아니요 | 특정 그룹이나 샤드에 동기화를 제한합니다. 유효한 값: "namespaces" , "shards" , 또는 null .
|
selective_sync_shards
| 배열 | 아니요 |
selective_sync_type == shards 인 경우 동기화되는 프로젝트의 저장소 저장소입니다.
|
selective_sync_namespace_ids
| 배열 | 아니요 |
selective_sync_type == namespaces 인 경우 동기화해야 하는 그룹의 ID입니다.
|
minimum_reverification_interval
| 정수 | 아니요 | 저장소 검증이 유효한 간격(일)입니다. 만료되면 다시 확인됩니다. 이 값을 보조 노드에서 설정하면 효과가 없습니다. |
예시 응답:
{
"id": 1,
"name": "cn-node",
"url": "https://secondary.example.com/",
"internal_url": "https://secondary.example.com/",
"primary": false,
"enabled": true,
"current": true,
"files_max_capacity": 10,
"repos_max_capacity": 25,
"container_repositories_max_capacity": 10,
"verification_max_capacity": 100,
"selective_sync_type": "namespaces",
"selective_sync_shards": [],
"selective_sync_namespace_ids": [1, 25],
"minimum_reverification_interval": 7,
"sync_object_storage": true,
"clone_protocol": "http",
"web_edit_url": "https://primary.example.com/admin/geo/sites/2/edit",
"web_geo_replication_details_url": "https://secondary.example.com/admin/geo/sites/2/replication/lfs_objects",
"_links": {
"self":"https://primary.example.com/api/v4/geo_nodes/2",
"status":"https://primary.example.com/api/v4/geo_nodes/2/status",
"repair":"https://primary.example.com/api/v4/geo_nodes/2/repair"
}
}
Geo 노드 삭제
Geo 노드를 제거합니다.
DELETE /geo_nodes/:id
속성 | 유형 | 필수 | 설명 |
---|---|---|---|
id
| 정수 | 예 | Geo 노드의 ID입니다. |
Geo 노드 복원
Geo 노드의 OAuth 인증을 복원합니다.
이 작업은 기본 Geo 노드에서만 실행할 수 있습니다.
POST /geo_nodes/:id/repair
예시 응답:
{
"id": 1,
"name": "us-node",
"url": "https://primary.example.com/",
"internal_url": "https://primary.example.com/",
"primary": true,
"enabled": true,
"current": true,
"files_max_capacity": 10,
"repos_max_capacity": 25,
"container_repositories_max_capacity": 10,
"verification_max_capacity": 100,
"clone_protocol": "http",
"web_edit_url": "https://primary.example.com/admin/geo/sites/1/edit",
"_links": {
"self": "https://primary.example.com/api/v4/geo_nodes/1",
"status":"https://primary.example.com/api/v4/geo_nodes/1/status",
"repair":"https://primary.example.com/api/v4/geo_nodes/1/repair"
}
}
GET /geo_nodes/status
curl --header "PRIVATE-TOKEN: <your_access_token>" "https://primary.example.com/api/v4/geo_nodes/status"
예시 응답:
[
{
"geo_node_id": 1,
"healthy": true,
"health": "Healthy",
"health_status": "Healthy",
"missing_oauth_application": false,
"db_replication_lag_seconds": null,
"lfs_objects_count": 5,
"lfs_objects_checksum_total_count": 5,
"lfs_objects_checksummed_count": 5,
"lfs_objects_checksum_failed_count": 0,
...
},
{
"geo_node_id": 2,
"healthy": true,
"health": "Healthy",
"health_status": "Healthy",
"missing_oauth_application": false,
"db_replication_lag_seconds": 0,
"lfs_objects_count": 5,
"lfs_objects_checksum_total_count": 5,
"lfs_objects_checksummed_count": 5,
"lfs_objects_checksum_failed_count": 0,
...
}
]
특정 Geo 노드에 대한 상태 검색
GET /geo_nodes/:id/status
curl --header "PRIVATE-TOKEN: <your_access_token>" "https://primary.example.com/api/v4/geo_nodes/2/status"
예시 응답:
{
"geo_node_id": 2,
"healthy": true,
"health": "Healthy",
"health_status": "Healthy",
...
(중략)
...
"project_repositories_verified_in_percentage": "100.00%"
}
참고:
health_status
매개변수는 “Healthy” 또는 “Unhealthy” 상태여야 하며, health
매개변수는 비어 있을 수 있고 “Healthy”이거나 실제 오류 메시지를 포함할 수 있습니다.