>개발 도구 >자식 >git은 지정된 커밋 정보를 수정합니다.

git은 지정된 커밋 정보를 수정합니다.

WBOY
WBOY원래의
2023-05-20 09:36:0711377검색

버전 관리를 위해 Git을 사용하는 과정에서, 제출된 제출 정보를 수정해야 하는 상황이 불가피하게 발생하게 됩니다. 이는 제출 시 잘못된 정보를 작성했기 때문일 수도 있고, 제출된 코드에 추가 설명을 추가해야 하는 경우 등이 있을 수 있습니다.

다음에는 git을 사용하여 지정된 커밋 정보를 수정하는 방법과 주의할 점을 자세히 소개하겠습니다.

1. git commit --amend를 사용하여 지정된 제출물 수정

제출 시 일부 파일이 누락되었거나 제출된 파일을 수정해야 하는 경우 git commit --amend 명령을 사용하여 지정된 제출 정보를 수정할 수 있습니다.

구체적인 단계는 다음과 같습니다.

  1. git log 명령을 실행하여 수정해야 하는 커밋 레코드 ID를 찾습니다.
  2. git rebase -i HEAD~n(n은 수정해야 하는 커밋 수) 명령을 실행하여 대화형 모드로 들어갑니다.
  3. i 키를 눌러 편집 모드로 들어갑니다.
  4. 수정, 저장, 종료를 위해 수정이 필요한 제출 기록 ID 선택을 변경하세요.
  5. 이전 커밋으로 롤백하려면 git Reset HEAD^ 명령을 실행하세요.
  6. 파일 수정 또는 추가와 같은 작업을 수행합니다.
  7. git add 명령을 실행하여 수정된 파일을 스테이징 영역에 추가합니다.
  8. 제출 정보를 수정하려면 git commit --amend 명령을 실행하세요.
  9. git rebase --continue 명령을 실행하여 제출 정보 수정을 완료합니다.

2. git filter-branch를 사용하여 지정된 커밋을 수정합니다.

커밋 정보를 많이 조정해야 하거나 수행하는 작업이 복잡한 경우 git filter-branch 명령을 사용하여 지정된 커밋을 수정할 수 있습니다. 정보.

구체적인 단계는 다음과 같습니다.

  1. git log 명령을 실행하여 수정해야 하는 커밋 레코드 ID를 찾습니다.
  2. git filter-branch --tree-filter 명령을 실행하고 그 뒤에 수행할 작업을 추가합니다. 예:
git filter-branch --tree-filter 'rm -f file.txt' HEAD

이는 file.txt 파일을 삭제한다는 의미입니다. 제출 정보를 수정해야 하는 경우 다음 명령을 실행할 수 있습니다.

git filter-branch --msg-filter 'sed "s/old_text/new_text/g"' HEAD
  1. git push --force 명령을 실행하여 수정된 정보를 원격 브랜치에 푸시합니다.

3. 참고 사항

  1. 제출 정보를 수정하면 제출의 SHA-1 코드 값이 변경되어 저장소의 참조 분기에 문제가 발생할 수 있습니다.
  2. 로컬 브랜치를 원격 브랜치로 푸시한 경우 git push --force 명령을 사용하여 수정된 커밋 정보를 강제로 푸시해야 합니다. 이는 다른 공동 작업자의 리포지토리에 영향을 미칠 수 있습니다.
  3. 불필요한 오류를 방지하기 위해 제출 정보를 수정하기 전에 백업을 생성하는 것이 좋습니다.
  4. git filter-branch 명령을 사용하여 수정할 때는 주의하세요. 작업이 표준화되지 않은 경우 제출된 다른 정보에 영향을 미칠 수 있습니다.

요컨대 제출 정보 수정은 비교적 복잡한 작업이므로 불필요한 문제가 발생하지 않도록 데이터 보안을 보장하면서 신중하게 수행해야 합니다.

위 내용은 git은 지정된 커밋 정보를 수정합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.