wrkbrs
git revert, reset을 통한 소스 복구 방법 본문
git revert, reset을 통한 소스 복구 방법입니다.
복구하려는 2~3개 커밋 전이라면 revert를, 그보다 훨씬 전이라면 reset을 통해 복구하면됩니다.
revert를 통한 복구
복구 시점 이후에 커밋이 많지않거나 merge 커밋이 없는 경우에 사용.
실제로 사고 발생시 merge 커밋이 없는 경우가 거의 없기 때문에 잘 사용하진 않음.
1) git revert -n [커밋id]
2) git commit -m "커밋 메시지"
3) git push [target]
예) git revert -n a123
git revert -n b456
git revert -n c789
git commit -m "Revert roll back"
git push origin [branch]
reset을 통한 복구
복구 시점 이후에 커밋이 많을 경우에 사용.
소스가 잘못올라간것을 뒤늦게 발견한 경우에는 revert 보다 이게 훨씬 편하다.
단, 커밋 이력이 날아갈수 있기때문에 반드시 주의해서 사용해야함.
reset 후 다시 reset으로 최신으로 돌아오는 이유는 커밋 이력을 유지하기 위함이다.
1) git reset --hard [복구시점 커밋id]
2) .git 폴더를 제외한 모든 소스 백업
3) git reset --hard [마지막 커밋id]
4) 백업한 소스 덮어쓰기
5) git add .
6) git commit -m "Reset roll back"
7) git push origin [branch]
출처: https://donggov.tistory.com/29 [동고랩]
'Git' 카테고리의 다른 글
Git 과거의 특정 커밋 수정하기 (0) | 2019.11.22 |
---|---|
git rebase -i 사용하기 (0) | 2019.11.22 |
[Git] 명령어(5) - reset, revert (0) | 2019.11.22 |
Git remote branch 가져오기 (0) | 2019.11.13 |
[Git] git 원격저장소 branch 가져오기 (0) | 2019.11.13 |