분기 정보
분기를 사용하면 리포지토리의 포함된 영역에서 기능을 개발하거나 버그를 수정하거나 새 아이디어를 안전하게 실험할 수 있습니다.
항상 기존 분기에서 분기를 만듭니다. 일반적으로 리포지토리의 기본 분기에서 새 분기를 만들 수 있습니다. 그런 다음 다른 사용자가 리포지토리에 적용하는 변경 내용과 격리된 상태로 이 새 분기에서 작업할 수 있습니다. 기능을 빌드하기 위해 만드는 분기를 일반적으로 기능 분기 또는 토픽 분기라고 합니다. 자세한 내용은 "리포지토리 내에서 분기 만들기 및 삭제"을(를) 참조하세요.
분기를 사용하여 GitHub Pages 사이트에 게시할 수도 있습니다. 자세한 내용은 "GitHub Pages 정보"을(를) 참조하세요.
분기를 만들거나, 끌어오기 요청을 열거나, 끌어오기 요청에서 분기를 삭제하고 복원하려면 리포지토리에 대한 쓰기 권한이 있어야 합니다. 자세한 내용은 "GitHub의 액세스 권한"을(를) 참조하세요.
기본 분기 정보
GitHub.com에 콘텐츠가 있는 리포지토리를 만들면 GitHub이(가) 단일 분기로 리포지토리를 만듭니다. 리포지토리의 이 첫 번째 분기는 기본 분기입니다. 기본 분기는 누군가가 리포지토리를 방문할 때 GitHub에 표시되는 분기입니다. 또한 기본 분기는 누군가가 리포지토리를 복제할 때 Git에서 로컬로 체크 아웃하는 초기 분기이기도 합니다. 다른 분기를 지정하지 않는 한 리포지토리의 기본 분기는 새 끌어오기 요청 및 코드 커밋의 기본 분기입니다.
기본적으로 GitHub는 새 리포지토리의 기본 분기 main
의 이름을 지정합니다.
기존 리포지토리의 기본 분기를 변경할 수 있습니다. 자세한 내용은 "기본 분기 변경"을(를) 참조하세요.
새 리포지토리의 기본 분기 이름을 설정할 수 있습니다. 자세한 내용은 "리포지토리의 기본 분기 이름 관리," "조직의 리포지토리에 대한 기본 분기 이름 관리," "엔터프라이즈에서 리포지토리 관리 정책 적용”를 참조하세요.
분기 작업
작업에 만족하면 끌어오기 요청을 열어 현재 분기(헤드 분기)의 변경 내용을 다른 분기(베이스 분기)로 병합할 수 있습니다. 자세한 내용은 "끌어오기 요청 정보"을(를) 참조하세요.
끌어오기 요청이 병합되거나 닫힌 후에는 더 이상 필요하지 않으므로 헤드 분기를 삭제할 수 있습니다. 분기를 삭제하려면 리포지토리에 대한 쓰기 권한이 있어야 합니다. 열려 있는 끌어오기 요청과 직접 연결된 분기는 삭제할 수 없습니다. 자세한 내용은 "끌어오기 요청에서 분기 삭제 및 복원"을(를) 참조하세요.
끌어오기 요청이 병합된 후 헤드 분기를 삭제한 경우 GitHub에서는 동일한 리포지토리 내에서 삭제된 분기를 기본 분기로 지정하는 시작된 끌어오기 요청이 있는지 확인합니다. GitHub에서는 이러한 끌어오기 요청을 자동으로 업데이트하여 기본 분기를 병합된 끌어오기 요청의 기본 분기로 변경합니다. 다음 다이어그램에서 이를 보여 줍니다.
여기서 누군가가 main
분기에서 feature1
이라는 분기를 만들었고 사용자는 feature1
에서 feature2
라는 분기를 만들었습니다. 두 분기 모두에 대해 열려 있는 끌어오기 요청이 있습니다. 화살표는 각 끌어오기 요청에 대한 현재 베이스 분기를 나타냅니다. 이때 feature1
은 feature2
에 대한 베이스 분기입니다. feature2
에 대한 끌어오기 요청이 지금 병합되면 feature2
분기가 feature1
에 병합됩니다.
다음 다이어그램에서 누군가가 feature1
에 대한 끌어오기 요청을 main
분기에 병합했으며 feature1
분기를 삭제했습니다. 결과적으로 GitHub는 feature2
에 대한 끌어오기 요청의 대상을 자동으로 변경하여 베이스 분기가 이제 main
이 되도록 했습니다.
이제 feature2
끌어오기 요청을 병합하면 main
분기에 병합됩니다.
보호된 분기 작업
리포지토리 관리자 또는 "리포지토리 규칙 편집" 권한이 있는 사용자 지정 역할은(는) 분기에서 보호를 활성화할 수 있습니다. 보호되는 분기에서 작업하는 경우 분기를 삭제하거나 강제로 푸시할 수 없습니다. 리포지토리 관리자는 분기를 병합하기 전에 다른 여러 보호된 분기 설정을 사용하도록 설정하여 다양한 워크플로를 적용할 수 있습니다.
참고: 리포지토리 관리자인 경우 분기 보호가 “관리자 포함”으로 설정되지 않은 한 끌어오기 요청이 요구 사항을 충족하지 않더라도 분기 보호가 설정된 분기의 끌어오기 요청을 병합할 수 있습니다.
끌어오기 요청을 병합할 수 있는지 확인하려면 끌어오기 요청의 대화 탭 아래쪽에 있는 병합 상자를 확인합니다. 자세한 내용은 “보호된 분기 정보”을(를) 참조하세요.
분기가 보호되는 경우:
- 분기를 삭제하거나 분기에 푸시를 강제 적용할 수 없습니다.
- 분기에서 필요한 상태 검사를 사용하도록 설정한 경우 필요한 모든 CI 테스트에 통과할 때까지 변경 내용을 분기에 병합할 수 없습니다. 자세한 내용은 "상태 검사 정보"을(를) 참조하세요.
- 분기에서 필요한 끌어오기 요청 검토를 사용하도록 설정한 경우 끌어오기 요청 검토 정책의 모든 요구 사항이 충족될 때까지 변경 내용을 분기에 병합할 수 없습니다. 자세한 내용은 "끌어오기 요청 병합"을(를) 참조하세요.
- 코드 소유자의 필수 검토를 분기에서 사용하도록 설정했고 끌어오기 요청이 소유자가 있는 코드를 수정하는 경우 코드 소유자는 끌어오기 요청을 병합하기 전에 승인해야 합니다. 자세한 내용은 "코드 소유자 정보"을(를) 참조하세요.
- 분기에서 필수 커밋 서명을 사용하는 경우 서명되지 않았거나 확인되지 않은 분기에 커밋을 푸시할 수 없습니다. 자세한 내용은 "커밋 서명 확인 정보" 및 "보호된 분기 정보"을(를) 참조하세요.
- GitHub의 충돌 편집기를 사용하여 보호된 분기에서 만든 끌어오기 요청에 대한 충돌을 해결하는 경우 GitHub를 사용하면 끌어오기 요청에 대한 대체 분기를 만들어 충돌 해결을 병합할 수 있습니다. 자세한 내용은 "GitHub에서 병합 충돌 해결"을(를) 참조하세요.
추가 참고 자료
- "끌어오기 요청 정보"
- GitHub 용어집의 “GitHub 용어”
- Git 설명서의 “분기에 대한 설명 요약”