# 내부 허용된 API

internal/allowed 엔드포인트는 사용자가 Git 리포지터리에서 특정 작업을 수행할 권한이 있는지를 평가합니다. 이는 여러 가지 확인을 수행합니다. - 브랜치 또는 태그 이름이 허용되는지 확인합니다. - 사용자가 해당 작업을 수행할 권한이 있는지 여부를 확인합니다.

엔드포인트 정의

내부 API 엔드포인트는 lib/api/internal 하위에 정의되어 있으며, /allowed 경로는 lib/api/internal/base.rb에 있습니다.

엔드포인트 사용

internal/allowed는 다음 시점에 호출됩니다. - 리포지터리에 푸시합니다. - 권고 사항을 적용하거나 GitLab IDE를 사용하는 등 GitLab 사용자 인터페이스를 통해 리포지터리에서 작업을 수행합니다.

일반적으로 Gitaly에서 이 엔드포인트를 호출합니다. 이는 API의 외부 사용자가 아닌 내부에서만(응용 프로그램의 다른 부분에서) 호출됩니다.

푸시 확인

internal/allowed 플로우의 중요한 부분은 EE::Gitlab::Checks::PushRuleCheck 호출입니다. 해당 호출은 다음과 같은 확인을 수행할 수 있습니다. - EE::Gitlab::Checks::PushRules::CommitCheck - EE::Gitlab::Checks::PushRules::TagCheck - EE::Gitlab::Checks::PushRules::BranchCheck - EE::Gitlab::Checks::PushRules::FileSizeCheck

재귀

internal/allowed에서 호출되는 일부 Gitaly RPC는 다시 internal/allowed로 호출됩니다. 해당 호출은 이제 원래 요청과 상관 관계가 있습니다. Gitaly는 인가를 위해 Rails 애플리케이션에 의존하며, 자체 권한 모델을 유지하지 않습니다.

이러한 호출은 초기 요청과 로그에 다르게 표시됩니다. {예시}

이 엔드포인트는 재귀적으로 호출될 수 있기 때문에, 이 엔드포인트의 성능이 느릴 경우 기하급수적인 영향을 미칠 수 있습니다. 이 문서는 실제로 성능 조사에 대한 조사에서 적응된 것입니다.

알려진 성능 문제

참조

Git 리포지터리의 refs 수는 git 명령어의 성능에 주목할 만한 영향을 미칩니다. Gitaly RPC도 마찬가지로 영향을 받습니다. 일부 git 명령어는 모든 참조를 스캔하므로 해당 명령어의 속도에 주목할 만한 영향을 미칩니다.

internal/allowed 엔드포인트에서 RPC 호출의 재귀적 성격으로 참조 수는 성능에 기하급수적인 영향을 미칩니다.

환경 참조

오래된 환경 참조는 성능 문제를 일으키는 과도한 참조의 일반적인 예시입니다. 활발한 리포지터리에서 오래된 환경 참조는 자동으로 정리되지 않기 때문에 수천 건에 이를 수 있습니다.

댄글링 참조

댄글링 참조는 객체 풀에서의 실수로 인한 삭제를 예방하기 위해 생성됩니다. 이러한 참조의 수가 많을 경우 성능에 영향을 줄 수 있는 잠재적인 영향이 있을 수 있습니다. 이 문제에 대한 논의는 이미 gitaly#1900에서 이뤄졌습니다. 이 문제는 활발한 환경 참조보다는 덜한 영향을 미치는 것으로 보입니다.

풀 리포지터리

GitLab에서 포크를 생성하면 중앙 풀 리포지터리가 생성되고 포크가 이에 연결됩니다. 이 풀 리포지터리는 다른 포크에게 공통 데이터를 저장함으로써 데이터의 중복을 방지합니다. 그러나 풀 리포지터리는 표준 리포지터리와 같은 방식으로 정리되지 않으며, 참조 문제에 민감합니다.

피처 플래그

병렬 푸시 확인

플래그: 자체 호스팅된 GitLab에서는 이 기능이 기본적으로 제공되지 않습니다. 이를 사용하려면 관리자가 parallel_push_checks라는 피처 플래그를 활성화해야 합니다. GitLab.com에서는 이 기능이 기본적으로 제공되지 않습니다. 프로젝트 별로 이를 사용하려면 GitLab.com 관리자에게 활성화해야 합니다. 이 기능은 프로덕션 환경에서 사용하지 않아야 합니다. GitLab Dedicated에서는 이 기능을 사용할 수 없습니다.

이 실험적인 피처 플래그는 엔드포인트가 동시에 여러 개의 RPC를 실행할 수 있도록 하여 전체 소요 시간을 대략적으로 절반으로 줄입니다. 이 소요 시간 단축은 스레딩을 통해 실현되며 대규모에 잠재적인 부작용이 있습니다. GitLab.com에서는 이 피처 플래그가 gitlab-org/gitlabgitlab-com/www-gitlab-com 프로젝트에 대해서만 활성화됩니다. 이를 사용하지 않으면 해당 프로젝트는 종종 엔드포인트에 대한 요청이 시간 초과됩니다. 이 기능이 GitLab.com에 모두 배포된 후에는 일부 푸시가 실패했는데, 이는 데이터베이스 연결 풀 등의 리소스를 고갈시켰던 것으로 보입니다.

이 피처 플래그는 요청이 시간 초과될 때에만 사용하고, 해당 프로젝트에 대해서만 활성화하는 것을 권장합니다.