개발도구

Git ] 이전 커밋에서 branch 생성하기

eteo 2024. 1. 16. 22:51

 

 

 

1. 이전 커밋 로그를 확인

git log --oneline

 

 

 

2. 현재 브랜치 확인

git branch

 

 

 

3. 특정 커밋으로부터 새로운 브랜치 생성

git branch <새로운 브랜치명> <커밋해쉬값 앞자리>
ex) git branch feature 9a124ef

 

 

 

4. 새로운 브랜치로 전환

git checkout <새로운 브랜치명>
ex. git checkout feature

 

 

git checkout <브랜치명> 명령어를 사용해 브랜치를 전환하면 해당 브랜치의 헤드로 이동하면서 작업 디렉토리의 파일들도 해당 브랜치의 최신 커밋 상태로 업데이트 된다.

 

위 경우에는 이전 커밋으로부터 새로운 브랜치를 생성했기 때문에 새로운 브랜치의 HEAD는 이전 커밋을 가리키게 되므로 작업 디렉토리가 해당 커밋의 상태로 변경된다.

 

 

 

 

혹은 아래 방법으로 위 두 단계를 한번에 할 수 있다.

 

# 새로운 브랜치 생성 및 이동
git switch -c <새로운 브랜치명> <커밋해쉬값 앞자리>

 

 

 

 

5. 새로운 브랜치에서 변경사항을 추가하고 커밋

 

git add .
git commit -m "Your commit message"

 

 

 

 

6. 새로운 브랜치를 원격에 푸시하면서 원격에 해당 브랜치 생성

 

git push --set-upstream <원격저장소명> <로컬 브랜치명>
또는
git push -u <원격저장소명> <로컬 브랜치명>
ex) git push --set-upstream origin feature

 

 

--set-upstream 플래그를 사용해 push하면 로컬 브랜치를 origin 원격 저장소의 <로컬 브랜치명> 브랜치와 연결한다. 한번 이렇게 하고나면 이후에는 git push 명령어만 사용하여 푸시할 수 있다.

 

예시와 같이 사용했을 땐 원격 저장소에 origin/feature 브랜치가 생성되면서 로컬 feature 브랜치의 변경사항이 원격으로 푸시된다.