VCS
[VCS/Git] Git-flow 전략
팡트루야
2020. 2. 20. 10:41
Git-flow 전략
Git-flow 전략은 소프트웨어의 소스코드를 관리하고 출시하기 위한 브랜치 관리 전략이다.
꽤 오래 전에 제시된 전략으로, 이를 개선한 Github-flow, Gitlab-flow 전략도 있다.
여튼 Git-flow 전략에는 총 5가지의 브랜치(Branch)가 존재한다.
- master : 제품으로 출시될 수 있는 브랜치 ( 최종 릴리즈 버전 )
master 브랜치에 병합( merge )한다는 것은 새 버전을 배포한다는 의미이다.
master 브랜치에서 커밋이 발생할 때, git hook 스크립트를 걸어서 자동으로 빌드 후 운영 서버로 배포하는 형식을 취한다. - develop : 다음 출시 버전을 개발하는 브랜치
다음에 배포하기 위해 개발하는 코드는 origin/master에서 관리한다. 프로젝트를 진행하는 개발자들이 함께 보며 업무를 진행하는 브랜치이다.
develop 브랜치의 코드가 안정화되고 배포할 준비가 되면 master로 병합( merge )하고 태그( Tag )를 단다. - feature : 기능 단위를 개발하기 위한 브랜치 ( develop 브랜치에서 생성되어 나온 브랜치다. )
- release : 이번 출시 버전을 개발하는 브랜치
- hotfix : 출시 버전( master )에서 발생한 버그를 수정하는 브랜치
아래는 Git-flow 전략 키워드로 검색했을 때 가장 많이 참조되는 그림이다.
참고자료
[1] https://gist.github.com/ihoneymon/a28138ee5309c73e94f9
[2] https://woowabros.github.io/experience/2017/10/30/baemin-mobile-git-branch-strategy.html