원본(내꺼내가쓴다는데!) : http://blog.naver.com/imf4/220796681049
GitHub_gitBash : Branch란? Branch 만들기 & 확인
Branch란?
커밋을 하면 Git은 다음 항목들을 저장한다.
- 현 Staging Area에 있는 데이터의 스냅샷에 대한 포인터,
- 저자나 커밋 메시지 같은 메타데이터,
- 이전 커밋에 대한 포인터 등을 포함하는 커밋 개체(커밋 Object)
이전 커밋 포인터가 있어서 현재 커밋이 무엇을 기준으로 바뀌었는지를 알 수 있다.
최초 커밋을 제외한 나머지 커밋은 이전 커밋 포인터가 적어도 하나씩 있고 브랜치를 합친 Merge 커밋 같은 경우에는 이전 커밋 포인터가 여러 개 있다.
파일이 3개 있는 디렉토리가 하나 있고 이 파일을 Staging Area에 저장하고 커밋하는 예제를 살펴 보자.
파일을 Stage 하면 Git 저장소에 파일을 저장하고(Git은 이것을 Blob이라고 부른다) Staging Area에 해당 파일의 체크섬을 저장한다(SHA-1 을 사용한다).
* SHA-1 : 24b9da6552252987aa493b52f8696cd6d3b00373
$ git add README test.rb LICENSE
$ git commit -m 'initial commit of my project'
git commit으로 커밋하면 먼저 루트 디렉토리와 각 하위 디렉토리의 트리 개체를 체크섬과 함께 저장소에 저장한다.
그다음에 커밋 개체를 만들고 메타데이터와 루트 디렉토리 트리 개체를 가리키는 포인터 정보를 커밋 개체에 넣어 저장한다.
그래서 필요하면 언제든지 스냅샷을 다시 만들 수 있다.
이 작업을 마치고 나면 Git 저장소에는 다섯 개의 데이터 개체가 생긴다.
각 파일에 대한 Blob 세 개,
파일과 디렉토리 구조가 들어 있는 tree 개체 하나,
메타데이터와 루트 트리를 가리키는 포인터가 담긴 commit 개체 하나이다.
다시 파일을 수정하고 커밋하면 이전 커밋이 무엇인지도 저장한다.
Git의 브랜치는 커밋 사이를 가볍게 이동할 수 있는 어떤 포인터 같은 것이다.
기본적으로 Git은 master 라는 이름의 브랜치를 만든다.
커밋을 만들 때 마다 브랜치가 자동으로 가장 마지막 커밋을 가리키게 한다.
Branch 만들기
$ git branch [브랜치_이름]
새로 만든 브랜치도 지금 작업하고 있던 마지막 커밋을 가리킨다.
아래 그림은 'testing' 이라는 이름의 브랜치를 새로 만든 모습이다.
지금 작업 중인 브랜치가 무엇인지 Git은 어떻게 파악할까.
다른 버전 관리 시스템과는 달리 Git은 HEAD라는 특수한 포인터가 있다.
이 포인터는 지금 작업하는 로컬 브랜치를 가리킨다.
브랜치를 새로 만들었지만, Git은 아직 master 브랜치를 가리키고 있다.
git branch 명령은 브랜치를 만들기만 하고 브랜치를 옮기지 않는다.
Branch 확인 명령어
git log 명령에 --decorate 옵션을 사용하면 쉽게 브랜치가 어떤 커밋을 가리키는지도 확인할 수 있다.
$ git log --oneline --decorate
f30ab (HEAD, master, testing) add feature #32 - ability to add new
34ac2 fixed bug #1328 - stack overflow under certain conditions
98ca9 initial commit of my project
“master”와 “testing” 이라는 브랜치가 f30ab 커밋 옆에 위치하여 이런식으로 브랜치가 가리키는 커밋을 확인할 수 있다.
아래는 필자가 직접 캡쳐한 확인 명령어의 결과.
참고로 필자는 master 브랜치 한개만 갖고있는 상황에서 캡쳐한 것임.
$ git branch -r
현재 설정된 Git Repository의 전체 branch목록들을 확인하는 명령어
현재 설정된 Git Repository의 전체 branch목록들을 확인하는 명령어
'GitHub' 카테고리의 다른 글
GitHub : 커밋 시 'HEAD detached at SHA-1.. ' 메시지가 나오며 push가 되지 않을 때 (0) | 2017.04.27 |
---|---|
GitHub_Git Bash : SSH키 만들기 (0) | 2017.04.27 |
GitHub_Git Bash : remote 저장소 push하려는데 reject될때 조치방법 (0) | 2017.04.27 |
GitHub_Git Bash : commit 히스토리를 push 하기 전에 취소 & 복구시키기 (0) | 2017.04.27 |
GitHub_Git Bash : git log - repository의 commit 로그 확인하기 (0) | 2017.04.27 |