php教程 PHP开发 Git 튜토리얼의 브랜치 관리에 대한 자세한 설명

Git 튜토리얼의 브랜치 관리에 대한 자세한 설명

Dec 16, 2016 pm 03:04 PM

Git 브랜치 관리

거의 모든 버전 제어 시스템은 어떤 형태로든 브랜치를 지원합니다. 브랜치를 사용한다는 것은 메인 개발 라인에서 분기하여 메인 라인에 영향을 주지 않고 작업을 계속할 수 있다는 것을 의미합니다.

어떤 사람들은 Git의 분기 모델을 "열반 기능"이라고 부르는데, 바로 그 이유 때문에 Git이 버전 제어 시스템 계열과 구별됩니다.

분기 생성 명령:

git 분기(분기 이름)

분기 전환 명령:

git 체크아웃(브랜치 이름)

브랜치를 전환하면 Git은 작업 디렉터리의 내용을 마지막으로 제출된 브랜치의 스냅샷으로 대체하므로 여러 브랜치에는 여러 디렉터리가 필요하지 않습니다.

브랜치 병합 명령:

git merge

동일한 브랜치를 여러 번 병합하거나 삭제할 수 있습니다. 병합된 브랜치.

Git 브랜치 관리

브랜치 나열

브랜치를 나열하는 기본 명령:

git Branch

매개변수가 없으면 git 브랜치는 로컬 브랜치를 나열합니다.

$ git Branch
* master

이 예의 의미는 "master"라는 브랜치가 있고 이 브랜치가 현재 브랜치라는 것입니다.

git init를 실행하면 Git은 기본적으로 "master" 브랜치를 생성합니다.

브랜치를 수동으로 생성하고 전환하려는 경우. 그냥 git Branch(브랜치 이름)을 실행하세요.

$ git branch testing
$ git branch
* master
 testing
로그인 후 복사

이제 새로운 브랜치 테스트가 있는 것을 볼 수 있습니다.

이런 식으로 마지막 업데이트 커밋 후 새 브랜치를 생성할 때 나중에 업데이트 커밋이 있으면 "testing" 브랜치로 전환하면 Git 작업 디렉터리는 브랜치를 생성했을 때의 상태로 복원됩니다.

다음으로 브랜치를 전환하는 방법을 보여드리겠습니다. git checkout(브랜치)을 사용하여 수정하려는 브랜치로 전환합니다. .

$ ls
README
$ echo 'w3cschool.cc' > test.txt
$ git add .
$ git commit -m 'add test.txt'
[master 048598f] add test.txt
 2 files changed, 1 insertion(+), 3 deletions(-)
 delete mode 100644 hello.php
 create mode 100644 test.txt
$ ls
README test.txt
$ git checkout testing
Switched to branch 'testing'
$ ls
README hello.php
로그인 후 복사

"testing" 분기로 전환했을 때 추가한 새 파일 test.txt가 제거되었습니다. 원래 삭제되었던 hello.php 파일이 다시 나타났습니다. "마스터" 분기로 다시 전환하면 다시 나타났습니다.

$ git checkout master
Switched to branch 'master'
$ ls
README test.txt
로그인 후 복사

또한 git checkout -b(branchname) 명령을 사용하여 새 브랜치를 생성하고 즉시 전환할 수 있습니다. 이 지점에서 운영됩니다.

$ git checkout -b newtest
Switched to a new branch 'newtest'
$ git rm test2.txt 
rm 'test2.txt'
$ ls
README test.txt
$ git commit -am 'removed test2.txt'
[newtest 556f0a0] removed test2.txt
 1 file changed, 1 deletion(-)
 delete mode 100644 test2.txt
$ git checkout master
Switched to branch 'master'
$ ls
README test.txt test2.txt
로그인 후 복사

보시다시피 브랜치를 생성하고 해당 브랜치의 컨텍스트에서 일부 파일을 제거한 다음 마스터 브랜치로 다시 전환했습니다. 돌아왔다.
분기를 사용하여 작업을 분리하면 서로 다른 상황에서 작업을 수행하고 앞뒤로 전환할 수 있습니다.

브랜치 삭제

브랜치 삭제 명령:

git Branch -d(브랜치 이름)

의 경우 예 "testing" 브랜치를 삭제하고 싶습니다.

$ git branch
* master
 testing
$ git branch -d testing
Deleted branch testing (was 85fc7e7).
$ git branch
* master
로그인 후 복사

브랜치 병합

브랜치에 독립적인 콘텐츠가 있으면 결국에는 마스터 브랜치에 다시 병합하고 싶습니다. 다음 명령을 사용하여 모든 분기를 현재 분기로 병합할 수 있습니다.

git merge

$ git branch
* master
 newtest
$ ls
README test.txt test2.txt
$ git merge newtest
Updating 2e082b7..556f0a0
Fast-forward
 test2.txt | 1 -
 1 file changed, 1 deletion(-)
 delete mode 100644 test2.txt
$ ls
README test.txt
로그인 후 복사

위의 예에서는 newtest 사용 브랜치가 메인 브랜치에 병합되고 test2.txt 파일이 삭제됩니다.

병합 충돌

병합은 단순히 파일을 추가하고 제거하는 단순한 작업이 아니라 Git이 수정 사항도 병합합니다.

$ git branch
* master
$ cat test.txt
w3cschool.cc
首先,我们创建一个叫做"change_site"的分支,切换过去,我们将内容改为 www.w3cschool.cc 。
$ git checkout -b change_site
Switched to a new branch 'change_site'
$ vim test.txt 
$ head -1 test.txt 
www.w3cschool.cc
$ git commit -am 'changed the site'
[change_site d7e7346] changed the site
 1 file changed, 1 insertion(+), 1 deletion(-)
로그인 후 복사

수정된 콘텐츠를 "change_site" 브랜치에 제출하세요. 이제 "마스터"로 다시 전환하면 브랜치에서는 test.txt 파일을 다시 수정하기 전의 내용으로 복원된 것을 볼 수 있습니다.

$ git checkout master
Switched to branch 'master'
$ head -1 test.txt 
w3cschool.cc
$ vim test.txt 
$ cat test.txt
w3cschool.cc
新增加一行
$ git diff
diff --git a/test.txt b/test.txt
index 704cce7..f84c2a4 100644
--- a/test.txt
+++ b/test.txt
@@ -1 +1,2 @@
 w3cschool.cc
+新增加一行
$ git commit -am '新增加一行'
[master 14b4dca] 新增加一行
 1 file changed, 1 insertion(+)
로그인 후 복사

이제 이러한 변경 사항이 내 "마스터" 지점에 기록되었습니다. 다음으로 "change_site" 분기를 병합합니다.

$ git merge change_site
Auto-merging test.txt
CONFLICT (content): Merge conflict in test.txt
Automatic merge failed; fix conflicts and then commit the result.
$ cat test.txt 
<<<<<<< HEAD
w3cschool.cc
新增加一行
=======
www.w3cschool.cc
>>>>>>> change_site
로그인 후 복사

이전 브랜치를 "마스터" 브랜치로 병합했는데 병합 충돌이 발생했습니다. 수동으로 수정해야 합니다.

$ vim test.txt 
$ cat test.txt 
www.w3cschool.cc
新增加一行
$ git diff
diff --cc test.txt
index f84c2a4,bccb7c2..0000000
--- a/test.txt
+++ b/test.txt
@@@ -1,2 -1,1 +1,2 @@@
- w3cschool.cc
+ www.w3cschool.cc
 +新增加一行
로그인 후 복사

Git에서는 git add를 사용하여 파일 충돌이 해결되었음을 Git에 알릴 수 있습니다.

$ git status -s
UU test.txt
$ git add test.txt 
$ git status -s
M test.txt
$ git commit
[master 88afe0e] Merge branch &#39;change_site&#39;
로그인 후 복사

이제 병합 충돌을 성공적으로 해결하고 결과를 제출했습니다.

위 내용은 Git 튜토리얼의 Branch 관리에 대한 자세한 설명입니다. 더 많은 관련 글은 PHP 중국어 홈페이지(www.php.cn)를 참고해주세요!


본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 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 옷 제거제

Video Face Swap

Video Face Swap

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

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

GIT 프로젝트를 로컬로 다운로드하는 방법 GIT 프로젝트를 로컬로 다운로드하는 방법 Apr 17, 2025 pm 04:36 PM

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

git에서 코드를 업데이트하는 방법 git에서 코드를 업데이트하는 방법 Apr 17, 2025 pm 04:45 PM

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

Git Commit을 사용하는 방법 Git Commit을 사용하는 방법 Apr 17, 2025 pm 03:57 PM

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

git에서 코드를 병합하는 방법 git에서 코드를 병합하는 방법 Apr 17, 2025 pm 04:39 PM

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

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 데스크탑)를 사용해보십시오. 화재 보호를 확인하십시오

git로 저장소를 삭제하는 방법 git로 저장소를 삭제하는 방법 Apr 17, 2025 pm 04:03 PM

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

PHP 프로젝트에서 효율적인 검색 문제를 해결하는 방법은 무엇입니까? Typesense는이를 달성하는 데 도움이됩니다! PHP 프로젝트에서 효율적인 검색 문제를 해결하는 방법은 무엇입니까? Typesense는이를 달성하는 데 도움이됩니다! Apr 17, 2025 pm 08:15 PM

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

Git에서 로컬 코드를 업데이트하는 방법 Git에서 로컬 코드를 업데이트하는 방법 Apr 17, 2025 pm 04:48 PM

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

See all articles