InfoGrab Docs

보조 러너

Geo 보조 사이트에 GitLab 러너를 등록하여 기본 인스턴스의 부하를 분산합니다.

히스토리 GitLab 16.8에서 geo_proxy_check_pipeline_refs 라는 플래그 와 함께 도입 되었습니다. 기본적으로 비활성화되어 있습니다. GitLab 16.9에서 기본적으로 활성화 되었습니다. 보조 사이트의 Geo 프록시 를 사용하면 gitlab-runner 를 보조 사이트에 등록할 수 있습니다. 이를 통해 기본 인스턴스의 부하를 분산할 수 있습니다. Note 파이프라인의 첫 번째 stage에서 시작하는 job은 거의 항상 Git 클론 요청이 기본 사이트로 전달됩니다. 이는 보조 사이트가 Git 데이터를 복제하고 검증하기 전에 해당 클론이 발생하기 때문입니다. 이후 stage도 보조 사이트에서 처리된다는 보장이 없습니다. 예를 들어 Git 변경 사항이 크거나, 대역폭이 작거나, 파이프라인 stage가 짧은 경우가 그렇습니다. 대부분의 경우 파이프라인의 이후 stage에서는 보조 사이트에서 Git 데이터를 제공합니다. 이슈 446176 은 첫 번째 stage 클론 요청이 보조 사이트에서 처리될 가능성을 높이기 위한 개선 사항을 제안합니다. 위치 인식 공개 URL(통합 URL)과 함께 보조 러너 사용 # 기능 플래그가 활성화된 상태에서 위치 인식 DNS 를 사용하면 추가 구성 없이 작동합니다. 보조 사이트와 동일한 위치에 러너를 설치하고 등록하면, 자동으로 가장 가까운 사이트와 통신하며, 보조 사이트가 최신 상태가 아닌 경우에만 기본 사이트로 프록시합니다. 별도의 URL과 함께 보조 러너 사용 # 별도의 보조 URL을 사용할 경우 러너는 다음과 같이 구성되어야 합니다: 보조 외부 URL로 등록합니다. 보조 인스턴스의 external_url 로 설정된 clone_url 로 구성합니다. 보조 러너가 있는 계획된 페일오버 처리 # 계획된 페일오버 를 실행할 때 보조 러너는 로컬 인스턴스와 계속 통신하려고 합니다. 이로 인해 러너 용량이 감소할 수 있으므로 이를 고려해야 합니다. 위치 인식 공개 URL 사용 시 # 위치 인식 DNS 를 사용할 경우 모든 러너가 자동으로 가장 가까운 Geo 사이트에 연결됩니다. 새 기본 사이트로 페일오버할 때: 이전 기본 사이트가 DNS 레코드에 있는 동안 이전 기본 사이트에 연결된 러너는 계속 이전 기본 사이트에서 job을 가져오려고 합니다. 이전 기본 사이트에 연결할 수 없는 경우 러너는 이를 감지 하고, 인스턴스가 돌아온 후 일정 시간 동안 요청을 중단합니다. 여러 보조 노드 가 있는 경우, 초기 페일오버 후 나머지 보조 사이트는 새 기본 사이트와 복제 될 때까지 비정상 상태가 됩니다. 해당 사이트에 연결된 러너는 체크인할 수 없으며 상태 확인도 작동합니다. 비정상 노드를 Geo DNS 항목에서 제거하면 러너가 다음으로 가까운 인스턴스를 선택합니다. 아키텍처에 따라 감소된 상태의 사이트에 과부하가 걸릴 수 있으므로 원치 않을 수 있습니다. 이러한 문제를 완화하려면 사이트가 100%로 복구될 때까지 일부 러너를 일시 중지 하거나 종료할 수 있습니다. 이러한 문제가 우려되지 않는 경우 아무것