git을 혼자만 쓰다보니 쓰는 기능이 한정되어 있고, 직전 실무는 SVN을 썼고 브랜치 전략이란게... 없었다.
아주 오래전 git flow 를 경험해본적이 있지만 잘 기억이 나지 않아 한번 정리해보았다.
git master branch의 default name
master vs main
예전에는 master로 default name이 사용됨
요즘에는 main이 default name으로 생성됨
origin : remote repository url을 참조하기 위한 alias같은 것.
remote: origin이 참조하는 remote repository에 특정 커맨드를 수행하기 위해 사용하는 커맨드
data:image/s3,"s3://crabby-images/e6a3c/e6a3cca862ef067f3577e18340ca10c384006d13" alt=""
pull과 fetch의 차이
pull: remote repository의 내용을 가져와 자동 병합 (fetch + merge)
fetch: remote repository의 내용을 확인하고 로컬 데이터와 병합은 하고 싶지 않은 경우 사용
fetch를 실행하면 최신 커밋 이력을 이름없는 브랜치로 로컬에 가져옴
FETCH_HEAD로 체크아웃 가능
git flow 기본 개념
main: backbone과 같은 중심기점 브랜치, 운영 소스
stage:
develop: 개발 서버에 배포되는 브랜치
relase(임시)
feature(임시): 이슈 브랜치, 기능 별 브랜치
hotfix(임시): 배포된 소스코드에 버그가 발견되면 생성하여 관리하는 브랜치
git 연습
main, develop 브랜치로 이것 저것 연습해볼까 한다.
1. main, develop repository 생성
1-1. main 브랜치 생성
일단 기본적으로 repository를 생성하고 git clone을 하면 main 브랜치가 생성됨
data:image/s3,"s3://crabby-images/3b956/3b9560d2d1cd503b43d6f3c598e6aeb3c5ad482e" alt=""
data:image/s3,"s3://crabby-images/4f845/4f845f462368911db8e6a7be77374508e3e30ab0" alt=""
1-2. develop 브랜치 만들기
data:image/s3,"s3://crabby-images/53ce7/53ce782b8c46a72495bd298c1cf0ad6903c45731" alt=""
아직 로컬에만 만들어진 상태이다.
리모트에 올려보자.
data:image/s3,"s3://crabby-images/9f1a3/9f1a3e4fa12c5bff37baea5c582faa57c903475a" alt=""
1-3. main에 직접 소스를 push 할 수 없도록 브랜치 설정을 github에서 해보자.
github > settings > branch
pull request를 통해서 merge 하도록 설정
직접 push못하게 막음
data:image/s3,"s3://crabby-images/95335/95335f58a2db1647844c41f49165062675e5b09d" alt=""
data:image/s3,"s3://crabby-images/58ce5/58ce55164c051ef934421141af0703ab1b5c900d" alt=""
2. feature 브랜치 생성해서 작업하고 develop에 merge, main에 pull request까지
feature브랜치는 기본적으로 develop브랜치에서 딴다고 함. (프로젝트 별로 다를 수 있음)
나는 main에서 따봤는데, 일반적으로 hotfix가 이런식으로 진행됨
data:image/s3,"s3://crabby-images/54e76/54e763203e420e348fb513195262471dda4ca3d9" alt=""
data:image/s3,"s3://crabby-images/ef0a5/ef0a5abe5183690fd99979cccfb2b89c30036a63" alt=""
2-1. feature 브랜치 만들어서 작업후 커밋, 푸쉬
2-2. develop에 feature 변경점 merge하기
data:image/s3,"s3://crabby-images/56abf/56abfb47511d8d23b5c26f321ca105d397c96c4c" alt=""
2-3. main에 pull request하기
github > pull request
data:image/s3,"s3://crabby-images/5e5bf/5e5bf7d2dd4e5aa10be49cbda7129efb19e407e7" alt=""
3. cherry pick 써보기
특정 commit만 찝어서 현재 Head가 가리키는 branch에 추가하는 방법
3-1. feature 브랜치에서 commit 두 번 수행
commit1) commit1파일 생성
commit2) commit2파일 생성
3-2. git develop으로 체크아웃 후, 체리픽으로 feature 브랜치에서 수행한 커밋중
마지막 커밋내용(커밋 hash) 을 추가해보기
data:image/s3,"s3://crabby-images/84e98/84e981af1f8348c397ed1c21829a3a4ea14ea849" alt=""
4. rebase
4-1. main 에서 feature3 브랜치 생성
git checkout main
git branch feature3
4-2. main 작업
C1, C2
PS C:\Workspace\git-flow-practice> git add .
PS C:\Workspace\git-flow-practice> git commit -m 'C1'
[main 5469492] C1
1 file changed, 1 insertion(+), 3 deletions(-)
PS C:\Workspace\git-flow-practice> git add .
PS C:\Workspace\git-flow-practice> git commit -m 'C2'
[main 84be1d5] C2
1 file changed, 2 insertions(+)
PS C:\Workspace\git-flow-practice> git push origin main
4-3. feature 작업
PS C:\Workspace\git-flow-practice> git add .
PS C:\Workspace\git-flow-practice> git commit -m 'C3'
[feature3 708e983] C3
1 file changed, 0 insertions(+), 0 deletions(-)
create mode 100644 feature.js
PS C:\Workspace\git-flow-practice> git add .
PS C:\Workspace\git-flow-practice> git commit -m 'C4'
[feature3 a8a5014] C4
1 file changed, 3 insertions(+)
PS C:\Workspace\git-flow-practice> git add .
PS C:\Workspace\git-flow-practice> git commit -m 'C5'
PS C:\Workspace\git-flow-practice> git push origin feature3
4-4. rebase main & squash commit
data:image/s3,"s3://crabby-images/91531/91531fce769f2820bccc593f7d0a5f64dbebd83d" alt=""
:wq
commit 메시지 수정
data:image/s3,"s3://crabby-images/b520f/b520f913e4f608ba2c6507714f13e7a121ed93db" alt=""
data:image/s3,"s3://crabby-images/390c4/390c4a1d7ed14565022df73477305b99f08a596c" alt=""
4-5. git push
이미 push된 상태라면 --force
그냥 push하면 아래와 같은 에러
리모트의 변경사항과 호환되지 않아서인듯
data:image/s3,"s3://crabby-images/7638b/7638bb72491e5524f2332f3853965f297a164a8c" alt=""
force push후 git graph
data:image/s3,"s3://crabby-images/e8127/e81273fab24a70d5bc8d44cbbe2cb2f80f5eae48" alt=""
4-6. 충돌 났을 때는?
충돌 파일 해결 후
git add .
git rebase --continue
continue 하면 해당 commit의 message 수정할 수 있는데
초반에 여러 커밋을 squash 한다고 설정했다면 그냥 넘어가면됨
마지막에 전체 커밋 메시지 수정하는 페이지에서 수정하면 됨
'💻IT' 카테고리의 다른 글
[HTTP완벽가이드] 캐시 (1) | 2023.10.16 |
---|---|
[HTTP 완벽가이드] TCP 커넥션 관리 (4) | 2023.08.31 |
[Kotiln] No default constructor for entity (0) | 2023.03.27 |
[클라우드 네이티브] 클라우드 네이티브 기술이란? (0) | 2022.04.07 |
[jqxGrid] cellsrenderer not working (callback function not called) (0) | 2022.01.27 |