Git

[GIT] Github-flow 사용하기

윤동민 2021. 1. 27. 20:40
반응형

Git 브랜치의 전략 중 하나인 Github-flow에 대해 포스팅을 진행해보려고 합니다.

 

이전에는 Git-flow에 대해 진행했었죠..⁉️

 

잘 모르시겠으면 이전 포스팅을 참조하면 좋을 것 같습니다.

 

[GIT] Git-flow 사용하기

Git Flow란 무엇일까요? 여러분들은 브랜치을 생성해서 각 작업 단위들을 구분해본적이 있나요. Git Flow란 바로 이 브랜치 흐름을 표준화시킨 방법(?) 같은 것입니다. 일종의 Branch을 나누는 기법입

dongminyoon.tistory.com

회사에서는 Git-flow가 아닌 Github-flow라는 브랜치 전략을 사용하기 때문에, 공부를 해보려고 합니다..!

 

 

Github-flow

이전의 Git-flow 보다는 조금 더 간단한 브랜치 전략이라고 해요.

 

우선 Git-flow를 살펴보았을 때, 5가지의 브랜치가 존재했죠?

master, develop, hotfix, feature, release

 

그러나 Github-flow에서는 별도의 브랜치가 다수로 분리되어 있지 않아요.

이렇게 그림을 확인해보면 master로부터 모든 브랜치들이 뻗어나오는 것을 알 수 있죠?

그렇기 때문에, master 브랜치는 항상 stable하고 배포가 가능한 상태로 유지해야 합니다.

 

그리고 하나 더 생각해보면 master 브랜치로부터 모든 브랜치가 뻗어나오기 떄문에, 각 브랜치의 이름들이 명확하게 구분되어야 해요.

그렇게 되어야 단순하지만 명확한 브랜치 전략으로 사용할 수 있을 것 같아요.

 

또 중요한 점이 master로 merge를 할 준비가 완료되었을 때는 꼭 PR을 통해 리뷰를 받고 merge를 할 수 있도록 해야합니다..!!

로컬에서 merge를 진행한 후, push를 하는 방식이 아닙니다.

 

제가 생각했을 때, Git-flow에 비해 많이 단순하고 쉬운 방법이어서 Git을 처음 사용하는 사람이 사용하기 좋고 Github에서 제공하는 기능으로 온전히 사용할 수 있는 브랜치 전략이라고 생각이 드네요.

 

 

마지막으로 정리를 해보면,

  • master 브랜치로부터 모든 브랜치가 뻗어나온다.
  • 브랜치의 이름을 명확하게 작성할 필요가 있다.
  • master 브랜치는 언제나 배포가 가능해야하기 때문에, stable 해야한다.
  • master로 merge를 진행하기 위해서는 꼭 PR을 통해 merge를 진행한다.

 

 

반응형