etc./StackOverFlow

Git은 핫픽스 분기를 기능 분기로 병합합니다.

청렴결백한 만능 재주꾼 2023. 4. 25. 10:55
반응형

질문자 :theomega


Git에 다음과 같은 상황이 있다고 가정해 보겠습니다.

  1. 생성된 저장소:

     mkdir GitTest2 cd GitTest2 git init
  2. 마스터에서 몇 가지 수정 사항이 발생하고 커밋됩니다.

     echo "On Master" > file git commit -a -m "Initial commit"
  3. Feature1이 마스터에서 분기되고 일부 작업이 완료되었습니다.

     git branch feature1 git checkout feature1 echo "Feature1" > featureFile git commit -a -m "Commit for feature1"
  4. 한편, 마스터 코드에서 버그가 발견되고 핫픽스 분기가 설정됩니다.

     git checkout master git branch hotfix1 git checkout hotfix1
  5. 버그는 핫픽스 분기에서 수정되고 마스터에 다시 병합됩니다(아마도 풀 요청/코드 검토 후):

     echo "Bugfix" > bugfixFile git commit -a -m "Bugfix Commit" git checkout master git merge --no-ff hotfix1
  6. feature1에 대한 개발은 계속됩니다.

     git checkout feature1

내 기능 분기에 핫픽스가 필요하다고 가정해 보겠습니다. 버그도 거기에서 발생하기 때문일 수 있습니다. 내 기능 분기에 커밋을 복제하지 않고 어떻게 이를 달성할 수 있습니까?

기능 구현과 관련이 없는 기능 분기에서 두 개의 새 커밋을 가져오는 것을 방지하고 싶습니다. 이것은 내가 pull 요청을 사용하는 경우 특히 중요해 보입니다. 이러한 모든 커밋은 또한 pull 요청에 포함되며 이것이 이미 완료되었지만(핫픽스가 이미 마스터에 있기 때문에) 검토해야 합니다.

git merge master --ff-only : "치명적: 빨리 감기, 중단할 수 없습니다."를 수행할 수 없지만 이것이 도움이 되었는지 확실하지 않습니다.



마스터 브랜치를 기능 브랜치에 어떻게 병합합니까? 쉬운:

 git checkout feature1 git merge master

빨리 감기 병합은 수행할 수 없으므로 여기에서 강제로 병합하는 것은 의미가 없습니다. 기능 분기와 마스터 분기에 모두 커밋했습니다. 빨리 감기는 이제 불가능합니다.

GitFlow를 살펴보십시오. 따를 수 있는 git의 분기 모델이며 무의식적으로 이미 수행했습니다. 또한 수동으로 수행해야 하는 작업을 자동으로 수행하는 새 워크플로 단계에 대한 몇 가지 명령을 추가하는 Git 확장 기능입니다.

그래서 당신은 당신의 작업 흐름에서 무엇을 올바르게 했습니까? 작업할 두 개의 분기가 있으며 feature1 분기는 기본적으로 GitFlow 모델의 "개발" 분기입니다.

마스터에서 핫픽스 분기를 만들고 다시 병합했습니다. 그리고 지금 당신은 붙어 있습니다.

GitFlow 모델은 핫픽스를 개발 분기(귀하의 경우 "feature1")에도 병합하도록 요청합니다.

따라서 실제 대답은 다음과 같습니다.

 git checkout feature1 git merge --no-ff hotfix1

이렇게 하면 핫픽스 내부에서 수행된 모든 변경 사항이 기능 분기에 추가되지만 해당 변경 사항 만 추가됩니다. 브랜치의 다른 개발 변경 사항과 충돌할 수 있지만 결국 기능 브랜치를 다시 마스터로 병합해야 마스터 브랜치와 충돌하지 않습니다.

리베이스에 매우 주의하십시오. 변경 사항이 저장소에 로컬로 유지된 경우에만 리베이스하십시오(예: 분기를 다른 저장소로 푸시하지 않은 경우). Rebasing은 로컬 커밋을 세상에 내보내기 전에 유용한 순서로 정렬할 수 있는 훌륭한 도구이지만, 나중에 rebase하면 여러분과 같은 git 초보자에게 혼란을 줄 수 있습니다.


Sven

master에서 브랜치를 리베이스할 수 있어야 합니다.

 git checkout feature1 git rebase master

발생하는 모든 갈등을 관리하십시오. 버그 수정(이미 마스터에 있음)이 있는 커밋에 도달하면 Git은 변경 사항이 없으며 이미 적용되었을 수도 있다고 말합니다. 그런 다음 (마스터에 이미 있는 커밋을 건너뛰면서) 다음을 사용하여 리베이스를 계속합니다.

 git rebase --skip

git log 를 수행하면 bugfix 커밋이 마스터 부분에 한 번만 나타나는 것을 볼 수 있습니다.

더 자세한 토론을 위해 이 정확한 사용 사례를 다루는 git rebase ( https://git-scm.com/docs/git-rebase )에 대한 Git 책 문서를 살펴보세요.

================ 추가 컨텍스트를 위해 편집 ====================

이 답변은 특히 @theomega의 특정 상황을 고려하여 질문한 질문에 대해 제공되었습니다. 이 부분에 유의하십시오.

기능 구현과 관련이 없는 기능 분기에서 [...] 커밋을 방지하고 싶습니다.

master에 개인 지점을 리베이스하는 것이 바로 그 결과를 산출하는 것입니다. 대조적으로 master를 그의 브랜치에 병합하는 것은 그가 구체적으로 원하지 않는 일을 정확하게 수행할 것입니다. 그가 그의 브랜치를 통해 작업하고 있는 기능 구현과 관련이 없는 커밋을 추가하는 것입니다.

질문 제목을 읽는 사용자를 처리하려면 질문의 실제 내용과 컨텍스트를 건너뛰고 맨 위 답변만 맹목적으로 읽고 그들의 (다른) 사용 사례에 항상 적용된다는 가정하에 자세히 설명하겠습니다.

  • 개인 브랜치만 리베이스합니다(즉, 로컬 저장소에만 존재하고 다른 사람과 공유되지 않은 지점). 공유 브랜치를 리베이스하면 다른 사람들이 가질 수 있는 복사본이 "파손"됩니다.
  • 브랜치(마스터 브랜치이든 다른 브랜치이든)의 변경 사항을 공개 브랜치로 통합하려는 경우(예: 풀 리퀘스트를 열기 위해 브랜치를 푸시했지만 이제 마스터와 충돌이 있고 업데이트해야 합니다. 이러한 충돌을 해결하기 위해 분기)를 병합해야 합니다(예: @Sven의 답변에서 git merge master
  • 선호하는 경우 분기를 로컬 개인 분기에 병합할 수도 있지만 분기에 "외부" 커밋이 발생한다는 점에 유의하십시오.

마지막으로 이 답변이 @theomega에 대한 것임에도 불구하고 귀하의 상황에 가장 적합하지 않다는 사실이 마음에 들지 않는다면 아래에 설명을 추가하는 것이 특히 도움이 되지 않을 것입니다. 어떤 답변이 선택되었는지 제어하지 않습니다. @theomega만 가능합니다.


David Sulc

이 문서에 따라 다음을 수행해야 합니다.

  • master의 새 버전을 기반으로 하는 새 분기를 만듭니다.

    git branch -b newmaster

  • 이전 기능 분기를 새 기능으로 병합

    git checkout newmaster

  • 새 기능 분기에서 충돌 해결

처음 두 명령을 git checkout -b newmaster 결합할 수 있습니다.

이렇게 하면 백 병합이 필요하지 않기 때문에 기록이 명확하게 유지됩니다. 그리고 Git 리베이스를 수행할 필요가 없기 때문에 매우 신중할 필요가 없습니다.


zimi

git merge

당신은 아래 단계를 따를 수 있습니다

1. origin/master 브랜치를 feature 브랜치에 병합

 # step1: change branch to master, and pull to update all commits $ git checkout master $ git pull # step2: change branch to target, and pull to update commits $ git checkout feature $ git pull # step3: merge master to feature(⚠️ current is feature branch) $ git merge master

2. feature 브랜치를 origin/master 브랜치에 병합

origin/master 는 원격 마스터 브랜치이고 master 는 로컬 마스터 브랜치입니다.

 $ git checkout master $ git pull origin/master $ git merge feature $ git push origin/master

xgqfrms

Zimi의 답변 은 이 프로세스를 일반적으로 설명합니다. 구체적인 내용은 다음과 같습니다.

  1. 새 분기를 만들고 전환합니다. 최신 핫픽스를 포함하도록 master 기반으로 하는지 확인하십시오.

     git checkout master git branch feature1_new git checkout feature1_new # Or, combined into one command: git checkout -b feature1_new master
  2. 새 분기로 전환한 후 기존 기능 분기의 변경 사항을 병합합니다. 이렇게 하면 핫픽스 커밋을 복제하지 않고 커밋이 추가됩니다.

     git merge feature1
  3. 새 분기에서 기능과 마스터 분기 간의 충돌을 해결합니다.

완료! 이제 새 분기를 사용하여 기능을 계속 개발하십시오.


jkdev

나는 다른 사람들과 유사하게 내 대답을 추가하지만 아마도 읽고 구현하는 것이 가장 빠를 것입니다.

참고: 이 경우에는 Rebase가 필요하지 않습니다.

repo1 과 두 개의 분기 masterdev-user 가 있다고 가정합니다.

dev-user master 의 특정 상태에서 수행되는 분기입니다.

dev-usermaster 가 모두 전진한다고 가정합니다.

어느 시점에서 나는 dev-user master 에서 이루어진 모든 커밋을 얻기를 원합니다.

어떻게 해야 하나요?

내 저장소 루트 폴더로 먼저 이동합니다.

cd name_of_the_repository

그 다음에

 git checkout master git pull git checkout dev-user git pull git merge master git push

이것이 같은 상황에있는 다른 사람에게 도움이되기를 바랍니다.


desmond13

다음은 마스터 브랜치를 현재 브랜치에 병합하는 데 사용할 수 있는 스크립트입니다.

스크립트는 다음을 수행합니다.

  • 마스터 브랜치로 전환
  • 마스터 브랜치를 당깁니다.
  • 현재 분기로 다시 전환
  • 마스터 브랜치를 현재 브랜치에 병합합니다.

이 코드를 배치 파일(.bat)로 저장하고 스크립트를 저장소의 아무 곳에나 배치합니다. 그런 다음 그것을 클릭하여 실행하면 설정됩니다.

 :: This batch file pulls current master and merges into current branch @echo off :: Option to use the batch file outside the repo and pass the repo path as an arg set repoPath=%1 cd %repoPath% FOR /F "tokens=*" %%g IN ('git rev-parse --abbrev-ref HEAD') do (SET currentBranch=%%g) echo current branch is %currentBranch% echo switching to master git checkout master echo. echo pulling origin master git pull origin master echo. echo switching back to %currentBranch% git checkout %currentBranch% echo. echo attemting merge master into %currentBranch% git merge master echo. echo script finished successfully PAUSE

Aaron M.

기능 분기에 필요한 정확한 커밋을 가져오기 위해 "체리 선택(cherry-pick)"을 수행할 수 있습니다.

git checkout hotfix1 을 수행하여 hotfix1 분기에 액세스합니다. 그런 다음 git log 를 수행하여 해당 커밋의 SHA-1 해시(커밋을 고유하게 식별하는 임의의 문자와 숫자의 큰 시퀀스)를 가져옵니다. 그것을 복사하십시오(또는 처음 10자 정도).

그런 다음 git checkout feature1 을 사용하여 기능 분기로 돌아갑니다.

그런 다음 git cherry-pick <the SHA-1 hash that you just copied>

그러면 해당 커밋과 해당 커밋만 기능 분기로 가져옵니다. 그 변경 사항은 분기에 있을 것입니다. 방금 "선택한" 것입니다. 그런 다음 작업을 재개하고, 편집하고, 커밋하고, 푸시하는 등의 작업을 원하는 대로 수행합니다.

결국 한 브랜치에서 기능 브랜치로(또는 그 반대로) 또 다른 병합을 수행하면 Git은 해당 특정 커밋에서 이미 병합되었음을 인식하고 다시 만들 필요가 없다는 것을 알고 "건너뛰세요".


Bob Gilmore

이러한 명령이 반복되므로 기존 답변을 보완하여 연속으로 수행할 수 있습니다. 기능 분기에 있다고 가정할 때:

 git checkout master && git pull && git checkout - && git merge -

또는 별칭에 추가합니다.

 alias merge_with_master="git checkout master && git pull && git checkout - && git merge -"

fabriciorissetto

저는 기능 분기에 있으며 리팩토링을 했습니다. 지금 내 기능 분기에 마스터 변경 사항을 병합하고 싶습니다. 나는 훨씬 뒤쳐져 있다. 참고 내 기능 분기에 모듈이 한 위치에서 다른 위치로 이동했기 때문에 마스터 변경 사항을 로컬로 가져오고 싶지 않습니다. 나는 당기지 않고 아래에서 수행하는 것이 작동하지 않는다는 것을 발견했습니다. "이미 최신 상태입니다."라고 표시됩니다.

 //below does not get the latest from remote master to my local feature branch without git pull git checkout master git fetch git checkout my-feature-branch git merge master

아래는 작동합니다. git merge origin/master를 사용하십시오.

 git checkout master git fetch git checkout my-feature-branch git merge origin/master

Tony

대용량 파일 버전 관리를 시작하려면 다음과 같은 간단한 단계만 수행하면 됩니다. OS용 Git LFS 명령줄 확장을 다운로드하여 설치합니다. 사용자 계정에 대한 Git LFS 설정: git lfs install 3. 대용량 파일을 추적하도록 Git LFS 구성: git lfs track "*.xyz"


Hamid Narimani

In Eclipse -

1) 체크아웃 마스터 브랜치

 Git Repositories ->Click on your repository -> click on Local ->double click master branch ->Click on yes for check out

2) 마스터 브랜치 가져오기

 Right click on project ->click on Team -> Click on Pull

3) 기능 분기를 확인하십시오(1 포인트에서 언급한 것과 동일한 단계를 따르십시오)

4) 마스터를 기능으로 병합

 Git Repositories ->Click on your repository -> click on Local ->Right Click on your selected feature branch ->Click on merge ->Click on Local ->Click on Master ->Click on Merge.

5) 이제 기능 분기에서 마스터 분기의 모든 변경 사항을 얻을 수 있습니다. 충돌이 있는 경우 제거합니다.

 For conflict if any exists ,follow this - Changes mentioned as Head(<<<<<< HEAD) is your change, Changes mentioned in branch(>>>>>>> branch) is other person change, you can update file accordingly.

참고 - 충돌 파일의 경우 색인에 추가를 수행해야 합니다.

6) 기능 분기에서 변경 사항을 커밋하고 푸시합니다.

 Right click on project ->click on Team -> Click on commit -> Commit and Push.

또는

 Git Repositories ->Click on your repository -> click on Local ->Right Click on your selected feature branch ->Click on Push Branch ->Preview ->Push

Vijay

출처 : http:www.stackoverflow.com/questions/16955980/git-merge-hotfix-branch-into-feature-branch

반응형