본문 바로가기

Git

[Git] 커밋 파헤치기2 - 이전 커밋으로 돌아가기(reset)

반응형

커밋은 연결 리스트 형식으로 저장되어 있습니다. git log로 커밋 이력들을 살펴보면 가장 최신 커밋에 'HEAD→MASTER'라고 적혀있습니다. HEAD는 가장 최신 커밋을 가리키고 있습니다. 그림으로 보면 저장된 커밋들은 아래와 같은 구조를 이루고 있습니다. 사실 엄밀하게 말하면 HEAD는 브랜치를 가리키는데 이는 브랜치를 배우고 나서 다시 자세히 다루겠습니다.

HEAD는 왜 있을까요? 만약 HEAD가 다른 곳을 가리킬 수 있다면 HEAD를 이용해서 이전 커밋으로 돌아갈 수 있겠죠? HEAD를 움직이는 명령어는 reset입니다. 그런데 reset에는 세 가지 옵션이 있습니다. 각 옵션에 따라 working directory, staging area, repository가 약간 다른 방식으로 바뀝니다.

reset의 세 가지 옵션

1. git reset --hard 해시ID
2. git reset --mixed 해시ID
3. git reset --soft 해시ID

 

옵션에 따라 working directory, staging area, repository가 어떻게 바뀌는지 표로 정리해보았습니다. 이 개념을 이해하기 위해서는 working directory, staging area, repository의 개념을 완벽하게 이해해야합니다.

아래 표는 커밋 아이디가 'ab2d'인 커밋으로 돌아가는 경우입니다.

 

 

mixed 옵션을 예로 들어 보겠습니다. 프로젝트를 진행하다가 마음에 안 들어서 reset --mixed를 통해 이전 버전으로 돌아간 경우를 생각해봅시다. 그러면 지금까지 add 했던 것들은 다 날아가 버립니다. staging area가 이전 커밋처럼 바뀌기 때문이죠. repository도 마찬가지겠네요. 만약 깃허브에 push를 한다면 방금까지 작업했던 작업물이 아닌 이전 버전의 작업물이 push될 것입니다. 다행이도 working directory는 변함이 없습니다. 즉 방금까지 작업했던 코드 파일 자체는 그대로 보존되어 있습니다. 이를 응용하면 마음에 안 드는 특정 커밋을 취소할 수 있습니다. 아래 그림에서 'Add print 5' 커밋을 지우려면 어떻게 해야할까요?

 

방법은 간단합니다! 우선 현재 워킹디렉터리의 모습은 가장 최신 커밋의 모습과 같다고 가정하겠습니다. mixed 옵션으로 'Add print.py print(3)' 커밋으로 reset하면 현재 워킹렉터리는 변함없겠죠? 그럼 git add 를 해주고 다시 커밋을 하면 'Add print 5' 커밋이 삭제된 것과 같은 효과를 얻을 수 있겠네요.

soft, hard 옵션도 잘 생각해보세요!

마지막으로 꿀팁 하나만 알려드리겠습니다. ' git cherry-pick [커밋 아이디] ' 명령어를 쓰면 필요한 커밋만 가져올 수 있습니다. 프로젝트를 진행하다가 다른 사람이 구현한 함수 하나를 가져오고 싶은 경우 cherry-pick를 사용하면 됩니다. 이는 다른 브랜치의 커밋도 가져올 수 있기 때문에 아주 유용합니다. 브랜치에 대한 소개는 이후에 하겠습니다. 그러니깐

$ git log

로 커밋 이력들을 쭉 살펴보면서 마음에 드는 커밋을

$ git cherry-pick 커밋아이디

로 나의 워킹디렉터리 가져올 수 있습니다.

 

반응형

'Git' 카테고리의 다른 글

[Git] branch merge 해보기  (0) 2022.01.14
[Git] branch 소개  (0) 2022.01.14
[Git] 커밋 파헤치기1- 커밋 해보기  (0) 2022.01.14
[Git] 다른 사람에게 git push 권한 부여  (0) 2022.01.14
[Git] GitHub에 파일 옮기기  (3) 2022.01.14