Git 을 사용하면서 pull 을 받을때 다른 브랜치를 pull 받는 경우가 있다.
예를 들어서 나는 현재 A 브랜치에서 작업을 하고 있다. 그런데 B 브랜치의 내용을 A 브랜치로 pull 을 받아야 한다. ( 왜 이렇게 사용하냐고 묻는 다면.. 어쩌다 보니 이렇게 사용하게 됐다..)
그래서 한가지 궁금한게 생겼다.
다른 브랜치를 pull 받는것과 merge 하는것과 차이가 있을까???
그럼 한번 실험을 해보자.
- master 브랜치, dev01 브랜치 생성
먼저 위 그림을 보자. 위 상황은 다음과 같다.
1. master 브랜치에서 test1.md 파일 생성후 커밋
2. dev01 브랜치 생성
3. dev01 브랜치에서 test2.md 파일 생성
- dev02 브랜치 추가 , test3.md 파일 추가
그럼 위와 같은 상태가 된다.
- dev01 브랜치로 돌아가서 test2.md 파일 수정
1. dev01 브랜치로 checkout
2. test1.md, test2.md 파일 수정
3. 커밋
- dev02 브랜치로 가서 dev01 브랜치 pull
dev02 브랜치에 있는 tet1.md 파일과 test2.md 파일은 변경이 되지 않은 상태이다.
여기에서 다음가 같이 명령어를 쓴다.
git pull . dev01
리모트 저장소에 push 된 상태라면 명령어는 다음과 같이 된다. (지금 화면에서는 내가 리모트 저장소에 push 를 안한 상태로 local 만 사용중이기 때문에 . 을 사용한다.)
git pull origin dev01
음?? merge 를 한다고 나오네??
저장을 하게 되면 Git graph 는 다음과 같이 나온다.
결과적으로 서로 다른 브랜치에서 pull을 하게 되면 merge 를 하는것과 동일하게 동작을 한다.
- Merge 확인해보기
dev03 브랜치를 만들어서 dev01 로 merge 를 해보자.
dev03 브랜치에서 test4.md 파일을 만들고 커밋을 했다.
dev02 에서 merge 를 한다는 것이 dev01 에서 merge 를 해서 dev01 도 표현이 되었다.
위와 약간 차이가 있어서 다시 해보겠다.
위 사진은 다음과 같이 실험한 결과이다.
1. dev02 브랜치에서 test5.md 생성 후 커밋
2. dev03 브랜치 checkout
3. dev03 브랜치에서 test4.md 파일 수정 후 커밋
4. dev02 브랜치로 다시 checkout
5. dev02 브랜치에서 dev03브랜치 merge
결과적으로 아래 Merge branch 'dev01' into dev02 와 동일한 그래프가 나타난다.
내가 내린 결론은 현재 브랜치에서 다른 브랜치를 pull하게 되면 merge와 동일한 동작을 하게 된다 라는 것이다.
.... 혹시 글을 읽고 잘못된 점이 있으면 댓글로 알려주세요. (제가 잘못 이해한것 일수도 있어서..)
'Development > Git' 카테고리의 다른 글
git cherry pick (0) | 2024.01.05 |
---|---|
Git Contribute 절차 (0) | 2021.12.10 |
github page 에 테마 설치 (0) | 2020.10.20 |
github 에 page 만들기 (0) | 2020.10.15 |
Git local, remote branch 삭제 (0) | 2020.09.08 |