- 보호된 태그를 수정할 수 있는 사용자
- 보호된 태그 구성
- 와일드카드로 보호된 태그
- 브랜치와 동일한 이름의 태그 생성 방지
- 배포 키를 사용하여 보호된 태그 생성 허용
- 보호된 태그에서 파이프라인 실행
- 보호된 태그 삭제
- 관련 주제
보호된 태그
보호된 태그:
- 태그를 만들 권한을 가진 사용자를 제어할 수 있습니다.
- 만든 후 실수로 업데이트 또는 삭제를 방지합니다.
각 규칙을 사용하여 다음 중 하나에 일치시킬 수 있습니다:
- 개별 태그 이름
- 여러 태그를 한꺼번에 제어하도록 와일드카드
이 기능은 보호된 브랜치에서 발전되었습니다.
보호된 태그를 수정할 수 있는 사용자
기본적으로:
- 태그를 만들거나 삭제하려면 Maintainer 역할이 있어야 합니다.
- 보호된 태그는 UI 또는 API를 사용하여만 삭제할 수 있습니다. (보호된 태그 삭제 참조)
보호된 태그 구성
전제 조건:
- 프로젝트에 대해 적어도 Maintainer 역할을 가져야 합니다.
- 왼쪽 사이드바에서 검색 또는 이동을 선택하고 프로젝트를 찾습니다.
- 설정 > 저장소를 선택합니다.
- 보호된 태그를 확장합니다.
- 새로 추가를 선택합니다.
- 개별 태그를 보호하려면 태그를 선택하고 드롭다운 목록에서 태그를 선택합니다.
- 문자열과 일치하는 이름을 가진 모든 태그를 보호하려면:
- 태그를 선택합니다.
- 태그 일치에 사용할 문자열을 입력합니다. 와일드카드(
*
)가 지원됩니다. - 와일드카드 생성을 선택합니다.
-
생성 허용에서 보호된 태그를 만들 수 있는 권한을 가진 역할을 선택합니다.
GitLab Premium과 Ultimate에서 생성 허용에 사용자 또는 그룹을 추가할 수도 있습니다. - 보호를 선택합니다.
보호된 태그(또는 와일드카드)는 보호된 태그 목록에 표시됩니다.
와일드카드로 보호된 태그
와일드카드로 보호된 태그를 지정할 수 있으며, 이를 통해 와일드카드와 일치하는 모든 태그가 보호됩니다. 예를 들어:
와일드카드로 보호된 태그 | 일치하는 태그 |
---|---|
v*
|
v1.0.0 , version-9.1
|
*-deploy
|
march-deploy , 1.0-deploy
|
*gitlab*
|
gitlab , gitlab/v1
|
*
|
v1.0.1rc2 , accidental-tag
|
서로 다른 두 가지 와일드카드가 동일한 태그와 일치할 수 있습니다. 예를 들어 *-stable
과 production-*
은 모두 production-stable
태그와 일치합니다. 이러한 경우, 이러한 보호된 태그 중 어떤 것이라도 생성을 허용과 같은 설정을 가지고 있다면 production-stable
도 같은 설정을 상속합니다.
보호된 태그 이름을 선택하면 GitLab에서 모든 일치하는 태그 목록이 표시됩니다.
브랜치와 동일한 이름의 태그 생성 방지
동일한 이름을 가진 태그와 브랜치는 서로 다른 커밋을 포함할 수 있습니다. 태그와 브랜치가 동일한 이름을 사용하는 경우 사용자가 git checkout
명령을 실행할 때 태그 qa
를 체크아웃하려고 했지만 실제로는 브랜치 qa
를 체크아웃할 수 있습니다. 추가적인 보안 조치로, 태그와 브랜치에 동일한 이름을 가진 태그를 만드는 것을 피하세요. 이 두 가지를 혼동하면 잠재적인 보안 또는 운영 문제로 이어질 수 있습니다.
이 문제를 방지하려면:
- 사용자가 태그로 사용하고 싶지 않은 브랜치 이름을 식별합니다.
-
보호된 태그 구성에서 설명한 대로 보호된 태그를 만듭니다:
-
이름에
stable
과 같은 이름을 제공합니다.stable-v1
및stable-v2
와 같이 여러 이름을 일치시키기 위해stable-*
와 같은 와일드카드를 만들 수도 있습니다. - 생성 허용에 대해 아무도를 선택합니다.
- 보호를 선택합니다.
-
이름에
사용자는 여전히 브랜치를 만들 수 있지만, 보호된 이름에 태그를 만들 수는 없습니다.
배포 키를 사용하여 보호된 태그 생성 허용
- GitLab 15.11에서 도입됨.
배포 키 소유자가 보호된 태그를 만들 권한을 부여할 수 있습니다. 사용자가 관련 프로젝트의 멤버가 아닌 경우에도 배포 키가 작동합니다. 그러나 배포 키의 소유자는 프로젝트에 대해 최소한 읽기 액세스 권한을 가져야 합니다.
전제 조건:
- 프로젝트에 대해 배포 키가 활성화되어 있어야 합니다. 프로젝트 배포 키는 생성될 때 기본적으로 활성화됩니다. 그러나 공개 배포 키는 프로젝트에 권한 부여되어야 합니다.
- 배포 키는 프로젝트 저장소에 대해 쓰기 액세스를 가져야 합니다.
배포 키를 사용하여 보호된 태그를 생성하도록 허용하려면:
- 왼쪽 사이드바에서 검색 또는 이동을 선택하고 프로젝트를 찾습니다.
- 설정 > 저장소를 선택합니다.
- 보호된 태그를 확장합니다.
- 태그 드롭다운 목록에서 보호할 태그를 선택합니다.
- 생성 허용 목록에서 배포 키를 선택합니다.
- 보호를 선택합니다.
보호된 태그에서 파이프라인 실행
보호된 태그를 생성하기 위한 권한은 사용자가 다음을 할 수 있는지 정의합니다:
- CI/CD 파이프라인을 초기화하고 실행합니다.
- 이러한 태그와 관련된 작업을 실행합니다.
이 권한은 보호된 태그에 대해 CI/CD 프로세스를 트리거하고 관리할 수 있는 권한이 있는 사용자만이 실행할 수 있도록 합니다.
보호된 태그 삭제
보호된 태그는 GitLab API 또는 GitLab 사용자 인터페이스를 사용하여 수동으로 삭제할 수 있습니다.
전제 조건:
- 프로젝트에 대해 적어도 Maintainer 역할을 가져야 합니다.
수행하려면:
- 왼쪽 사이드바에서 검색 또는 이동을 선택하고 프로젝트를 찾습니다.
- 코드 > 태그를 선택합니다.
- 삭제할 태그 옆에 삭제를 선택합니다 ().
- 확인 대화 상자에서 태그 이름을 입력하고 예, 보호된 태그 삭제를 선택합니다.
보호된 태그는 로컬 Git 명령이나 타사 Git 클라이언트를 통해 실수로 태그를 삭제하지 못하도록 하기 위해 GitLab를 사용하여만 삭제할 수 있습니다.