InfoGrab Docs

GitLab용 Go 프록시

요약

이 기능의 가용성은 기능 플래그에 의해 제어됩니다. GitLab용 Go 프록시를 사용하면 GitLab의 모든 프로젝트를 Go 프록시 프로토콜로 가져올 수 있습니다. GitLab용 Go 프록시는 실험으로, 대형 리포지터리의 잠재적 성능 문제로 인해 프로덕션 사용 준비가 되지 않았습니다.

히스토리
Feature flag

이 기능의 가용성은 기능 플래그에 의해 제어됩니다. 자세한 내용은 히스토리를 참조하세요. 이 기능은 테스트용으로 사용 가능하지만 프로덕션 사용 준비가 되지 않았습니다. 에픽 3043을 참조하세요.

GitLab용 Go 프록시를 사용하면 GitLab의 모든 프로젝트를 Go 프록시 프로토콜로 가져올 수 있습니다.

GitLab용 Go 프록시는 실험으로, 대형 리포지터리의 잠재적 성능 문제로 인해 프로덕션 사용 준비가 되지 않았습니다. 이슈 218083을 참조하세요.

GitLab은 Go 프록시가 활성화되어 있더라도 패키지 레지스트리에 Go 모듈을 표시하지 않습니다. 이슈 213770을 참조하세요.

Go 프록시가 사용하는 특정 API 엔드포인트 문서는 Go 프록시 API 문서를 참조하세요.

GitLab을 Go 프록시로 추가#

GitLab을 Go 프록시로 사용하려면 Go 1.13 이상을 사용해야 합니다.

사용 가능한 프록시 엔드포인트는 프로젝트별로 모듈을 가져오는 /api/v4/projects/:id/packages/go입니다.

GitLab에서 Go 모듈을 가져오려면 프로젝트별 엔드포인트를 GOPROXY에 추가하세요.

Go는 엔드포인트를 쿼리하고 기본 동작으로 폴백합니다:

go env -w GOPROXY='https://gitlab.example.com/api/v4/projects/1234/packages/go,https://proxy.golang.org,direct'

이 구성으로 Go는 다음 순서로 의존성을 가져옵니다:

  1. Go가 프로젝트별 Go 프록시에서 가져오려고 시도합니다.
  2. Go가 proxy.golang.org에서 가져오려고 시도합니다.
  3. Go가 버전 관리 시스템 작업(예: git clone, svn checkout 등)으로 직접 가져옵니다.

GOPROXY가 지정되지 않은 경우 Go는 2단계와 3단계를 따르며, 이는 GOPROXYhttps://proxy.golang.org,direct로 설정하는 것과 같습니다. GOPROXY에 프로젝트별 엔드포인트만 포함된 경우 Go는 해당 엔드포인트만 쿼리합니다.

Go 환경 변수 설정 방법에 대한 자세한 내용은 환경 변수 설정을 참조하세요.

프라이빗 프로젝트에서 모듈 가져오기#

go는 안전하지 않은 연결을 통한 자격 증명 전송을 지원하지 않습니다. 다음 단계는 GitLab이 HTTPS로 구성된 경우에만 작동합니다:

  1. GitLab용 Go 프록시에서 가져올 때 HTTP 기본 인증 자격 증명을 포함하도록 Go를 구성합니다.
  2. 공개 체크섬 데이터베이스에서 프라이빗 GitLab 프로젝트의 체크섬 다운로드를 건너뛰도록 Go를 구성합니다.

요청 인증 활성화#

api 또는 read_api 범위로 설정된 개인 액세스 토큰을 만드세요.

~/.netrc 파일을 열고 다음 텍스트를 추가합니다. < >의 변수를 실제 값으로 교체합니다.

잘못된 HTTP 자격 증명으로 go get 요청을 하면 404 오류가 발생합니다.

Warning

NETRC라는 환경 변수를 사용하면 Go는 해당 값을 파일 이름으로 사용하고 ~/.netrc를 무시합니다. GitLab CI에서 ~/.netrc를 사용하려는 경우 NETRC를 환경 변수 이름으로 사용하지 마세요.

machine <url> login <username> password <token>
  • <url>: GitLab URL, 예: gitlab.com.
  • <username>: 사용자 이름.
  • <token>: 개인 액세스 토큰.

체크섬 데이터베이스 쿼리 비활성화#

Go 1.13 이상에서 의존성을 다운로드할 때 가져온 소스는 체크섬 데이터베이스 sum.golang.org에 대해 검증됩니다.

가져온 소스의 체크섬이 데이터베이스의 체크섬과 일치하지 않으면 Go는 의존성을 빌드하지 않습니다.

sum.golang.org가 프라이빗 모듈의 소스를 가져올 수 없어 체크섬을 제공할 수 없으므로 프라이빗 모듈은 빌드에 실패합니다.

이 문제를 해결하려면 GONOSUMDB를 프라이빗 프로젝트의 쉼표로 구분된 목록으로 설정합니다. Go 환경 변수 설정 방법에 대한 자세한 내용은 환경 변수 설정을 참조하세요.

예를 들어 gitlab.com/my/project의 체크섬 쿼리를 비활성화하려면 GONOSUMDB를 설정합니다:

go env -w GONOSUMDB='gitlab.com/my/project,<previous value>'

Go 작업#

Go의 의존성 관리 또는 Go 전반에 익숙하지 않은 경우 다음 문서를 검토하세요:

환경 변수 설정 {#set-environment-variables}#

Go는 환경 변수를 사용하여 다양한 기능을 제어합니다. 일반적인 방법으로 이러한 변수를 관리할 수 있습니다. 그러나 Go 1.14는 기본적으로 ~/.go/env인 특수 Go 환경 파일에서 Go 환경 변수를 읽고 씁니다.

  • GOENV가 파일로 설정된 경우 Go는 해당 파일에서 읽고 씁니다.
  • GOENV가 설정되지 않았지만 GOPATH가 설정된 경우 Go는 $GOPATH/env를 읽고 씁니다.

Go 환경 변수는 go env <var>로 읽을 수 있으며 Go 1.14 이상에서는 go env -w <var>=<value>로 쓸 수 있습니다. 예를 들어 go env GOPATH 또는 go env -w GOPATH=/go.

모듈 릴리스#

Go 모듈과 모듈 버전은 Git, SVN, Mercurial과 같은 소스 리포지터리에 의해 정의됩니다. 모듈은 go.mod와 Go 파일을 포함하는 리포지터리입니다. 모듈 버전은 버전 관리 시스템(VCS) 태그로 정의됩니다.

모듈을 게시하려면 go.mod와 소스 파일을 VCS 리포지터리에 푸시합니다. 모듈 버전을 게시하려면 VCS 태그를 푸시합니다.

GitLab용 Go 프록시

Tier: Free, Premium, Ultimate
Offering: GitLab.com, GitLab Self-Managed, GitLab Dedicated
원문 보기
요약

이 기능의 가용성은 기능 플래그에 의해 제어됩니다. GitLab용 Go 프록시를 사용하면 GitLab의 모든 프로젝트를 Go 프록시 프로토콜로 가져올 수 있습니다. GitLab용 Go 프록시는 실험으로, 대형 리포지터리의 잠재적 성능 문제로 인해 프로덕션 사용 준비가 되지 않았습니다.

히스토리
Feature flag

이 기능의 가용성은 기능 플래그에 의해 제어됩니다. 자세한 내용은 히스토리를 참조하세요. 이 기능은 테스트용으로 사용 가능하지만 프로덕션 사용 준비가 되지 않았습니다. 에픽 3043을 참조하세요.

GitLab용 Go 프록시를 사용하면 GitLab의 모든 프로젝트를 Go 프록시 프로토콜로 가져올 수 있습니다.

GitLab용 Go 프록시는 실험으로, 대형 리포지터리의 잠재적 성능 문제로 인해 프로덕션 사용 준비가 되지 않았습니다. 이슈 218083을 참조하세요.

GitLab은 Go 프록시가 활성화되어 있더라도 패키지 레지스트리에 Go 모듈을 표시하지 않습니다. 이슈 213770을 참조하세요.

Go 프록시가 사용하는 특정 API 엔드포인트 문서는 Go 프록시 API 문서를 참조하세요.

GitLab을 Go 프록시로 추가#

GitLab을 Go 프록시로 사용하려면 Go 1.13 이상을 사용해야 합니다.

사용 가능한 프록시 엔드포인트는 프로젝트별로 모듈을 가져오는 /api/v4/projects/:id/packages/go입니다.

GitLab에서 Go 모듈을 가져오려면 프로젝트별 엔드포인트를 GOPROXY에 추가하세요.

Go는 엔드포인트를 쿼리하고 기본 동작으로 폴백합니다:

go env -w GOPROXY='https://gitlab.example.com/api/v4/projects/1234/packages/go,https://proxy.golang.org,direct'

이 구성으로 Go는 다음 순서로 의존성을 가져옵니다:

  1. Go가 프로젝트별 Go 프록시에서 가져오려고 시도합니다.
  2. Go가 proxy.golang.org에서 가져오려고 시도합니다.
  3. Go가 버전 관리 시스템 작업(예: git clone, svn checkout 등)으로 직접 가져옵니다.

GOPROXY가 지정되지 않은 경우 Go는 2단계와 3단계를 따르며, 이는 GOPROXYhttps://proxy.golang.org,direct로 설정하는 것과 같습니다. GOPROXY에 프로젝트별 엔드포인트만 포함된 경우 Go는 해당 엔드포인트만 쿼리합니다.

Go 환경 변수 설정 방법에 대한 자세한 내용은 환경 변수 설정을 참조하세요.

프라이빗 프로젝트에서 모듈 가져오기#

go는 안전하지 않은 연결을 통한 자격 증명 전송을 지원하지 않습니다. 다음 단계는 GitLab이 HTTPS로 구성된 경우에만 작동합니다:

  1. GitLab용 Go 프록시에서 가져올 때 HTTP 기본 인증 자격 증명을 포함하도록 Go를 구성합니다.
  2. 공개 체크섬 데이터베이스에서 프라이빗 GitLab 프로젝트의 체크섬 다운로드를 건너뛰도록 Go를 구성합니다.

요청 인증 활성화#

api 또는 read_api 범위로 설정된 개인 액세스 토큰을 만드세요.

~/.netrc 파일을 열고 다음 텍스트를 추가합니다. < >의 변수를 실제 값으로 교체합니다.

잘못된 HTTP 자격 증명으로 go get 요청을 하면 404 오류가 발생합니다.

Warning

NETRC라는 환경 변수를 사용하면 Go는 해당 값을 파일 이름으로 사용하고 ~/.netrc를 무시합니다. GitLab CI에서 ~/.netrc를 사용하려는 경우 NETRC를 환경 변수 이름으로 사용하지 마세요.

machine <url> login <username> password <token>
  • <url>: GitLab URL, 예: gitlab.com.
  • <username>: 사용자 이름.
  • <token>: 개인 액세스 토큰.

체크섬 데이터베이스 쿼리 비활성화#

Go 1.13 이상에서 의존성을 다운로드할 때 가져온 소스는 체크섬 데이터베이스 sum.golang.org에 대해 검증됩니다.

가져온 소스의 체크섬이 데이터베이스의 체크섬과 일치하지 않으면 Go는 의존성을 빌드하지 않습니다.

sum.golang.org가 프라이빗 모듈의 소스를 가져올 수 없어 체크섬을 제공할 수 없으므로 프라이빗 모듈은 빌드에 실패합니다.

이 문제를 해결하려면 GONOSUMDB를 프라이빗 프로젝트의 쉼표로 구분된 목록으로 설정합니다. Go 환경 변수 설정 방법에 대한 자세한 내용은 환경 변수 설정을 참조하세요.

예를 들어 gitlab.com/my/project의 체크섬 쿼리를 비활성화하려면 GONOSUMDB를 설정합니다:

go env -w GONOSUMDB='gitlab.com/my/project,<previous value>'

Go 작업#

Go의 의존성 관리 또는 Go 전반에 익숙하지 않은 경우 다음 문서를 검토하세요:

환경 변수 설정 {#set-environment-variables}#

Go는 환경 변수를 사용하여 다양한 기능을 제어합니다. 일반적인 방법으로 이러한 변수를 관리할 수 있습니다. 그러나 Go 1.14는 기본적으로 ~/.go/env인 특수 Go 환경 파일에서 Go 환경 변수를 읽고 씁니다.

  • GOENV가 파일로 설정된 경우 Go는 해당 파일에서 읽고 씁니다.
  • GOENV가 설정되지 않았지만 GOPATH가 설정된 경우 Go는 $GOPATH/env를 읽고 씁니다.

Go 환경 변수는 go env <var>로 읽을 수 있으며 Go 1.14 이상에서는 go env -w <var>=<value>로 쓸 수 있습니다. 예를 들어 go env GOPATH 또는 go env -w GOPATH=/go.

모듈 릴리스#

Go 모듈과 모듈 버전은 Git, SVN, Mercurial과 같은 소스 리포지터리에 의해 정의됩니다. 모듈은 go.mod와 Go 파일을 포함하는 리포지터리입니다. 모듈 버전은 버전 관리 시스템(VCS) 태그로 정의됩니다.

모듈을 게시하려면 go.mod와 소스 파일을 VCS 리포지터리에 푸시합니다. 모듈 버전을 게시하려면 VCS 태그를 푸시합니다.