목차
git commit –amend
git rebase -i를 사용하세요
리베이스를 잘 활용하세요
요약
개발 도구 자식 3가지 동작으로 완료하세요! 깔끔한 Git 커밋 기록 유지

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

Feb 22, 2022 pm 06:01 PM
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 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 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

GO에서 플로팅 포인트 번호 작업에 어떤 라이브러리가 사용됩니까? GO에서 플로팅 포인트 번호 작업에 어떤 라이브러리가 사용됩니까? Apr 02, 2025 pm 02:06 PM

Go Language의 부동 소수점 번호 작동에 사용되는 라이브러리는 정확도를 보장하는 방법을 소개합니다.

Gitee Pages 정적 웹 사이트 배포 실패 : 단일 파일 문제를 해결하고 해결하는 방법 404 오류? Gitee Pages 정적 웹 사이트 배포 실패 : 단일 파일 문제를 해결하고 해결하는 방법 404 오류? Apr 04, 2025 pm 11:54 PM

GiteEpages 정적 웹 사이트 배포 실패 : 404 오류 문제 해결 및 해결시 Gitee ...

H5 프로젝트를 실행하는 방법 H5 프로젝트를 실행하는 방법 Apr 06, 2025 pm 12:21 PM

H5 프로젝트를 실행하려면 다음 단계가 필요합니다. Web Server, Node.js, 개발 도구 등과 같은 필요한 도구 설치. 개발 환경 구축, 프로젝트 폴더 작성, 프로젝트 초기화 및 코드 작성. 개발 서버를 시작하고 명령 줄을 사용하여 명령을 실행하십시오. 브라우저에서 프로젝트를 미리보고 개발 서버 URL을 입력하십시오. 프로젝트 게시, 코드 최적화, 프로젝트 배포 및 웹 서버 구성을 설정하십시오.

GO의 어떤 라이브러리가 대기업에서 개발하거나 잘 알려진 오픈 소스 프로젝트에서 제공합니까? GO의 어떤 라이브러리가 대기업에서 개발하거나 잘 알려진 오픈 소스 프로젝트에서 제공합니까? Apr 02, 2025 pm 04:12 PM

GO의 어떤 라이브러리가 대기업이나 잘 알려진 오픈 소스 프로젝트에서 개발 했습니까? GO에 프로그래밍 할 때 개발자는 종종 몇 가지 일반적인 요구를 만납니다.

Beego ORM의 모델과 관련된 데이터베이스를 지정하는 방법은 무엇입니까? Beego ORM의 모델과 관련된 데이터베이스를 지정하는 방법은 무엇입니까? Apr 02, 2025 pm 03:54 PM

Beegoorm 프레임 워크에서 모델과 관련된 데이터베이스를 지정하는 방법은 무엇입니까? 많은 Beego 프로젝트에서는 여러 데이터베이스를 동시에 작동해야합니다. Beego를 사용할 때 ...

Redis Stream을 사용하여 GO Language에서 메시지 대기열을 구현할 때 User_ID 유형 변환 문제를 해결하는 방법은 무엇입니까? Redis Stream을 사용하여 GO Language에서 메시지 대기열을 구현할 때 User_ID 유형 변환 문제를 해결하는 방법은 무엇입니까? Apr 02, 2025 pm 04:54 PM

Go Language에서 메시지 대기열을 구현하기 위해 Redisstream을 사용하는 문제는 Go Language와 Redis를 사용하는 것입니다 ...

H5 페이지 생산에는 지속적인 유지 보수가 필요합니까? H5 페이지 생산에는 지속적인 유지 보수가 필요합니까? Apr 05, 2025 pm 11:27 PM

코드 취약점, 브라우저 호환성, 성능 최적화, 보안 업데이트 및 사용자 경험 개선과 같은 요소로 인해 H5 페이지를 지속적으로 유지해야합니다. 효과적인 유지 관리 방법에는 완전한 테스트 시스템 설정, 버전 제어 도구 사용, 페이지 성능을 정기적으로 모니터링하고 사용자 피드백 수집 및 유지 관리 계획을 수립하는 것이 포함됩니다.

해외 버전의 배송 지역 데이터를 얻는 방법은 무엇입니까? 기성품 리소스는 무엇입니까? 해외 버전의 배송 지역 데이터를 얻는 방법은 무엇입니까? 기성품 리소스는 무엇입니까? Apr 01, 2025 am 08:15 AM

질문 설명 : 해외 버전의 배송 지역 데이터를 얻는 방법은 무엇입니까? 기성품 자원이 있습니까? 국경 간 전자 상거래 또는 세계화 된 비즈니스에서 정확하게 ...

See all articles