Notice
Recent Posts
Recent Comments
Link
«   2024/05   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
Archives
Today
Total
05-17 00:00
관리 메뉴

nomad-programmer

[VCS/Git] git revert: 공개된 커밋의 변경 내역 되돌리기 본문

VCS/Git

[VCS/Git] git revert: 공개된 커밋의 변경 내역 되돌리기

scii 2019. 12. 3. 14:02

이미 공개된 커밋 내역을 수정하는 것은 매우 위험하다. 할 수는 있지만 "절대로" 하면 안된다.

하지만 안전하게 변경 내역을 되돌리는 방법이 있다. 커밋으로 발생한 변경 내역의 반대 커밋을 하면 된다. 즉 추가한 코드는 빼고, 지운 코드는 다시 추가하는 커밋을 하는 것이다.

git revert <커밋 SHA-1 체크섬 값>

이 명령을 특정 지점의 커밋 SHA-1 체크섬 값을 입력하면 해당 지점까지 변경 내역을 취소하게 된다.

ex) git log -5 

git log 명령을 통해 특정 지점의 커밋 SHA-1 체크섬 값을 찾는다. 그 후 git revert 523a 명령을 실행한다. vim 편집기 창이 등장하면서 커밋 메시지를 수정하게 된다. 잘 살펴보면 원래의 커밋 메시지가 큰 따옴표로 묶여 있고 앞에 'Revert'라는 문자가 입력되어 있다.

중요한 것은 실제로 되돌리는 것이 아니라 되돌리는 것 같은 효과를 내는 것이다. 

git revert를 실행한 시점부터, 대상 커밋까지 변경 내역을 거꾸로 적용하는 새 커밋을 만드는 것이다.

이미 공개된 커밋 내역은 이런 안전한 방법으로 되돌려야 한다. 이제 이후에 새로운 브랜치를 만들거나 병합해서 작업할 수 있다.

Comments