본문 바로가기

Git

[Git] remote repository에 올라간 커밋 취소하기

반응형

제목이 조금 이상하게 느껴지셨을 수도 있습니다. 커밋을 취소하려면 리셋을 쓰면 되지 않을까요? 반은 맞지만 반은 틀린 말입니다. 만약 로컬 레포지터리에서만 작업을 하는 상황이면 리셋을 사용하면 됩니다. 하지만 리모트 레포지터리에서 같이 작업을 할 때는 리셋을 쓸 수가 없습니다. 그 이유를 살펴보겠습니다.

아래 그림은 리모트 레포지터리에서 내용을 수정하고 커밋을 한 뒤에 로컬 레포지터리에 푸쉬를 한 상황입니다.

 

 

세 번째 커밋으로 reset을 하면 아래 그림과 같을 것입니다.

 

 

자 그런데 이 상태에서 푸시를 하면 어떻게 될까요? 당연히 오류가 나겠죠! 왜냐하면 리모트 레포지터리에 더 최신 커밋이 있기 때문입니다. 그럼....어떻게 하면 리모트 레포지터리에서 세 번째 커밋으로 돌아갈 수 있을까요? 우선 저희는 로컬 레포지터리의 최신 커밋이 리모트 레포지터리의 최신 커밋보다 더 최신이면 푸시를 할 수 있다는 사실을 알고 있습니다. 그 말은 로컬 레포지터리에 커밋을 한개 추가한 뒤에 푸시를 해주면 오류가 나지 않는다는 소리입니다. 그러면 로컬 레포지터리에서 세 번째 커밋을 복사해서 네번째 커밋 다음에 붙여주면 되지 않을까요? 이걸 가능하게 해주는 명령어가 revert입니다. ' git revert 해시아이디 ' 명령어를 입력하면 다음 커밋이 입력한 해시아이디의 이전 커밋과 일치하게 됩니다. 그러니깐 입력한 해시 아이디의 이전 커밋으로 돌아가는거라고 할 수 있죠. 아래 그림을 참고하세요.

 

 

이제 푸시를 하게 되면 리모트 레포지터리가 아래 그림처럼 되겠죠? 이게 바로 reset 대신 revert를 사용하는 이유입니다.

 

 

revert를 약간 응용하면 리모트 레포지터리에서 여러 커밋을 취소하는 것도 가능해집니다. git history를 먼저 살펴보겠습니다.

 

 

여기서 빨간색 부분을 취소해보겠습니다. 명령어는 아래와 같습니다.

$ git revert 5896..6aa3

여기서 해시아이디의 범위가 약간 헷갈립니다. 범위를 자세히 보면 지우려는 커밋은 두 개인데 5896은 지우려는 커밋에 포함되지 않는 커밋입니다. 두 개 이상의 연속적인 커밋을 지울때는 커밋 범위의 시작점은 지우려는 커밋의 이전 커밋임을 유의해주시기를 바랍니다. 위 명령어를 입력하면 README.md에서 '하하하'와 '라라라'가 지워져야합니다.

revert하기 전 README.md의 모습입니다.

 

 

$ git revert 5896..6aa3 명령어를 입력하면 아래와 같이 뜨는데요, 그대로 저장하겠습니다.

 

 

README.md 가 제대로 고쳐졌음을 확인할 수 있습니다. 이제 다시 push를 하면 리모트 레포지터리에 그대로 반영되겠죠?

반응형

'Git' 카테고리의 다른 글

[Git] 명령어 정리  (0) 2022.01.14
[Git] 작업 내용 임시 저장하기 - stash  (0) 2022.01.14
[Git] 누가 기록했는지 확인하기  (0) 2022.01.14
[Git] git pull시 주의점  (0) 2022.01.14
[Git] merge 완전정복  (0) 2022.01.14