스택큐힙리스트

'git pull'과 'git fetch'의 차이점은 무엇인가요? 본문

카테고리 없음

'git pull'과 'git fetch'의 차이점은 무엇인가요?

스택큐힙리스트 2023. 2. 28. 10:40
반응형

git pull과 git fetch의 차이점은 무엇인가요?

 

Git Pull과 Git Fetch: 차이점 이해하기

Git은 개발자가 코드의 변경 사항을 추적하는 데 널리 사용되는 버전 관리 시스템입니다. Git으로 작업할 때는 "git pull" 명령과 "git fetch" 명령의 차이점을 아는 것이 중요합니다.

Git Pull

"git pull"은 원격 리포지토리에서 로컬 리포지토리로 변경 내용을 가져와 병합하는 데 사용되는 명령입니다. 즉, "git pull"은 두 가지 작업을 결합합니다: "git fetch"와 "git merge". "git pull"을 실행하면 Git이 원격 리포지토리에서 최신 변경 내용을 가져와 로컬 복사본과 자동으로 병합합니다.

Git Fetch

반면에 "git fetch"는 원격 리포지토리에서 최신 변경 내용만 다운로드할 뿐 로컬 복사본과 병합하지 않습니다. 즉, "git fetch"를 실행한 후 "git merge" 명령을 사용하여 로컬 복사본과 변경 내용을 수동으로 병합해야 합니다.

주요 차이점

"git pull"과 "git fetch"의 주요 차이점은 "git pull"은 변경 내용을 로컬 복사본과 자동으로 병합하는 반면, "git fetch"는 변경 내용만 다운로드한다는 것입니다.

또 다른 중요한 차이점은 병합하기 전에 변경 내용을 검토할 수 있으므로 일반적으로 "git pull"보다 "git fetch"가 더 안전하다는 것입니다. 또한 "git fetch"는 병합을 수행하지 않고 변경 내용만 다운로드하기 때문에 "git pull"보다 빠를 수 있습니다.

요약하면, 로컬 사본을 최신 변경 사항으로 빠르게 업데이트하고 자동으로 병합하려는 경우 "git pull"을 사용하는 것이 가장 좋습니다. 그러나 병합하기 전에 변경 내용을 검토하거나 자동 병합을 피하려면 "git 가져오기"가 더 나은 옵션입니다.

Git으로 작업할 때는 "git pull"과 "git fetch"의 차이점을 이해하는 것이 중요합니다. 다양한 시나리오에서 어떤 명령을 사용해야 하는지 알면 보다 효율적으로 작업하고 잠재적인 충돌을 피할 수 있습니다.

 

 

 

 

가장 간단한 용어로, git pull은 git fetch를 수행한 다음 git merge를 수행한다.

git fetch는 refs/remotes/<remote>/에서 원격 추적 브랜치를 업데이트한다. 이 작업은 refs/heads 아래의 로컬 브랜치를 변경하지 않으므로 언제든지 실행해도 안전하다.

git pull은 로컬 브랜치를 원격 버전으로 최신 상태로 만드는 동시에 다른 원격 추적 브랜치도 업데이트한다.

Git 문서에서 git pull에 대해 알아보세요:

git pull은 주어진 매개변수로 git fetch를 실행한 다음 구성 옵션 또는 명령줄 플래그에 따라 git rebase 또는 git merge를 호출하여 갈라진 브랜치를 조정합니다.

 

"리포지토리를 최신 상태로 유지하기 위해 "git pull"을 수행하는 것입니다." <- 리포지토리 업데이트는 이미 fetch로 수행되지 않나요? 로컬 브랜치를 원격 브랜치에 최신 상태로 가져오는 것을 의미하지 않나요? 병합으로: 원격 브랜치를 로컬 브랜치의 로컬 복사본과 병합하는 건가요, 아니면 정확히 여기서 병합하는 게 뭔가요? - 


네, 단어가 이상하네요. git pull은 항상 현재 브랜치에 병합합니다. 따라서 어느 브랜치에서 가져올지 선택하면 현재 브랜치로 가져온다. 로컬 브랜치나 원격 브랜치가 될 수 있으며, 등록된 git 원격 브랜치가 아닌 원격 브랜치일 수도 있습니다(즉, git pull 명령줄에 URL을 전달해야 함). - 


아니요. Push는 자동으로 Merge를 수행하지 않습니다. 사용자는 끌어와서 로컬에서 병합 충돌을 해결한 다음 다시 리모트로 푸시해야 한다. - 


내가 /home/alice/에 있고 /home/bob을 git fetch하는 경우, 후속 git merge에 어떤 매개 변수를 전달해야 하나요? - 


Git을 배우는 사람들을 위한 참고 사항: 끌어오기는 실제로 가져오기와 병합으로 에뮬레이션할 수 없습니다. 원격 브랜치 포인터만 변경되는 변경 사항을 가져왔고 merge는 아무 작업도 수행하지 않습니다. 반면 pull은 내 추적 브랜치를 빨리 감습니다. 

반응형
Comments