data:image/s3,"s3://crabby-images/9be26/9be26510ce65d9388a66c6add066b787b533ecab" alt=""
[Git] 특정 커밋 수정하기
ETC작업 전 주의사항
강제 푸시를 실행해야 하기 때문에 공동 작업자가 있을 경우 Git이 꼬이지 않도록 협의 후 진행한다.
수정할 커밋 확인
feat: two를 수정하기 위해 그 직전 커밋 해시를 복사한다.
shell
git log
data:image/s3,"s3://crabby-images/d1a1d/d1a1d2ded8ff1573a252343821dc3a1a1c97b4ee" alt=""
git log
커밋을 수정할 수 있도록 설정
git rebase 명령어를 대화형으로 실행한다.
text
git rebase -i {commit_hash or HEAD}
git rebase --interactive {commit_hash or HEAD}
shell
git rebase --interactive 8a7b752c75de3b60c4e316de10dec5b567a0b0f5
지정한 커밋 해시 다음부터 현재(HEAD) 범위에 있는 모든 커밋이 표시된다.
data:image/s3,"s3://crabby-images/edbe8/edbe8f587772dd78ce1188163651a699dea1e92b" alt=""
수정할 커밋 앞에 표시되어 있는 pick을 edit으로 변경하고 저장한다.
data:image/s3,"s3://crabby-images/c3a40/c3a40606cecd541c97525b5f04c9be5263ea4409" alt=""
저장이 완료되면 안내 문구가 표시된다. 커밋을 수정 처리하는 명령어들로 다음 순서 후 실행한다.
data:image/s3,"s3://crabby-images/66667/666673ad29cb981419cf92448e515d2bfca0cbc6" alt=""
커밋 수정
파일 수정을 진행한다.
수정이 완료되면 git add로 Git 준비(staging) 영역에 추가한 후 커밋한다.
shell
git commit --amed
화면에 표시되는 커밋 내용은 :q로 빠져나온다.
data:image/s3,"s3://crabby-images/b2484/b2484e89beb49153504eba4fca39aa7cd4425ec3" alt=""
data:image/s3,"s3://crabby-images/d1605/d1605be4365185da18587f52d3411de8a24ecef3" alt=""
git rebase를 완료한다.
shell
git rebase --continue
data:image/s3,"s3://crabby-images/800b2/800b27d24d40c7a183f4ee62d85d70fd48d8b046" alt=""
변경 확인
git log로 수정한 커밋부터 최신 커밋까지 커밋 해시가 바뀐 것을 확인할 수 있다. git status에서는 몇 개가 변경되었는지 확인할 수 있다.
data:image/s3,"s3://crabby-images/2aa1c/2aa1c686dc0d3e08c6d092933ff4e866a056dcd0" alt=""
적용
강제 푸시로 원격 브런치를 덮어쓴다.
shell
git push origin dev --force
data:image/s3,"s3://crabby-images/b78fb/b78fb0f84bd3df5448764de0937923ff7cba979e" alt=""
Reference
https://docs.github.com/ko/get-started/using-git/using-git-rebase-on-the-command-line
https://homoefficio.github.io/2017/04/16/Git-과거의-특정-커밋-수정하기
https://ios-development.tistory.com/1355