Git-지점 관리
지점 운영을 통해 또 다른 개발 라인을 만들 수 있습니다. 이 작업을 사용하여 개발 프로세스를 두 가지 다른 방향으로 나눌 수 있습니다. 예를 들어, 6.0 버전 용 제품을 출시했으며 7.0 기능의 개발을 6.0 버그 수정과 별도로 유지할 수 있도록 분기를 만들 수 있습니다.
지점 생성
Tom은 git branch <branch name> 명령을 사용하여 새 브랜치를 생성합니다. 기존 분기에서 새 분기를 만들 수 있습니다. 특정 커밋이나 태그를 시작점으로 사용할 수 있습니다. 특정 커밋 ID가 제공되지 않으면 HEAD를 시작점으로 사용하여 분기가 생성됩니다.
[jerry@CentOS src]$ git branch new_branch
[jerry@CentOS src]$ git branch
* master
new_branch
새 분기가 생성됩니다. Tom은 git branch 명령을 사용하여 사용 가능한 분기를 나열했습니다. Git은 현재 체크 아웃 된 분기 앞에 별표를 표시합니다.
분기 생성 작업의 그림 표현은 다음과 같습니다.
분기 간 전환
Jerry는 git checkout 명령을 사용하여 분기간에 전환합니다.
[jerry@CentOS src]$ git checkout new_branch
Switched to branch 'new_branch'
[jerry@CentOS src]$ git branch
master
* new_branch
분기 생성 및 전환 단축키
위의 예에서는 두 개의 명령을 사용하여 각각 분기를 만들고 전환했습니다. 힘내 제공–b체크 아웃 명령 옵션; 이 작업은 새 분기를 만들고 즉시 새 분기로 전환합니다.
[jerry@CentOS src]$ git checkout -b test_branch
Switched to a new branch 'test_branch'
[jerry@CentOS src]$ git branch
master
new_branch
* test_branch
지점 삭제
git branch 명령어와 함께 –D 옵션을 제공하여 브랜치를 삭제할 수 있습니다. 그러나 기존 분기를 삭제하기 전에 다른 분기로 전환하십시오.
Jerry는 현재 test_branch그는 그 가지를 제거하려고합니다. 그래서 그는 분기를 전환하고 아래와 같이 분기를 삭제합니다.
[jerry@CentOS src]$ git branch
master
new_branch
* test_branch
[jerry@CentOS src]$ git checkout master
Switched to branch 'master'
[jerry@CentOS src]$ git branch -D test_branch
Deleted branch test_branch (was 5776472).
이제 Git은 두 개의 분기 만 표시합니다.
[jerry@CentOS src]$ git branch
* master
new_branch
분기 이름 변경
Jerry는 문자열 작업 프로젝트에서 와이드 문자에 대한 지원을 추가하기로 결정합니다. 그는 이미 새 브랜치를 만들었지 만 브랜치 이름이 적절하지 않습니다. 그래서 그는 사용하여 지점 이름을 변경합니다.–m 옵션 뒤에 old branch name 그리고 new branch name.
[jerry@CentOS src]$ git branch
* master
new_branch
[jerry@CentOS src]$ git branch -m new_branch wchar_support
이제 git branch 명령이 새 분기 이름을 표시합니다.
[jerry@CentOS src]$ git branch
* master
wchar_support
두 분기 병합
Jerry는 와이드 문자열의 문자열 길이를 반환하는 함수를 구현합니다. 새로운 코드는 다음과 같이 나타납니다.
[jerry@CentOS src]$ git branch
master
* wchar_support
[jerry@CentOS src]$ pwd
/home/jerry/jerry_repo/project/src
[jerry@CentOS src]$ git diff
위의 명령은 다음 결과를 생성합니다-
t a/src/string_operations.c b/src/string_operations.c
index 8ab7f42..8fb4b00 100644
--- a/src/string_operations.c
+++ b/src/string_operations.c
@@ -1,4 +1,14 @@
#include <stdio.h>
+#include <wchar.h>
+
+size_t w_strlen(const wchar_t *s)
+
{
+
const wchar_t *p = s;
+
+
while (*p)
+ ++p;
+ return (p - s);
+
}
테스트 후 그는 변경 사항을 커밋하고 새 분기로 푸시합니다.
[jerry@CentOS src]$ git status -s
M string_operations.c
?? string_operations
[jerry@CentOS src]$ git add string_operations.c
[jerry@CentOS src]$ git commit -m 'Added w_strlen function to return string lenght of wchar_t
string'
[wchar_support 64192f9] Added w_strlen function to return string lenght of wchar_t string
1 files changed, 10 insertions(+), 0 deletions(-)
Jerry는 이러한 변경 사항을 새 브랜치로 푸시하고 있으므로 브랜치 이름을 사용했습니다. wchar_support 대신에 master 분기.
[jerry@CentOS src]$ git push origin wchar_support <−−− Observer branch_name
위의 명령은 다음과 같은 결과를 생성합니다.
Counting objects: 7, done.
Compressing objects: 100% (4/4), done.
Writing objects: 100% (4/4), 507 bytes, done.
Total 4 (delta 1), reused 0 (delta 0)
To [email protected]:project.git
* [new branch]
wchar_support -> wchar_support
변경 사항을 커밋하면 새 분기가 다음과 같이 나타납니다.
Tom은 Jerry가 자신의 개인 브랜치에서 무엇을하고 있는지 궁금합니다. wchar_support 분기.
[tom@CentOS src]$ pwd
/home/tom/top_repo/project/src
[tom@CentOS src]$ git log origin/wchar_support -2
위의 명령은 다음과 같은 결과를 생성합니다.
commit 64192f91d7cc2bcdf3bf946dd33ece63b74184a3
Author: Jerry Mouse <[email protected]>
Date: Wed Sep 11 16:10:06 2013 +0530
Added w_strlen function to return string lenght of wchar_t string
commit 577647211ed44fe2ae479427a0668a4f12ed71a1
Author: Tom Cat <[email protected]>
Date: Wed Sep 11 10:21:20 2013 +0530
Removed executable binary
커밋 메시지를보고 Tom은 Jerry가 와이드 캐릭터에 대해 strlen 함수를 구현했으며 마스터 브랜치에서 동일한 기능을 원한다는 것을 알게됩니다. 다시 구현하는 대신 그는 브랜치를 마스터 브랜치와 병합하여 Jerry의 코드를 사용하기로 결정합니다.
[tom@CentOS project]$ git branch
* master
[tom@CentOS project]$ pwd
/home/tom/top_repo/project
[tom@CentOS project]$ git merge origin/wchar_support
Updating 5776472..64192f9
Fast-forward
src/string_operations.c | 10 ++++++++++
1 files changed, 10 insertions(+), 0 deletions(-)
병합 작업 후 마스터 분기는 다음과 같이 나타납니다.
자, 지점 wchar_support마스터 브랜치와 병합되었습니다. 커밋 메시지를 보거나 string_operation.c 파일에 적용된 수정 사항을 확인하여 확인할 수 있습니다.
[tom@CentOS project]$ cd src/
[tom@CentOS src]$ git log -1
commit 64192f91d7cc2bcdf3bf946dd33ece63b74184a3
Author: Jerry Mouse
Date: Wed Sep 11 16:10:06 2013 +0530 Added w_strlen function to return string lenght of wchar_t string [tom@CentOS src]$ head -12 string_operations.c
위의 명령은 다음과 같은 결과를 생성합니다.
#include <stdio.h>
#include <wchar.h>
size_t w_strlen(const wchar_t *s)
{
const wchar_t *p = s;
while (*p)
++p;
return (p - s);
}
테스트 후 그는 자신의 코드 변경 사항을 마스터 브랜치에 푸시합니다.
[tom@CentOS src]$ git push origin master
Total 0 (delta 0), reused 0 (delta 0)
To [email protected]:project.git
5776472..64192f9 master −> master
리베이스 브랜치
Git rebase 명령은 분기 병합 명령이지만 차이점은 커밋 순서를 수정한다는 것입니다.
Git merge 명령은 현재 로컬 분기의 HEAD 위에 다른 분기의 커밋을 배치하려고합니다. 예를 들어, 로컬 브랜치가 A-> B-> C-> D를 커밋하고 병합 브랜치가 A-> B-> X-> Y를 커밋하면 git merge는 현재 로컬 브랜치를 A->와 같은 것으로 변환합니다. B-> C-> D-> X-> Y
Git rebase 명령은 현재 로컬 분기와 병합 분기 사이의 공통 조상을 찾으려고합니다. 그런 다음 현재 로컬 브랜치의 커밋 순서를 수정하여 커밋을 로컬 브랜치로 푸시합니다. 예를 들어, 로컬 브랜치에 A-> B-> C-> D 커밋이 있고 병합 브랜치에 A-> B-> X-> Y 커밋이있는 경우 Git rebase는 현재 로컬 브랜치를 A-와 같은 것으로 변환합니다. > B-> X-> Y-> C-> D.
여러 개발자가 단일 원격 저장소에서 작업하는 경우 원격 저장소에서 커밋 순서를 수정할 수 없습니다. 이 상황에서 리베이스 작업을 사용하여 원격 저장소 커밋 위에 로컬 커밋을 배치하고 이러한 변경 사항을 푸시 할 수 있습니다.