공동 프로젝트에서 git에 실수로 commit했다면, git commit을 취소하면 된다.
아래 내용은 출처의 내용과 같다. 내가 보기 위해 정리한 것이고, 블로그에 와주신 분들은 출처에도 한 번씩 들어가 봐주시면 좋겠다.
1. git add 취소하기
파일 상태를 Unstage로 변경하기
$ git reset HEAD <file>
명령어를 통해 git add를 취소할 수 있다.
뒤에 파일명이 없으면 add한 파일 전체를 취소한다.
1.1. untracked 파일 삭제하기
git clean 명령은 추적 중이지 않은 파일만 지우는 게 기본 동작이다. 즉, .gitignore 에 명시하여 무시되는 파일은 지우지 않는다.
$ git clean -f // 디렉터리를 제외한 파일들만 삭제
$ git clean -f -d // 디렉터리까지 삭제
$ git clean -f -d -x // ignored 된 파일까지 삭제
2. git commit 취소하기
1. commit을 취소하고 해당 파일들은 staged 상태로 워킹 디렉터리에 보존
$ git reset --soft HEAD^
2. commit을 취소하고 해당 파일들은 unstaged 상태로 워킹 디렉터리에 보존
$ git reset --mixed HEAD^ // 기본 옵션
$ git reset HEAD^ // 위와 동일
$ git reset HEAD~2 // 마지막 2개의 commit을 취소
3. commit을 취소하고 해당 파일들은 unstaged 상태로 워킹 디렉터리에서 삭제
$ git reset --hard HEAD^
2.1. commit message 변경하기
커밋 메세지를 잘못 적은 경우, 아래 명령어를 통해 메세지를 변경할 수 있다.
$ git commit --amend
3. git push 취소하기
이 명령을 사용하면 자신의 local의 내용을 remote에 강제로 덮어쓰기를 하는 것이기 때문에 주의해야 한다.
되돌아간 commit 이후의 모든 commit 정보가 사라지기 때문에 주의해야 한다.
특히, 협업 프로젝트에서는 동기화 문제가 발생할 수 있으므로 팀원과 상의 후 진행하는 것이 좋다.
1. 가장 최근의 commit을 취소한다.
$ git reset HEAD^ // 가장 최근의 commit을 취소 (기본 옵션: --mixed)
2. 원하는 시점으로 워킹 디렉터리를 되돌린다.// Reflog(브랜치와 HEAD가 지난 몇 달 동안에 가리켰었던 커밋) 목록 확인
$ git reflog 또는 $ git log -g // 원하는 시점으로 워킹 디렉터리를 되돌린다.
$ git reset HEAD@{number}
//또는 $ git reset [commit id]
3. 되돌려진 상태에서 다시 commit 한다.
$ git commit -m "Write commit messages"
4. 원격 저장소에 강제로 push 한다.
$ git push -f origin [branch name]
velog.io/@hidaehyunlee/Git-add-commit-push-%EC%B7%A8%EC%86%8C%ED%95%98%EA%B8%B0
'👩💻 Web Programming > GitOps' 카테고리의 다른 글
Git이란? (0) | 2023.07.10 |
---|---|
[GIT] Github에 파일 업로드하기 (0) | 2022.06.26 |
[GIT] Github Repository 완전 복제 (0) | 2021.06.09 |
[GITHUB] GitHub Profile 꾸미기 (0) | 2021.04.02 |