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