GitHub 제품 간의 마이그레이션 정보
GitHub Enterprise Importer을(를) 사용하면 GitHub Enterprise Server에서 GitHub Enterprise Cloud(으)로 데이터를 마이그레이션하거나 GitHub Enterprise Cloud의 계정 간에 데이터를 마이그레이션할 수 있습니다. 자세한 내용은 "GitHub Enterprise Importer 정보"을(를) 참조하세요.
마이그레이션 원본이 GitHub.com의 다른 계정인 경우 조직 간에 개별 리포지토리를 마이그레이션하거나 엔터프라이즈 간에 전체 조직을 마이그레이션할 수 있습니다. 마이그레이션 원본이 GitHub Enterprise Server인 경우 리포지토리를 마이그레이션할 수 있습니다.
GitHub Enterprise Importer에서 마이그레이션하는 데이터는 마이그레이션의 원본과 리포지토리를 마이그레이션하는지, 조직을 마이그레이션하는지에 따라 달라집니다.
Note
마이그레이션하는 리포지토리에 들어오는 리포지토리가 일치하지 않는 규칙 집합이 있는 경우 마이그레이션이 차단됩니다. 이러한 규칙 집합을 무시하고 마이그레이션을 허용하기 위해 대상 조직의 모든 배포 키 대해 규칙 집합 바이패스를 적용할 수 있습니다.
리포지토리 규칙 집합은 조직 수준에서 설정할 수 있습니다. 들어오는 리포지토리가 이러한 규칙 집합과 일치하지 않는 경우 각 규칙 집합에 대해 배포 키 무시를 사용해야 합니다. "조직에서 리포지토리에 대한 규칙 집합 만들기" 항목을 참조하세요.
GitHub Enterprise Server에서 마이그레이션된 데이터
Warning
Wikis 마이그레이션은 현재 사용할 수 없습니다. 해결 방법으로 수동으로 마이그레이션할 수 있습니다.
git clone --mirror OLD-REPOSITORY-URL cd OLD-REPOSITORY-NAME git remote add new-origin NEW-REPOSITORY-URL git push new-origin --mirror
git clone --mirror OLD-REPOSITORY-URL
cd OLD-REPOSITORY-NAME
git remote add new-origin NEW-REPOSITORY-URL
git push new-origin --mirror
GitHub Enterprise Server(GHES)에서 마이그레이션하려면 GHES 버전 3.4.1 이상이 있어야 합니다. 마이그레이션되는 데이터는 사용 중인 버전에 따라 달라집니다.
Item | GHES 3.4.1 이상 | GHES 3.5.0 이상 |
---|---|---|
Git 원본(커밋 기록 포함) | ||
끌어오기 요청 | ||
문제 | ||
마일스톤 | ||
Wikis | ||
GitHub Actions 워크플로 | ||
커밋 주석 | ||
활성 웹후크 | ||
분기 보호 | ||
GitHub Pages 설정 | ||
위의 데이터에 대한 사용자 기록 | ||
첨부 파일("파일 첨부" 참조) | ||
릴리스 |
리포지토리당 다양한 크기 제한이 GHES 버전에 따라 적용됩니다.
제한 | GHES 3.8.0 미만 | GHES 3.8.0 이상 |
---|---|---|
Git 원본 | 2GB | 10GB |
메타데이터 | 2GB | 10GB |
마이그레이션되지 않는 데이터
현재 다음 데이터는 마이그레이션되지 않습니다.
- Code scanning 결과
- 커밋 상태 검사
- Dependabot 경고
- Dependabot 비밀
- 리포지토리 수준의 토론
- 문제 주석 및 끌어오기 요청 주석의 기록 편집
- 리포지토리 간의 포크 관계("포크 정보" 참조)
- GitHub Actions 비밀, 변수, 환경, 자체 호스팅 실행기, 더 큰 실행기s 또는 워크플로 실행 기록
- GitHub 앱 및 GitHub 앱 설치
- Git LFS 개체 및 큰 이진 파일(Git LFS을(를) 사용하는 리포지토리는 계속 지원됩니다. "GitHub Enterprise Importer의 제한 사항"을 참조하세요.
- GitHub Packages의 패키지
- 조직 수준의 프로젝트(클래식)
- Projects(새로운 프로젝트 환경)
- 끌어오기 요청과 다른 리포지토리의 문제 간 참조("자동 링크된 참조 및 URL" 참조)
- secret scanning 결과의 수정 상태
- 사용자 계정이 소유한 리포지토리
- 리포지토리 별표
- 리포지토리 감시자
- 규칙 집합
- 태그 보호 규칙
- 사용자 프로필, SSH 키, 서명 키 또는 personal access tokens
- 웹후크 비밀
- Teams
- 리포지토리에 대한 사용자 또는 팀 액세스
- 끌어오기 요청에 대한 리포지토리 설정
분기 보호
분기 보호는 특정 분기 이름 또는 분기 이름 패턴에 지정된 규칙의 세트를 적용합니다. 자세한 내용은 "보호된 분기 정보"을(를) 참조하세요.
분기 보호는 항상 마이그레이션되지만 특정 규칙은 마이그레이션되지 않습니다. 다음 분기 보호 규칙은 마이그레이션되지 않습니다.
- 특정 행위자가 필요한 끌어오기 요청을 바이패스하도록 허용
- 최신 푸시의 승인 필요
- 병합 전 배포 성공 필요
- 분기 잠금
- 일치하는 분기를 만드는 푸시 제한
- 강제 푸시 허용
또한 다음과 같은 제한 사항이 적용됩니다.
- 분기 보호 규칙에서 선택적으로 "끌어오기 요청 검토를 해제할 수 있는 사람 제한"과 같이 규칙에서 제외된 사람, 팀 또는 앱을 지정할 수 있는 경우 예외는 마이그레이션되지 않습니다.
- "강제 푸시 허용" 규칙이 "강제 푸시할 수 있는 사용자 지정" 모드에서 사용하도록 설정된 경우 규칙은 마이그레이션되지 않습니다.
GitHub.com의 다른 계정에서 마이그레이션된 데이터
마이그레이션 원본이 GitHub.com의 다른 계정인 경우 조직 간에 개별 리포지토리를 마이그레이션하거나 엔터프라이즈 간에 전체 조직을 마이그레이션할 수 있습니다.
조직의 마이그레이션된 데이터
조직을 마이그레이션하면 대상 엔터프라이즈 계정 내에 새 조직이 만들어집니다. 그런 다음, 다음 데이터가 새 조직으로 마이그레이션됩니다.
- Teams
- 리포지토리
- 리포지토리에 대한 팀 액세스
- 멤버 권한
- 조직 수준 웹후크(마이그레이션 후 다시 사용하도록 설정해야 함, "웹후크 사용" 참조)
- 조직의 리포지토리에서 만들어진 새로운 리포지토리를 위한 기본 분기 이름
모든 리포지토리는 프라이빗 표시 여부로 마이그레이션됩니다. 리포지토리의 가시성을 퍼블릭 또는 내부로 설정하려는 경우 UI 또는 API를 사용하여 마이그레이션 후 이 작업을 수행할 수 있습니다.
팀 멤버십은 마이그레이션되지 않습니다. 마이그레이션 후에는 마이그레이션된 팀에 구성원을 추가해야 합니다. 자세한 정보는 "GitHub 제품 간 마이그레이션의 개요" 항목을 참조하세요.
참고: @octo-org/octo-team
와(과) 같은 팀에 대한 참조는 조직 마이그레이션의 일부로 업데이트되지 않습니다. 이로 인해 CODEOWNERS
파일이 예상대로 작동하지 않는 등, 대상 조직에서 문제가 발생할 수 있습니다. 이러한 문제를 방지하고 해결하는 방법에 대한 자세한 내용은 "GitHub Enterprise Importer를 사용하여 마이그레이션 문제 해결"을 참조하세요.
리포지토리의 마이그레이션된 데이터
직접 또는 조직 마이그레이션의 일부로 리포지토리를 마이그레이션하는 경우 다음 데이터만 마이그레이션됩니다.
- Git 원본(커밋 기록 포함)
- 끌어오기 요청
- 문제
- 마일스톤
- Wiki(첨부 파일 제외)
- GitHub Actions 워크플로
- 커밋 주석
- 활성 웹후크(마이그레이션 후 다시 사용하도록 설정해야 함, "웹후크 사용" 참조)
- 리포지토리 토픽
- 리포지토리 설정
- 분기 보호(자세한 내용은 "분기 보호" 참조)
- GitHub Pages 설정
- 참조 자동 연결
- GitHub Advanced Security 설정
- 끌어오기 요청 설정
- 자동으로 제목 분기 삭제
- 자동 병합 허용
- 병합 커밋 허용(커밋 메시지 설정이 기본 메시지로 다시 설정됨)
- Squash 병합 허용(커밋 메시지 설정이 기본 메시지로 다시 설정됨)
- 병합 다시 지정 허용
- 릴리스(리포지토리당 최대 10GB)
- 위의 데이터에 대한 사용자 기록
- 첨부 파일("파일 첨부" 참조)
마이그레이션되지 않는 데이터
현재 다음 데이터는 마이그레이션되지 않습니다.
- Codespaces 비밀 * Code scanning 결과
- 커밋 상태 검사
- Dependabot 경고
- Dependabot 비밀
- 리포지토리 수준의 토론
- 문제 주석 및 끌어오기 요청 주석의 기록 편집
- 리포지토리 간의 포크 관계("포크 정보" 참조)
- GitHub Actions 비밀, 변수, 환경, 자체 호스팅 실행기, 더 큰 실행기s 또는 워크플로 실행 기록
- GitHub 앱 및 GitHub 앱 설치
- Git LFS 개체 및 큰 이진 파일(Git LFS을(를) 사용하는 리포지토리는 계속 지원됩니다. "GitHub Enterprise Importer의 제한 사항"을 참조하세요.
- GitHub Packages의 패키지
- 조직 수준의 프로젝트(클래식)
- Projects(새로운 프로젝트 환경)
- 끌어오기 요청과 다른 리포지토리의 문제 간 참조("자동 링크된 참조 및 URL" 참조)
- secret scanning 결과의 수정 상태
- 사용자 계정이 소유한 리포지토리
- 리포지토리 별표
- 리포지토리 감시자
- 규칙 집합
- 태그 보호 규칙
- 사용자 프로필, SSH 키, 서명 키 또는 personal access tokens
- 웹후크 비밀
- 리포지토리에 대한 사용자 액세스
리포지토리를 직접 마이그레이션하는 경우 팀 및 팀 액세스 권한이 리포지토리로 마이그레이션되지 않습니다.
분기 보호
분기 보호는 특정 분기 이름 또는 분기 이름 패턴에 지정된 규칙의 세트를 적용합니다. 자세한 내용은 "보호된 분기 정보"을(를) 참조하세요.
분기 보호는 항상 마이그레이션되지만 특정 규칙은 마이그레이션되지 않습니다. 다음 분기 보호 규칙은 마이그레이션되지 않습니다.
- 특정 행위자가 필요한 끌어오기 요청을 바이패스하도록 허용
- 최신 푸시의 승인 필요
- 병합 전 배포 성공 필요
- 분기 잠금
- 일치하는 분기를 만드는 푸시 제한
- 강제 푸시 허용
또한 다음과 같은 제한 사항이 적용됩니다.
- 분기 보호 규칙에서 선택적으로 "끌어오기 요청 검토를 해제할 수 있는 사람 제한"과 같이 규칙에서 제외된 사람, 팀 또는 앱을 지정할 수 있는 경우 예외는 마이그레이션되지 않습니다.
- "강제 푸시 허용" 규칙이 "강제 푸시할 수 있는 사용자 지정" 모드에서 사용하도록 설정된 경우 규칙은 마이그레이션되지 않습니다.
마이그레이션된 데이터에 대한 제한 사항
GitHub Enterprise Importer에서 마이그레이션할 수 있는 항목에는 제한이 있습니다. 일부는 GitHub의 제한 사항으로 인해 발생하지만 다른 일부는 GitHub Enterprise Importer 자체의 제한 사항입니다.
GitHub의 제한 사항
- 단일 Git 커밋에 대한 2GB 크기 제한: Git 리포지토리의 단일 커밋은 2GB보다 클 수 없습니다. 커밋이 2GB보다 큰 경우 커밋을 각각 2GB 이하인 더 작은 커밋으로 분할해야 합니다.
- Git 참조에 대한 255바이트 제한: 일반적으로 "ref"라고 하는 단일 Git 참조는 255바이트보다 큰 이름을 가질 수 없습니다. 일반적으로 참고자료는 255자를 초과할 수 없지만 이모지와 같은 비 ASCII가 아닌 문자는 둘 이상의 바이트를 사용할 수 있습니다. Git 참고자료가 너무 크면 명확한 오류 메시지가 반환됩니다.
- 100MB 파일 크기 제한: Git 리포지토리의 단일 파일은 100MB를 초과할 수 없습니다. 대용량 파일을 저장하기 위해 Git LFS을(를) 사용하는 것을 고려합니다. 자세한 내용은 "대형 파일 관리"을(를) 참조하세요.
GitHub Enterprise Importer의 제한 사항
- Git 리포지토리에 대한 10GB 크기 제한: 이 제한 사항은 소스 코드에만 적용됩니다. 리포지토리 보관이 한도를 초과하는지 확인하려면 git-sizer 도구를 사용하고 출력의 총 미확인 개체 크기를 검토합니다. git-sizer 도구는 또한 마이그레이션에 영향을 미칠 수 있는 큰 파일 보고서, 미확인 개체 크기, 커밋 크기 및 트리 수와 관련된 잠재적인 문제를 식별하는 데 도움이 됩니다.
- 메타데이터에 대한 10GB 제한: Importer은(는) 10GB 이상의 메타데이터를 사용하여 리포지토리를 마이그레이션할 수 없습니다. 메타데이터에는 문제, 끌어오기 요청, 릴리스 및 첨부 파일이 포함됩니다. 대부분의 경우 큰 메타데이터는 릴리스에 연결된 이진 자산으로 인해 발생합니다.
migrate-repo
명령의--skip-releases
플래그를 사용하여 마이그레이션에서 릴리스를 제외한 다음 마이그레이션 후에 릴리스를 수동으로 이동할 수 있습니다. - Git LFS 개체가 마이그레이션되지 않음: Importer은(는) Git LFS을(를) 사용하는 리포지토리를 마이그레이션할 수 있지만 LFS 개체 자체는 마이그레이션되지 않습니다. 마이그레이션이 완료된 후 후속작업으로 마이그레이션 대상에 푸시할 수 있습니다. 자세한 내용은 "리포지토리 복제"을(를) 참조하세요.
- 후속작업 필요: GitHub 제품 간에 마이그레이션할 때 특정 설정은 마이그레이션되지 않으며 새 리포지토리에서 다시 구성해야 합니다. 각 마이그레이션 후에 완료해야 하는 후속작업 목록은 "GitHub 제품 간 마이그레이션의 개요"을 참조하세요.
- 지연된 코드 검색 기능: 리포지토리가 마이그레이션된 후 검색 인덱스를 다시 인덱싱하는 데 몇 시간이 걸릴 수 있으며, 코드 검색은 다시 인덱싱이 완료될 때까지 예기치 않은 결과를 반환할 수 있습니다.
- 조직에 대해 구성된 규칙 집합으로 인해 마이그레이션 실패: 예를 들어 커밋 작성자의 이메일 주소가
@monalisa.cat
(으)로 끝나야 하는 규칙을 구성하고 마이그레이션하려는 리포지토리에 이 규칙을 준수하지 않는 커밋이 포함되어 있으면 마이그레이션이 실패합니다. 규칙 집합에 대한 자세한 내용은 "규칙 세트 정보"을 참조하세요. - 마네킹 콘텐츠가 검색되지 않을 수 있습니다. 마네킹은 가져온 콘텐츠(예: 이슈, 끌어오기 요청, 메모 등)가 연결된 자리 표시자 사용자입니다. 할당된 이슈와 같이 마네킹과 연결된 콘텐츠를 검색하는 경우 이슈를 찾지 못할 수 있습니다. 마네킹이 회수되면 새 소유자를 통해 콘텐츠를 찾아야 합니다. 자세한 내용은 "GitHub Enterprise Importer에 대한 마네킹 회수" 항목을 참조하세요.
시작
GitHub 제품 간에 마이그레이션하기 전에 마이그레이션 실행 방법을 계획해야 합니다. 데이터를 마이그레이션하기 전에 마이그레이션을 실행할 사용자를 선택해야 합니다. 마이그레이션의 원본과 대상 모두에 대해 필요한 액세스 권한을 해당 사용자에게 부여해야 합니다. 또한 먼저 평가판 마이그레이션을 실행하는 것이 좋습니다.
전체 마이그레이션 프로세스의 개요는 "GitHub 제품 간 마이그레이션의 개요" 섹션을 참조하세요.