찾다
개발 도구자식3가지 동작으로 완료하세요! 깔끔한 Git 커밋 기록 유지

이 글은 "git commit –amend", "git rebase -i" 및 "rebase"와 관련된 문제를 포함하여 Git커밋 기록을 깨끗하게 유지하는 방법에 대한 관련 지식을 제공합니다.

3가지 동작으로 완료하세요! 깔끔한 Git 커밋 기록 유지

추천 학습: "Git Tutorial"

모든 사람이 표준화되고 간결한 방식으로 코드를 작성하는 방법을 배웠지만 표준적이고 간결한 방식으로 코드를 제출하는 방법은 거의 배우지 않습니다. 요즘에는 누구나 기본적으로 Git을 소스 코드 관리 도구로 사용하는데, Git은 다양한 워크플로우에 따라 코드를 제출/병합합니다. 이 유연성이 제대로 제어되지 않으면 많은 문제가 발생합니다

지저분하고 냄새나고 긴 git 로그 기록. 저는 개인적으로 이런 종류의 로그를 좋아하지 않습니다

3가지 동작으로 완료하세요! 깔끔한 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

이 기술을 알면 각 저장소가 제출된 내용 중 유효한 정보가 포함되어 있습니다. 과정을 설명하는 그림은 다음과 같습니다.

3가지 동작으로 완료하세요! 깔끔한 Git 커밋 기록 유지

버프 보너스인 --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

3가지 동작으로 완료하세요! 깔끔한 Git 커밋 기록 유지

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을 제출하고 기능을 메인 분기에 병합할 수 있습니다

에 대한 간단한 설명 병합과 리베이스의 차이점은 다음과 같습니다.

3가지 동작으로 완료하세요! 깔끔한 Git 커밋 기록 유지

여기에서는 git pull Origin main --rebase를 사용하여 메인을 전환하고 최신 콘텐츠를 가져온 다음 다시 전환하는 과정을 생략합니다. 그 뒤에 있는 원리는

여기에 나와 있습니다. rebase를 사용할 때 따라야 할 황금률입니다. 이전에 말했으므로 더 이상 반복하지 않겠습니다.

요약

이 세 가지 팁을 사용하면 모든 사람의 git log가 매우 명확하다고 믿습니다. 아직은 사용할 수 있습니다. 그룹 구성원이 모른다면 확실히 홍보할 수 있습니다. 이런 종류의 저장소는 더 건강해 보일 것입니다.

추천 학습: "Git Tutorial"

위 내용은 3가지 동작으로 완료하세요! 깔끔한 Git 커밋 기록 유지의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 CSDN에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
GIT : 버전 제어의 핵심, Github : 소셜 코딩GIT : 버전 제어의 핵심, Github : 소셜 코딩Apr 23, 2025 am 12:04 AM

Git과 Github는 최신 소프트웨어 개발을위한 핵심 도구입니다. GIT는 리포지토리, 분기, 커밋 및 합병을 통해 코드를 관리 할 수있는 버전 제어 기능을 제공합니다. GitHub는 문제 및 풀 레크와 같은 코드 호스팅 및 협업 기능을 제공합니다. GIT와 GitHub를 사용하면 개발 효율성과 팀 협업 기능을 크게 향상시킬 수 있습니다.

GIT : 버전 제어 시스템, GitHub : 호스팅 플랫폼GIT : 버전 제어 시스템, GitHub : 호스팅 플랫폼Apr 22, 2025 am 12:02 AM

GIT는 2005 년 Linus Torvaz가 개발 한 분산 버전 제어 시스템이며 Github는 2008 년에 설립 된 GIT 기반 코드 호스팅 플랫폼입니다. GIT는 Snapshot Management 파일을 통한 분기 및 병합을 지원하며 Github는 풀 요청, 문제 추적 및 코드 검토 기능을 제공하여 팀 공동 작업을 용이하게합니다.

Git 및 Github : 비교 분석Git 및 Github : 비교 분석Apr 21, 2025 am 12:10 AM

Git과 Github는 최신 소프트웨어 개발의 핵심 도구입니다. GIT는 분산 버전 제어 시스템이며 GitHub는 GIT 기반 코드 호스팅 플랫폼입니다. GIT의 핵심 기능에는 버전 제어 및 지점 관리가 포함되며 Github은 협업 및 프로젝트 관리 도구를 제공합니다. GIT를 사용할 때 개발자는 파일 변경을 추적하고 함께 작업 할 수 있습니다. GitHub를 사용할 때 팀은 PullRequest 및 문제를 통해 협력 할 수 있습니다.

Github : 코드 호스팅 플랫폼 소개Github : 코드 호스팅 플랫폼 소개Apr 20, 2025 am 12:10 AM

githubiscrucialforsoftwaredevelopmentdueToitscompeholecosystemforcodemanagementandcollaboration.itoffersioncontrol, CommunitySupport, 및 Tools -LikeGithUbactionandPages.StartBymasteringbasicslikecreatingAreposority, andautomatingwo

Git 및 Github : 개발자를위한 필수 도구Git 및 Github : 개발자를위한 필수 도구Apr 19, 2025 am 12:17 AM

Git과 Github는 현대 개발자에게 필수 도구입니다. 1. 버전 제어에 GIT를 사용하십시오 : 병렬 개발을위한 분기를 만들고, 분기를 병합하고, 롤백 오류. 2. 팀 협업에 GitHub를 사용하십시오 : 풀 레크를 통한 코드 검토를 통해 병합 충돌을 해결하십시오. 3. 실용적인 팁 및 모범 사례 : 정기적으로 제출하고, 메시지를 명확하게 제출하고, .gitignore를 사용하고, 코드 기반을 정기적으로 백업하십시오.

Git and Github : 그들의 관계가 설명되었습니다Git and Github : 그들의 관계가 설명되었습니다Apr 18, 2025 am 12:03 AM

Git과 Github는 동일하지 않습니다. Git은 분산 버전 제어 시스템이며 Github는 Git을 기반으로 한 온라인 플랫폼입니다. GIT는 개발자가 코드 버전을 관리하고 분기, 병합 및 기타 기능을 통해 협업을 달성하도록 도와줍니다. GitHub은 코드 호스팅, 검토, 문제 관리 및 소셜 상호 작용 기능을 제공하여 GIT의 협업 기능을 향상시킵니다.

Git을 다운로드 한 후 무엇을 설정해야합니까?Git을 다운로드 한 후 무엇을 설정해야합니까?Apr 17, 2025 pm 04:57 PM

GIT를 설치 한 후보다 효율적으로 사용하려면 다음 설정이 필요합니다. 사용자 정보 설정 (이름 및 사서함) 텍스트 편집기 선택 외부 병합 도구 생성 SSH 키 설정을 무시하십시오. 파일 모드를 무시하십시오.

GIT 다운로드가 활성화되지 않은 경우해야 할 일GIT 다운로드가 활성화되지 않은 경우해야 할 일Apr 17, 2025 pm 04:54 PM

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

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

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

뜨거운 도구

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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