git에서 push와 pull의 차이점은 무엇입니까?
git에서 푸시와 풀의 차이점: 1. "git push" 명령은 로컬 라이브러리의 최신 정보를 원격 라이브러리로 보내고, 로컬 브랜치의 업데이트를 원격 호스트로 푸시하는 데 사용됩니다. git pull" 명령은 원격지에서 로컬 라이브러리로 최신 버전을 가져오는 것으로, 다른 저장소나 로컬 브랜치에서 가져와서 통합하는 데 사용됩니다.
이 문서의 운영 환경: Windows 10 시스템, Git 버전 2.30.0, Dell G3 컴퓨터.
git에서 push와 pull의 차이점은 무엇인가요?
git push와 git pull은 브랜치를 push/pull하는 한 쌍의 git 명령입니다.
git push는 로컬 해당 브랜치를 사용하여 해당 원격 브랜치를 업데이트합니다
$ git push <远程主机名> <本地分支名>:<远程分支名>
참고: 명령에서 로컬 브랜치는 원격 끝으로 푸시될 브랜치를 나타내고, 원격 브랜치는 대상 브랜치를 나타냅니다. 로컬 브랜치인 푸시의 브랜치가 원격 브랜치에 병합됩니다.
원격 브랜치 이름이 생략되면 로컬 브랜치가 "추적 관계"가 있는 원격 브랜치로 푸시된다는 의미입니다(일반적으로 둘 다 동일한 이름을 가짐). 원격 브랜치가 존재하지 않으면 생성됩니다.
$ git push origin master
위 명령은 로컬 마스터 브랜치를 원본 호스트의 마스터 브랜치로 푸시하는 것을 의미합니다. 후자가 존재하지 않으면 생성됩니다.
origin은 원격 공장 주소입니다.
로컬 브랜치 이름이 생략되면 지정된 원격 브랜치를 삭제한다는 의미입니다. 이는 빈 로컬 브랜치를 원격 브랜치로 푸시하는 것과 같기 때문입니다. 이 명령은 원격 마스터 브랜치를 삭제합니다.
$ git push origin :master # 等同于 $ git push origin --delete master
위 명령은 원본 호스트의 마스터 브랜치를 삭제하라는 의미입니다.
현재 브랜치와 원격 브랜치 사이에 추적 관계가 있는 경우(즉, 브랜치 이름이 동일한 경우) 로컬 브랜치와 원격 브랜치를 모두 생략할 수 있습니다.
$ git push origin
위 명령은 현재 분기를 원본 호스트의 해당 분기로 푸시하는 것을 의미합니다.
현재 브랜치에 추적 브랜치가 하나만 있는 경우 호스트 이름을 생략할 수 있습니다.
$ git push
현재 브랜치가 여러 호스트와 추적 관계에 있는 경우 -u 옵션을 사용하여 기본 호스트를 지정할 수 있으므로 나중에 매개변수를 추가하지 않고도 git push를 사용할 수 있습니다.
$ git push -u origin master
위 명령은 로컬 마스터 브랜치를 원본 호스트로 푸시하고 원본을 기본 호스트로 지정합니다. 그러면 매개변수를 추가하지 않고도 git push를 사용할 수 있습니다.
매개변수가 없는 Git push는 기본적으로 현재 분기만 push합니다. 이를 간단한 방법이라고 합니다. 또한 해당 원격 분기가 있는 모든 로컬 분기를 푸시하는 일치 방법이 있습니다. Git 버전 2.0 이전에는 매칭 방식을 기본으로 사용했으나 현재는 기본적으로 단순 방식으로 변경되었습니다. 이 설정을 수정하려면 git config 명령을 사용하면 됩니다.
$ git config --global push.default matching # 或者 $ git config --global push.default simple
해당 원격 브랜치가 있는지 여부에 관계없이 모든 로컬 브랜치를 원격 호스트로 푸시하는 또 다른 상황이 있습니다. 이 경우 –all 옵션을 사용해야 합니다.
$ git push --all origin
위 명령은 모든 로컬 브랜치가 원본 호스트로 푸시됨을 나타냅니다.
원격 호스트의 버전이 로컬 버전보다 최신인 경우 Git은 푸시할 때 오류를 보고하므로 원격 호스트로 푸시하기 전에 로컬에서 git pull을 수행하여 차이점을 병합해야 합니다. 이때 꼭 push를 해야 한다면 --force 옵션을 사용하면 된다.
$ git push --force origin
위 명령은 –force 옵션을 사용하며, 이로 인해 원격 호스트에서 "빠르게 감기가 아닌 병합"이 발생합니다. 이 작업을 수행하려는 것이 확실하지 않은 경우 --force 옵션을 사용하지 않는 것이 좋습니다.
마지막으로 –tags 옵션을 사용하지 않으면 git push는 태그를 푸시하지 않습니다.
$ git push origin --tags
git pull은 다른 저장소나 다른 로컬 지점을 가져오고 병합합니다.
git pull은 git push 작업과 목적은 동일하지만 작업의 목적은 반대입니다. 명령 형식은 다음과 같습니다.
git pull <远程主机> <远程分支>:<本地分支>
예:
git pull origin master:my_test
위 명령은 원본 팩토리 라이브러리의 마스터 브랜치를 가져와 로컬 my_test 브랜치에 병합하는 것입니다.
로컬 브랜치를 생략하면 현재 브랜치에 자동으로 병합됩니다. 다음과 같습니다:
git pull origin master
참고: github의 훌륭한 프로젝트에 참여하고 싶다면 아래에 일반적인 예가 제공됩니다.
먼저 github 계정이 필요하고 관심 있는 저장소를 포크합니다.
다음 설명 프로세스에는 두 개의 원격 마스터 브랜치가 포함됩니다. 구분을 위해 포크된 마스터 브랜치를 원격 A 저장소라고 부르며, 이 포크의 브랜치는 원격 B 저장소라고 합니다.
$git clone <远程Arepository> #克隆你fork出来的分支 $git remote add <远程Brepository标签> git@github.com:XXXX/ceph.git #添加远程Brepository标签 $git pull <远程B厂库标签> master:master #从远程Brepository的master分支拉取最新objects合并到本地master分支 $git checkout YYYY #切换到要修改的分支上 $git branch develop; git checkout develop #在当前分支的基础上创建一个开发分支,并切换到该分支上,你将在该分支上coding coding...... #在工作区coding $git add .#将修改保存到索引区 $git commit -a #将修改提交到本地分区 $git push origin my_test:my_test #将本地分支my_test提交到远程A repository的my_test分支上
그런 다음 github 웹 인터페이스에서 my_test 분기를 원격 B 저장소 분기로 변경해야 합니다. 문제가 있으면 계속해서 개발 브랜치를 변경하고 커밋 -amend를 수행하여 이전 커밋을 변경합니다. 메가로 알아보세요.
추천 학습: "Git Tutorial"
위 내용은 git에서 push와 pull의 차이점은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











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

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

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

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

해결 : GIT 다운로드 속도가 느리면 다음 단계를 수행 할 수 있습니다. 네트워크 연결을 확인하고 연결 방법을 전환하십시오. GIT 구성 최적화 : 포스트 버퍼 크기를 늘리고 (GIT 구성-글로벌 http.postBuffer 524288000) 저속 제한 (git config --global http.lowspeedlimit 1000)을 줄입니다. git 프록시 (예 : git-proxy 또는 git-lfs-proxy)를 사용하십시오. 다른 git 클라이언트 (예 : Sourcetree 또는 Github 데스크탑)를 사용해보십시오. 화재 보호를 확인하십시오

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

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

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