[Git] merge 전략
merge전략
- branch1에서 공용브랜치(dev 또는 main)로 PR을 만든뒤 merge하는 상황
- merge/ rebase / squash
- merge
- merge는 두 브랜치의 변경 사항을 통합하는 기본적인 방법
- branch1에서 넘어온 commitID와 신규 merge commitID가 dev브랜치에 남게됨
- rebase
- 한 브랜치의 커밋을 다른 브랜치의 최신 커밋에 “재적용”(re-apply)하는 방식
- 이때에는 브랜치에서 넘어온 commitID가 아닌, 새로운 commitID가 발급되어 dev브랜치에 생성
- 장점
- merge commitID는 남지 않게 되어, 깔끔한 커밋관리
- 기존의 commit history는 유지
- 단점
- 이후에 branch1에서 다시 merge를 할때 충돌이 발생하므로, 사용하던 branch1은 더이상 사용이 어려움
- squash
- squash는 여러 커밋을 하나의 커밋으로 합치는 과정
- local repository에서 여러 커밋을 발생시켰을때 해당 커밋ID를 통합하여 하나의 commitID로 만들어 dev에는 하나의 commitID로만 이력 생성
- rebase, squash는 feature브랜치에서 공용브랜치로 merge할때에는 선택에 따라 가능. 다만, 기존의 feature브랜치는 재사용이 어려움에 유의
- dev와 main 브랜치는 서로 정기적으로 싱크를 맞춰야함 → 일반 merge 사용
⇒ dev 브랜치를 버릴 수는 없기 때문
- merge
실습 - merge
data:image/s3,"s3://crabby-images/47cd2/47cd2f87d09540f234a5741626c663dd0967fc2c" alt=""
로컬 branch1에서 수정
data:image/s3,"s3://crabby-images/92fc2/92fc250a5643b44c81d017b96c773009213789e6" alt=""
origin/branch1으로 올림
data:image/s3,"s3://crabby-images/c44d4/c44d4e695f46cb40227669874110a0628888d1a1" alt=""
pull requests - new pull request
data:image/s3,"s3://crabby-images/50a9b/50a9b30e27a26e1eecaed491c212e08c5f5a9006" alt=""
main <- branch1으로 바꾸고 create pull request
data:image/s3,"s3://crabby-images/6b3e0/6b3e00f55977240d537a0146aa805a09266790d7" alt=""
merge
data:image/s3,"s3://crabby-images/f936b/f936bf43cedb2f156e204948abd78d47e391328b" alt=""
merge commit 생성됨
⇒ 일반 merge는 merge할 때마다 merge commit이 생성
실습 - squash merge
data:image/s3,"s3://crabby-images/161f4/161f44b6a41882421b467f6c5c0c1398236bd7d8" alt=""
branch1에서 커밋 3개 만들기
data:image/s3,"s3://crabby-images/16026/160267653fc6bd35deb4e66445297e6e78f028ad" alt=""
push
data:image/s3,"s3://crabby-images/fa634/fa6344381d58c68e2949799bca9a434888c4fabf" alt=""
세개의 커밋을 main에 일반 merge하면 보통 3+merge commit까지 총 네개 됨
data:image/s3,"s3://crabby-images/46094/46094746a298ab2d34b4acc9c48eec9f5fdc3b74" alt=""
create pull request
data:image/s3,"s3://crabby-images/4a079/4a079449daa878b3c5a99913850faa92a04d08e7" alt=""
branch1의 현재 커밋 수 58
data:image/s3,"s3://crabby-images/d742e/d742ec05392c73029868b595bcdc6df22e4e99a2" alt=""
main의 현재 커밋 수 55
→ 여기서 일반 merge하면 main은 59가 될 것 (55+3+1)
data:image/s3,"s3://crabby-images/7c6f3/7c6f330a9477a964a19861d35740cef57721ff42" alt=""
squash merge를 해보자
data:image/s3,"s3://crabby-images/2b4d0/2b4d06e22b22418b5fc6db8402ed168bea740510" alt=""
main의 커밋 수가 56으로 예상과 다름
⇒ squash merge는 commit 내역을 제외하고 merge커밋만 만든다
→ 세 커밋ID를 통합하여 하나의 새로운 커밋ID로 만들어 merge하는 것 → 55+1
data:image/s3,"s3://crabby-images/eca90/eca90b3aa93c82ce5e966e41538dca51eb1043b6" alt=""
문제는 다시 pull request 해보면 merge안된 것처럼 커밋3개가 남아있음
→ branch 삭제 필요
data:image/s3,"s3://crabby-images/ad1a7/ad1a75c28b2a1a76dc2474dd63adb0f51c691cf9" alt=""
branch 삭제 전 main으로 이동하고 삭제해야 함
data:image/s3,"s3://crabby-images/0e7ac/0e7acc93032ef2992484e09efba5222243637e52" alt=""
origin의 branch1도 삭제
data:image/s3,"s3://crabby-images/77dd2/77dd2b5773d1dd19869984dcb901a211b9564c46" alt=""
밀려있는 main도 pull해주기
data:image/s3,"s3://crabby-images/7433c/7433c01bc75c194d89fe9a8544f4bbf4dd950340" alt=""
반영 완료
data:image/s3,"s3://crabby-images/e701d/e701d58ff37d138a06b4bdeced28eab537233177" alt=""
실습 - rebase merge
data:image/s3,"s3://crabby-images/fbc02/fbc029c630e340662c2ff6215f8e90d32eb7a520" alt=""
main 브랜치에서 branch 생성
data:image/s3,"s3://crabby-images/bea78/bea784febc43f42b54a212d7fa99273b47d16cdd" alt=""
commit 2개 생성
data:image/s3,"s3://crabby-images/6e6e0/6e6e000be97dc69052851c3629ff44924d5cf2ab" alt=""
push
data:image/s3,"s3://crabby-images/06e03/06e03a7fbe625219994329e859e7975a3a12dbf5" alt=""
create pull request
data:image/s3,"s3://crabby-images/2779b/2779bd73c9b59a60f03e1a48271aa5452663c232" alt=""
rebase merge
data:image/s3,"s3://crabby-images/c24ae/c24ae88dcca449914d101a7e1a27bc6cec27f574" alt=""
merge 커밋 없이 기존 커밋 내용만 추가됨
data:image/s3,"s3://crabby-images/4a3db/4a3dba107cc3c9b36c867f7173eba30579e49f54" alt=""
main으로 옮기고 rebase 삭제, pull origin main
data:image/s3,"s3://crabby-images/edcae/edcae9a026082ff6f0eed4e6b88c2bc1596f57b8" alt=""
다 최신화 완료
충돌상황 발생 시 merge
main 에서 branch1 생성
data:image/s3,"s3://crabby-images/da74f/da74fd42bb13de80146621206763e364ebcb757d" alt=""
main에서 파일 수정
data:image/s3,"s3://crabby-images/caae3/caae3bef809fdcf5de23d787d31465556982935a" alt=""
commit → push
data:image/s3,"s3://crabby-images/1bd9f/1bd9f5c482717576ce626dba6c9c6ec79fb22e2c" alt=""
branch1으로 변경
data:image/s3,"s3://crabby-images/faa36/faa365f70dec13782b244e7a69b99c40c43f3027" alt=""
동일파일 수정 후 commit
data:image/s3,"s3://crabby-images/f9219/f921915992c934d499cbb93f86a9ae2bb763f8a8" alt=""
여기서 충돌해결방법은 크게 두 가지
- git push origin branch1 → github로 main에서 branch1으로 pr → merge하면서 수정 가능
- pull을 통해 충돌 해결 후 push 및 pr, merge
2번을 해보자
data:image/s3,"s3://crabby-images/2b0e3/2b0e3e50bdafdd38f936c39c1c4d86e648377bba" alt=""
git pull
data:image/s3,"s3://crabby-images/681b2/681b27f6af35bbdd6fed967afe6808c199e66ade" alt=""
충돌 해결 후 add, commit, push
data:image/s3,"s3://crabby-images/39280/3928029f2b4e111d447988c34e2dddc7f1d10888" alt=""
create pull request 후 merge pull request
data:image/s3,"s3://crabby-images/9a211/9a211d1a9c952107710269c874b5e45bea8860c1" alt=""
반영완료
data:image/s3,"s3://crabby-images/fcf89/fcf8966698d4a4acd50b43d4b8315ff97bfc5e85" alt=""
사용한 branch 삭제해주기
data:image/s3,"s3://crabby-images/c0db4/c0db448ff6510769cd88e510d93c58cf6425df82" alt=""
branch1 삭제, origin/branch1도 삭제
data:image/s3,"s3://crabby-images/3f313/3f3136637b29812c7dcda83bbf03949a9ff87473" alt=""
git pull origin main으로 싱크맞추기