찾다
개발 도구자식버전 관리 도구 Git - 지점 관리

Branch는 Git의 킬러 애플리케이션입니다. 다른 버전 제어 도구와 달리 Git은 분기 생성 및 전환에 매우 효율적입니다.

브랜치 소개

브랜치란 무엇인가요? 이제 우리에게 매우 익숙한 시나리오부터 시작해 보겠습니다. 이제 출시된 제품에 새로운 기능이 추가되어야 합니다. 이때 원래 브랜치에서 계속 개발한다면 이미 출시된 애플리케이션이고 출시하기 전에 테스트를 거쳐야 하기 때문에 매우 불편할 것입니다. 일반적으로 우리의 접근 방식은 새 분기를 만들고 이 새 분기에서 새 기능을 개발한 다음 테스트 후 기본 분기에 병합하는 것입니다.

브랜치 생성 및 전환

현재 내 저장소의 브랜치 상황은 다음과 같습니다.

버전 관리 도구 Git - 지점 관리

브랜치 생성

이제 새로운 브랜치인 dev를 생성합니다. 브랜치를 생성하고 브랜치를 보는 명령은 다음과 같습니다.

git branch 分支名
git branch

# git branch dev
# git branch
  dev
* master

Switch Branch

브랜치가 성공적으로 설정되었습니다. 이제 새 브랜치로 전환해 보겠습니다. 브랜치를 전환하는 명령은 다음과 같습니다. git checkout Branch name

# git checkout dev
Switched to branch 'dev'

버전 관리 도구 Git - 지점 관리

이제 새 브랜치에서 몇 가지 수정 사항을 적용한 다음 제출하고 마스터 브랜치로 전환하여 make를 수행합니다. 일부 수정하여 제출합니다. 그런 다음 지점의 상태를 살펴보겠습니다.

git vim config.php # 修改config.php文件
git add . && git commit -m 'add config.php'

git checkout master # 切换到主分支
git vim config.php
git add . && git commit -m 'change config.php'

버전 관리 도구 Git - 지점 관리

$ git log --oneline --decorate --graph --all
* ca4589c (HEAD -> master) add config file
| * 43a5a8f (dev) add config.php
|/
* 19e3186 add index.php
* 9cc82f9 first commit

브랜치 생성 및 브랜치 전환을 완료하는 하나의 명령

git checkout -b 新分支名

브랜치 병합

먼저 매우 일반적인 시나리오를 소개합니다.

  • 시스템은 이미 온라인에 접속하세요

  • 시스템을 새로운 기능으로 업데이트해야 하므로 새 브랜치(dev)를 만들고 이 브랜치에서 작업하세요.

  • 이때 갑자기 시스템에 문제가 발생하여 긴급 조사와 처리가 필요했습니다.

  • 그러면 이때 먼저 온라인 버전(master)으로 전환한 후 새 브랜치를 생성(fixbug)하고 새 브랜치에서 오류를 수정해야 합니다

  • 테스트 완료 후 스위치 그런 다음 Fixbug 분기를 병합하고 변경 사항을 온라인 분기로 푸시합니다.

  • 마지막으로 dev 브랜치로 전환하여 작업을 계속할 수 있습니다.

현재 저장소 상태는 다음과 같습니다.

버전 관리 도구 Git - 지점 관리

이제 새 브랜치를 생성하고 새 브랜치에 새로운 기능을 추가해야 합니다.

git checkout -b dev

그런 다음 새 브랜치에서 몇 가지 사항을 변경하세요.

버전 관리 도구 Git - 지점 관리

이때 온라인에서 심각한 버그가 발견되어 긴급히 처리해야 했습니다. 우선 마스터 브랜치로 전환해야 합니다. 그런데 전환 중에 오류가 발생했습니다

$ git checkout master
error: Your local changes to the following files would be overwritten by checkout:
        login.php
Please commit your changes or stash them before you switch branches.
Aborting

위 오류가 자주 발생하는 이유는브랜치를 병합할 때 작업 공간과 스테이징 영역이 "깨끗"해야 하기 때문입니다. 위의 요구 사항을 충족하는 방법에는 두 가지가 있습니다

  • 변경 사항 제출

  • Staging

여기에서는 임시 저장 방법을 사용하여 설명합니다

$ git stash
$ git checkout master
Switched to branch 'master'

当你切换分支的时候,Git 会重置你的工作目录,使其看起来像回到了你在那个分支上最后一次提交的样子。

现在,我们新建fixbug分支,在这个分支上修复bug。

$ git checkout -b fixbug

合并分支

修复完成且测试通过时,就可以把它合并到master上了。合并使用git  merge 分支名

$ git checkout master Switched to branch 'master' 
$ git merge fixbug

删除分支

这个时候,fixbug功能已经完成了,可以将它给删除掉了。

$ git branch -d fixbug 
Deleted branch fixbug (was cca73bb).

现在,我们可以继续在dev分支上工作了。我们需要把之前暂存的内容取出来。

$ git checkout dev

$ git stash pop
On branch dev
Changes not staged for commit:
  (use "git add <file>..." to update what will be committed)
  (use "git checkout -- <file>..." to discard changes in working directory)

        modified:   login.php

no changes added to commit (use "git add" and/or "git commit -a")
Dropped refs/stash@{0} (2f8476defbaa813e31f3e1b081f5b88416b2ff50)

新功能完成后,提交到版本库。

버전 관리 도구 Git - 지점 관리

冲突解决

现在我们新的功能完成了,那么就可以把它合并到master分支上了。现在我们来演示合并时遇到冲突时,如何去解决。

$ git checkout master
Switched to branch &#39;master&#39;

$ git merge dev
Auto-merging index.php
CONFLICT (content): Merge conflict in index.php
Automatic merge failed; fix conflicts and then commit the result.

提示我index.php合并的时候有冲突,我们来看看该文件

$ cat index.php
<?php

<<<<<<< HEAD
echo &#39;hello world&#39;;
=======
echo &#39;version 1.1 finished&#39;;
>>>>>>> dev
<br/>
$ cat index.php 
<?php 
echo &#39;version 1.1 finished&#39;;

然后再add并提交,最后在提交

$ git commit -m &#39;merge dev&#39;

这个时候就合并成功了,现在就去删除dev分支吧。

$ git branch -d dev

위 내용은 버전 관리 도구 Git - 지점 관리의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

GitHub의 핵심 기능에는 버전 제어, 지점 관리, 코드 검토, 문제 추적 및 프로젝트 관리가 포함됩니다. 1. 버전 제어 및 지점 관리는 GIT를 기반으로하므로 코드 변경 및 실험 개발을 추적 할 수 있습니다. 2. 코드 검토는 PullRequest를 통해 구현되어 코드 품질 및 팀 협업을 개선합니다. 3. 문제 추적 및 프로젝트 관리는 프로젝트 투명성 및 추적 성을 향상시키기 위해 문제와 프로젝트 관리위원회를 통해 수행됩니다.

GitHub의 행동 : 예 및 사용 사례GitHub의 행동 : 예 및 사용 사례Apr 12, 2025 am 12:16 AM

Github는 소프트웨어 개발의 효율성과 품질을 향상시키는 강력한 도구입니다. 1) 버전 제어 : GIT를 통해 코드 변경을 관리합니다. 2) PullRequests : 코드 검토를 수행하고 코드 품질을 향상시킵니다. 3) 문제 : 버그 및 프로젝트 진행 상황을 추적합니다. 4) githubactions : 건설, 테스트 및 배치 프로세스를 자동화합니다.

Git vs. Github : 버전 제어 및 코드 호스팅Git vs. Github : 버전 제어 및 코드 호스팅Apr 11, 2025 am 11:33 AM

GIT는 버전 제어 시스템이며 GitHub는 GIT 기반 코드 호스팅 플랫폼입니다. GIT는 코드 버전을 관리하는 데 사용되며 로컬 작업을 지원합니다. GitHub는 문제 추적 및 풀 레크와 같은 온라인 협업 도구를 제공합니다.

간단한 말로 git은 무엇입니까?간단한 말로 git은 무엇입니까?Apr 09, 2025 am 12:12 AM

GIT는 개발자가 파일 변경을 추적하고 협력하며 코드 버전을 관리하는 데 도움이되는 오픈 소스 분산 버전 제어 시스템입니다. 핵심 기능에는 1) 레코드 코드 수정, 2) 이전 버전으로의 폴백, 3) 협업 개발 및 4) 병렬 개발을위한 분기 생성 및 관리가 포함됩니다.

git은 github와 동일합니까?git은 github와 동일합니까?Apr 08, 2025 am 12:13 AM

Git과 Github도 같은 것이 아닙니다. GIT는 버전 제어 시스템이며 GitHub는 GIT 기반 코드 호스팅 플랫폼입니다. GIT는 코드 버전을 관리하는 데 사용되며 Github은 온라인 협업 환경을 제공합니다.

HTML에 github를 사용하는 방법은 무엇입니까?HTML에 github를 사용하는 방법은 무엇입니까?Apr 07, 2025 am 12:13 AM

HTML 프로젝트를 관리하기 위해 GitHub를 사용하는 이유는 버전 제어, 협업 개발 및 작품 발표를위한 플랫폼을 제공하기 때문입니다. 특정 단계에는 다음이 포함됩니다. 1. Git 저장소 작성 및 초기화, 2. HTML 파일 추가 및 제출, 3. GitHub에 푸시, 4. GitHubPages를 사용하여 웹 페이지를 배포, 5. GitHubactions를 사용하여 빌드 및 배포를 자동화하십시오. 또한 GitHub은 HTML 프로젝트를 최적화하고 협업하는 데 도움이되는 코드 검토, 문제 및 풀 레크 기능 기능을 지원합니다.

git 또는 github로 시작해야합니까?git 또는 github로 시작해야합니까?Apr 06, 2025 am 12:09 AM

GIT에서 시작하는 것은 버전 제어 원칙에 대한 깊은 이해에 더 적합하며 GitHub에서 시작하는 것은 협업 및 코드 호스팅에 중점을 두는 데 더 적합합니다. 1. git은 코드 버전 기록을 관리하는 데 도움이되는 분산 버전 제어 시스템입니다. 2. GitHub는 GIT를 기반으로 한 온라인 플랫폼으로 코드 호스팅 및 협업 기능을 제공합니다.

Microsoft는 git 또는 github를 소유합니까?Microsoft는 git 또는 github를 소유합니까?Apr 05, 2025 am 12:20 AM

Microsoft는 Git을 소유하지 않지만 Github를 소유하고 있습니다. 1. Git은 2005 년 Linus Torvaz가 만든 분산 버전 제어 시스템입니다. 2. Github는 GIT를 기반으로 한 온라인 코드 호스팅 플랫폼입니다. 2008 년에 설립되어 2018 년 Microsoft에서 인수했습니다.

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

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에서 모든 것을 잠금 해제하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

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

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기