Else
잘못 push 한 것 강제로 복구하는 방법
공부하곰
2024. 11. 18. 16:59
728x90
반응형
예: 내가 work → master 한 후 push해야되는데 master → work 한 후 push해버렸다.
로컬 work 브랜치를 이전 상태로 되돌리고 이를 force push 해야 됨.
1. git reflog로 이전 상태 확인
여기서 work 브랜치가 정상적으로 작업되었던 시점의 커밋 해시를 찾아야 된다.
예: abcd123 (HEAD -> rfid-working)와 같은 커밋 해시를 확인.
reset한 거 등등 아주 다양한 기록이 나와서 찾기 어려웠다.
이건 그냥 쓰고 있는 깃 툴에서 원하는 시점의 해시 값을 가지고 왔다.
2. 브랜치를 해당 커밋으로 되돌리기
정상적인 커밋 해시를 찾았다면 아래 명령어를 실행
git reset --hard <정상 커밋 해시>
나는 github desktop을 쓰고 있는데 reset이 안 돼서 그냥 git bash 켜서 했다.
3. 잘못된 push를 강제로 덮어쓰기
-- force 옵션으로 강제 푸시: git push --force
4. 정상 상태로 돌아온 후 원하는 작업을 진행
이렇게 하면 이전에 이상하게 머지됐던 branch 모양(?)흔적(?)도 사라진다.
728x90
반응형