3가지 동작으로 완료하세요! 깔끔한 Git 커밋 기록 유지
이 글은 "git commit –amend", "git rebase -i" 및 "rebase"와 관련된 문제를 포함하여 Git커밋 기록을 깨끗하게 유지하는 방법에 대한 관련 지식을 제공합니다.
추천 학습: "Git Tutorial"
모든 사람이 표준화되고 간결한 방식으로 코드를 작성하는 방법을 배웠지만 표준적이고 간결한 방식으로 코드를 제출하는 방법은 거의 배우지 않습니다. 요즘에는 누구나 기본적으로 Git을 소스 코드 관리 도구로 사용하는데, Git은 다양한 워크플로우에 따라 코드를 제출/병합합니다. 이 유연성이 제대로 제어되지 않으면 많은 문제가 발생합니다
지저분하고 냄새나고 긴 git 로그 기록. 저는 개인적으로 이런 종류의 로그를 좋아하지 않습니다
이 문제의 근본 원인은 무작위 코드 제출입니다.
코드가 제출되었습니다. 저장할 수 있는 방법이 있나요? 세 가지 팁으로 문제를 완벽하게 해결할 수 있습니다
git commit –amend
를 잘 활용하세요. 이 명령의 도움말 문서는 다음과 같이 설명되어 있습니다.
--amend amend previous commit
즉, 마지막 커밋
을 수정하는 데 도움이 될 수 있습니다. 제출한 메시지를 수정할 수 있고, 제출한 파일을 수정하고 마지막 커밋 ID를 바꿀 수 있습니다
제출할 때 특정 파일이 누락될 수도 있고, 다시 제출할 때 여러 오류가 발생할 수 있습니다. -id, 모두가 이 작업을 수행하면 git 로그가 점점 더 지저분해져서 완전한 기능을 추적할 수 없게 됩니다
그런 로그 정보가 있다고 가정합시다
* 98a75af (HEAD -> feature/JIRA123-amend-test) feat: [JIRA123] add feature 1.2 * 119f86e feat: [JIRA123] add feature 1.1 * 5dd0ad3 feat: [JIRA123] add feature 1 * c69f53d (origin/main, origin/feature/JIRA123-amend-test, origin/HEAD, main) Initial commit
마지막 로그 메시지를 수정하고 싶다고 가정하면 다음을 사용할 수 있습니다. 명령:
git commit --amend -m "feat: [JIRA123] add feature 1.2 and 1.3"
로그 정보를 다시 살펴보겠습니다. 기존 커밋 ID 98a75af를 새 커밋 ID 5e354d1로 바꾸고, 메시지를 수정했으며, 노드를 추가하지 않았습니다
* 5e354d1 (HEAD -> feature/JIRA123-amend-test) feat: [JIRA123] add feature 1.2 and 1.3 * 119f86e feat: [JIRA123] add feature 1.1 * 5dd0ad3 feat: [JIRA123] add feature 1 * c69f53d (origin/main, origin/feature/JIRA123-amend-test, origin/HEAD, main) Initial commit
이제 파일을 확인할 수 있습니다.
. ├── README.md └── feat1.txt 0 directories, 2 files
기능 1.3을 제출할 때 구성 파일 config.yaml을 잊어버렸고 로그를 수정하거나 새 커밋 ID를 추가하고 싶지 않다고 가정하면 다음 명령을 사용하기가 매우 쉽습니다.
echo "feature 1.3 config info" > config.yaml git add . git commit --amend --no-edit
git commit --amend --no-edit가 핵심입니다. 현재 repo 파일을 살펴보겠습니다.
. ├── README.md ├── config.yaml └── feat1.txt 0 directories, 3 files
git log를 살펴보겠습니다.
* 247572e (HEAD -> feature/JIRA123-amend-test) feat: [JIRA123] add feature 1.2 and 1.3 * 119f86e feat: [JIRA123] add feature 1.1 * 5dd0ad3 feat: [JIRA123] add feature 1 * c69f53d (origin/main, origin/feature/JIRA123-amend-test, origin/HEAD, main) Initial commit
이 기술을 알면 각 저장소가 제출된 내용 중 유효한 정보가 포함되어 있습니다. 과정을 설명하는 그림은 다음과 같습니다.
버프 보너스인 --no-edit를 사용하면 더욱 강력해집니다.
git rebase -i를 사용하세요
위의 로그를 보면 기능을 개발 중입니다. 1. 기능 브랜치를 메인 브랜치에 병합하기 전에 로그 커밋 노드를 계속 병합해야 합니다. 이는
git rebase -i HEAD~n
에서 사용됩니다. 여기서 n은 마지막 몇 개의 커밋을 나타냅니다. 위에서는 기능 1에 대한 3개의 커밋이 있으므로 다음을 사용할 수 있습니다.
git rebase -i HEAD~3
실행 후 vim 편집기에 다음 내용이 표시됩니다.
1 pick 5dd0ad3 feat: [JIRA123] add feature 1 2 pick 119f86e feat: [JIRA123] add feature 1.1 3 pick 247572e feat: [JIRA123] add feature 1.2 and 1.3 4 5 # Rebase c69f53d..247572e onto c69f53d (3 commands) 6 # 7 # Commands: 8 # p, pick <commit> = use commit 9 # r, reword <commit> = use commit, but edit the commit message 10 # e, edit <commit> = use commit, but stop for amending 11 # s, squash <commit> = use commit, but meld into previous commit 12 # f, fixup <commit> = like "squash", but discard this commit's log message 13 # x, exec <command> = run command (the rest of the line) using shell 14 # d, drop <commit> = remove commit 15 # l, label <label> = label current HEAD with a name 16 # t, reset <label> = reset HEAD to a label 17 # m, merge [-C <commit> | -c <commit>] <label> [# <oneline>] 18 # . create a merge commit using the original merge commit's 19 # . message (or the oneline, if no original merge commit was 20 # . specified). Use -c <commit> to reword the commit message. 21 # 22 # These lines can be re-ordered; they are executed from top to bottom. 23 # 24 # If you remove a line here THAT COMMIT WILL BE LOST. 25 # 26 # However, if you remove everything, the rebase will be aborted. 27 # 28 # 29 # Note that empty commits are commented out</commit></oneline></label></commit></commit></label></label></commit></command></commit></commit></commit></commit></commit>
가장 일반적으로 사용되는 병합 커밋 ID는 squash와 fixup이며, 후자는 여기에서 fixup을 사용하지 않습니다. then :wq Exit
1 pick 5dd0ad3 feat: [JIRA123] add feature 1 2 fixup 119f86e feat: [JIRA123] add feature 1.1 3 fixup 247572e feat: [JIRA123] add feature 1.2 and 1.3
로그를 다시 살펴보니 매우 명확합니다
* 41cd711 (HEAD -> feature/JIRA123-amend-test) feat: [JIRA123] add feature 1 * c69f53d (origin/main, origin/feature/JIRA123-amend-test, origin/HEAD, main) Initial commit
리베이스를 잘 활용하세요
위 기능 1은 완전히 개발되었으며 메인 브랜치도 다른 사람들에 의해 업데이트되었으며 병합됩니다. 기능을 메인 브랜치로 되돌리기 전에, 코드 충돌이 발생할 경우 먼저 메인 브랜치의 내용을 기능에 병합해야 합니다. 병합 명령을 사용하면 추가 병합 노드도 있을 것입니다. 선형이 아닌 로그 기록의 변곡점이므로 여기서는 기능 브랜치에서 rebase 명령을 사용할 수 있습니다
git pull origin main --rebase
pull 명령은 자동으로 병합을 돕지만 여기서는 rebase 형태로 로그를 보세요
* d40daa6 (HEAD -> feature/JIRA123-amend-test) feat: [JIRA123] add feature 1 * 446f463 (origin/main, origin/HEAD) Create main.properties * c69f53d (origin/feature/JIRA123-amend-test, main) Initial commit
feature1 함수의 제출 노드가 main 위에 있거나 선형성을 유지한 다음 코드를 푸시한 다음 PR을 제출하고 기능을 메인 분기에 병합할 수 있습니다
에 대한 간단한 설명 병합과 리베이스의 차이점은 다음과 같습니다.
여기에서는 git pull Origin main --rebase를 사용하여 메인을 전환하고 최신 콘텐츠를 가져온 다음 다시 전환하는 과정을 생략합니다. 그 뒤에 있는 원리는
여기에 나와 있습니다. rebase를 사용할 때 따라야 할 황금률입니다. 이전에 말했으므로 더 이상 반복하지 않겠습니다.
요약
이 세 가지 팁을 사용하면 모든 사람의 git log가 매우 명확하다고 믿습니다. 아직은 사용할 수 있습니다. 그룹 구성원이 모른다면 확실히 홍보할 수 있습니다. 이런 종류의 저장소는 더 건강해 보일 것입니다.
추천 학습: "Git Tutorial"
위 내용은 3가지 동작으로 완료하세요! 깔끔한 Git 커밋 기록 유지의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

GIT를 통해 로컬로 프로젝트를 다운로드하려면 다음 단계를 따르십시오. GIT를 설치하십시오. 프로젝트 디렉토리로 이동하십시오. 다음 명령을 사용하여 원격 저장소 클로닝 : git 클론 https://github.com/username/repository-name.git

GIT 코드를 업데이트하는 단계 : 코드 확인 : git 클론 https://github.com/username/repo.git 최신 변경 사항 가져 오기 : Git Fetch Merge 변경 사항 : GIT 병합 원산지/마스터 푸시 변경 (옵션) : Git Push Origin Master

Git Commit은 프로젝트의 현재 상태에 대한 스냅 샷을 저장하기 위해 파일 변경을 GIT 저장소에 기록하는 명령입니다. 사용 방법은 다음과 같습니다. 임시 저장 영역에 변경 사항 추가 제출 메시지를 저장하고 종료하기 위해 간결하고 유익한 제출 메시지를 작성하여 제출을 완료하기 위해 제출물을 완료하십시오. 제출자에 서명을 추가하여 제출 내용을보기 위해 GIT 로그를 사용하십시오.

GIT 코드 병합 프로세스 : 충돌을 피하기 위해 최신 변경 사항을 가져옵니다. 병합하려는 지점으로 전환하십시오. 병합을 시작하고 병합을 지정합니다. 병합 충돌을 해결하십시오 (있는 경우). 커밋 메시지를 제공하여 병합을 준비하고 커밋합니다.

전자 상거래 웹 사이트를 개발할 때 어려운 문제가 발생했습니다. 대량의 제품 데이터에서 효율적인 검색 기능을 달성하는 방법은 무엇입니까? 기존 데이터베이스 검색은 비효율적이며 사용자 경험이 좋지 않습니다. 일부 연구 후, 나는 검색 엔진 타입을 발견하고 공식 PHP 클라이언트 Typeense/Typeense-PHP를 통해이 문제를 해결하여 검색 성능을 크게 향상 시켰습니다.

해결 : GIT 다운로드 속도가 느리면 다음 단계를 수행 할 수 있습니다. 네트워크 연결을 확인하고 연결 방법을 전환하십시오. GIT 구성 최적화 : 포스트 버퍼 크기를 늘리고 (GIT 구성-글로벌 http.postBuffer 524288000) 저속 제한 (git config --global http.lowspeedlimit 1000)을 줄입니다. git 프록시 (예 : git-proxy 또는 git-lfs-proxy)를 사용하십시오. 다른 git 클라이언트 (예 : Sourcetree 또는 Github 데스크탑)를 사용해보십시오. 화재 보호를 확인하십시오

git 저장소를 삭제하려면 다음 단계를 따르십시오. 삭제하려는 저장소를 확인하십시오. 로컬 리포지토리 삭제 : rm -rf 명령을 사용하여 폴더를 삭제하십시오. 원격으로 창고 삭제 : 창고 설정으로 이동하고 "창고 삭제"옵션을 찾은 후 작동을 확인하십시오.

로컬 git 코드를 업데이트하는 방법은 무엇입니까? Git Fetch를 사용하여 원격 저장소에서 최신 변경 사항을 가져옵니다. Git Merge Origin/& Lt; 원격 지점 이름 & gt; 합병으로 인해 발생하는 갈등을 해결합니다. git commit -m "merge branch & lt; 원격 브랜치 이름 & gt;" 병합 변경 사항을 제출하고 업데이트를 적용합니다.
