힘내 지점 관리
거의 모든 버전 제어 시스템은 어떤 형태로든 분기를 지원합니다. 브랜치를 사용한다는 것은 메인 개발 라인에서 분기하여 메인 라인에 영향을 주지 않고 작업을 계속할 수 있다는 것을 의미합니다.
어떤 사람들은 Git의 분기 모델을 "열반 기능"이라고 부르는데, 바로 그 이유 때문에 Git이 버전 제어 시스템 제품군과 구별됩니다.
브랜치 생성 명령:
git branch (branchname)
브랜치 전환 명령:
git checkout (branchname)
브랜치를 전환하면 Git은 작업 디렉터리의 내용을 마지막으로 제출된 브랜치의 스냅샷으로 대체하므로 여러 브랜치에 여러 디렉터리가 필요하지 않습니다.
브랜치 병합 명령:
git merge
동일한 브랜치를 여러 번 병합할 수도 있고 병합 후 바로 병합된 브랜치를 삭제하도록 선택할 수도 있습니다.
Git 브랜치 관리
List Branches
브랜치를 나열하는 기본 명령:
git branch
매개변수가 없으면 git Branch는 로컬 브랜치를 나열합니다.
$ git branch * master
이 예의 의미는 "master"라는 분기가 있고 이 분기가 현재 분기라는 것입니다.
git init을 실행하면 Git은 기본적으로 "master" 브랜치를 생성합니다.
브랜치를 수동으로 생성하고 전환하려는 경우. 그냥 git Branch(브랜치 이름)을 실행하세요.
$ git branch testing $ git branch * master testing
이제 새로운 브랜치 테스트가 있는 것을 볼 수 있습니다.
이런 식으로 마지막 커밋 업데이트 이후에 새 브랜치를 생성할 때 나중에 업데이트 커밋이 있는 경우 "testing" 브랜치로 전환하면 Git은 작업 디렉터리를 생성했을 때의 모습으로 복원합니다. Branch
다음으로 브랜치를 전환하는 방법을 보여드리겠습니다. git checkout(브랜치)을 사용하여 수정하려는 브랜치로 전환합니다.
$ ls README $ echo 'w3cschool.cc' > test.txt $ git add . $ git commit -m 'add test.txt' [master 048598f] add test.txt 2 files changed, 1 insertion(+), 3 deletions(-) delete mode 100644 hello.php create mode 100644 test.txt $ ls README test.txt $ git checkout testing Switched to branch 'testing' $ ls README hello.php
"testing" 브랜치로 전환하자 새로 추가했던 test.txt 파일이 삭제되고, 원래 삭제되었던 hello.php 파일이 다시 나타났습니다. "마스터" 분기로 다시 전환하면 다시 나타났습니다.
$ git checkout master Switched to branch 'master' $ ls README test.txt
git checkout -b(branchname) 명령을 사용하여 새 브랜치를 생성하고 즉시 이 브랜치로 전환하여 이 브랜치에서 작업할 수도 있습니다.
$ git checkout -b newtest Switched to a new branch 'newtest' $ git rm test2.txt rm 'test2.txt' $ ls README test.txt $ git commit -am 'removed test2.txt' [newtest 556f0a0] removed test2.txt 1 file changed, 1 deletion(-) delete mode 100644 test2.txt $ git checkout master Switched to branch 'master' $ ls README test.txt test2.txt
보시다시피 브랜치를 생성하고 해당 브랜치의 컨텍스트에서 일부 파일을 제거한 다음 마스터 브랜치로 다시 전환하면 해당 파일이 다시 돌아옵니다.
분기를 사용하여 작업을 분리하면 서로 다른 상황에서 작업을 수행하고 앞뒤로 전환할 수 있습니다.
Delete Branch
브랜치 삭제 명령:
git branch -d (branchname)
예를 들어, "testing" 브랜치를 삭제하고 싶습니다:
$ git branch * master testing $ git branch -d testing Deleted branch testing (was 85fc7e7). $ git branch * master
Branch merge
브랜치에 독립적인 콘텐츠가 있으면 결국 이를 다시 병합하고 싶을 것입니다. 마스터 브랜치 . 다음 명령을 사용하여 모든 브랜치를 현재 브랜치에 병합할 수 있습니다.
git merge
$ git branch * master newtest $ ls README test.txt test2.txt $ git merge newtest Updating 2e082b7..556f0a0 Fast-forward test2.txt | 1 - 1 file changed, 1 deletion(-) delete mode 100644 test2.txt $ ls README test.txt
위의 예에서는 newtest 브랜치를 메인 브랜치에 병합했고 test2.txt 파일은 삭제되었습니다.
Merge conflicts
Merge는 파일을 추가하고 제거하는 단순한 작업이 아니라 Git이 수정 사항도 병합합니다.
$ git branch * master $ cat test.txt w3cschool.cc
먼저 "change_site"라는 브랜치를 생성하고, 그 브랜치로 전환한 후 내용을 www.w3cschool.cc로 변경합니다.
$ git checkout -b change_site Switched to a new branch 'change_site' $ vim test.txt $ head -1 test.txt www.w3cschool.cc $ git commit -am 'changed the site' [change_site d7e7346] changed the site 1 file changed, 1 insertion(+), 1 deletion(-)
수정된 내용을 "change_site" 브랜치에 제출하세요. 이제 "마스터" 분기로 다시 전환하면 내용이 수정 전의 내용으로 복원되고 test.txt 파일을 다시 수정하는 것을 볼 수 있습니다.
$ git checkout master Switched to branch 'master' $ head -1 test.txt w3cschool.cc $ vim test.txt $ cat test.txt w3cschool.cc 新增加一行 $ git diff diff --git a/test.txt b/test.txt index 704cce7..f84c2a4 100644 --- a/test.txt +++ b/test.txt @@ -1 +1,2 @@ w3cschool.cc +新增加一行 $ git commit -am '新增加一行' [master 14b4dca] 新增加一行 1 file changed, 1 insertion(+)
이제 이러한 변경 사항이 내 "마스터" 지점에 기록되었습니다. 다음으로 "change_site" 분기를 병합합니다.
$ git merge change_site Auto-merging test.txt CONFLICT (content): Merge conflict in test.txt Automatic merge failed; fix conflicts and then commit the result. $ cat test.txt <<<<<<< HEAD w3cschool.cc 新增加一行 ======= www.w3cschool.cc >>>>>>> change_site
이전 브랜치를 "마스터" 브랜치로 병합했는데 병합 충돌이 발생했습니다. 다음으로 수동으로 수정해야 합니다.
$ vim test.txt $ cat test.txt www.w3cschool.cc 新增加一行 $ git diff diff --cc test.txt index f84c2a4,bccb7c2..0000000 --- a/test.txt +++ b/test.txt @@@ -1,2 -1,1 +1,2 @@@ - w3cschool.cc + www.w3cschool.cc +新增加一行
Git에서는 git add를 사용하여 파일 충돌이 해결되었음을 Git에 알릴 수 있습니다.
$ git status -s UU test.txt $ git add test.txt $ git status -s M test.txt $ git commit [master 88afe0e] Merge branch 'change_site'
이제 병합의 충돌을 성공적으로 해결하고 결과를 커밋했습니다.