git push & git pull 推送/拉取分支


git push與git pull是一對推送/拉取分支的git命令。 
git push 使用本地的對應分支來更新對應的遠程分支。

$ git push <遠程主機名> <本地分支名>:<遠程分支名>

注意: 命令中的本地分支是指將要被推送到遠端的分支,而遠程分支是指推送的目標分支,即將本地分支合並到遠程分支。 
如果省略遠程分支名,則表示將本地分支推送與之存在”追蹤關系”的遠程分支(通常兩者同名),如果該遠程分支不存在,則會被新建。

$ git push origin master

上面命令表示,將本地的master分支推送到origin主機的master分支。如果后者不存在,則會被新建。 
origin是一個遠程廠庫地址。

如果省略本地分支名,則表示刪除指定的遠程分支,因為這等同於推送一個空的本地分支到遠程分支,這條命令是刪除遠程master分支。

$ git push origin :master
# 等同於
$ git push origin --delete master

上面命令表示刪除origin主機的master分支。

如果當前分支與遠程分支之間存在追蹤關系(即分支名相同),則本地分支和遠程分支都可以省略。

$ git push origin

上面命令表示,將當前分支推送到origin主機的對應分支。

如果當前分支只有一個追蹤分支,那么主機名都可以省略。

$ git push

如果當前分支與多個主機存在追蹤關系,則可以使用-u選項指定一個默認主機,這樣后面就可以不加任何參數使用git push。

$ git push -u origin master

上面命令將本地的master分支推送到origin主機,同時指定origin為默認主機,后面就可以不加任何參數使用git push了。

不帶任何參數的git push,默認只推送當前分支,這叫做simple方式。此外,還有一種matching方式,會推送所有有對應的遠程分支的本地分支。Git 2.0版本之前,默認采用matching方法,現在改為默認采用simple方式。如果要修改這個設置,可以采用git config命令。

$ git config --global push.default matching
# 或者
$ git config --global push.default simple

還有一種情況,就是不管是否存在對應的遠程分支,將本地的所有分支都推送到遠程主機,這時需要使用–all選項。

$ git push --all origin

上面命令表示,將所有本地分支都推送到origin主機。

如果遠程主機的版本比本地版本更新,推送時Git會報錯,要求先在本地做git pull合並差異,然后再推送到遠程主機。這時,如果你一定要推送,可以使用–force選項。

$ git push --force origin

上面命令使用–force選項,結果導致在遠程主機產生一個”非直進式”的合並(non-fast-forward merge)。除非你很確定要這樣做,否則應該盡量避免使用–force選項。

最后,git push不會推送標簽(tag),除非使用–tags選項。

$ git push origin --tags

git pull 獲取並合並其他的廠庫,或者本地的其他分支。

git pull 與 git push操作的目的相同,但是操作的目標相反。命令格式如下:

git pull <遠程主機> <遠程分支>:<本地分支>

例如:

git pull origin master:my_test

上面的命令是將origin廠庫的master分支拉取並合並到本地的my_test分支上。

如果省略本地分支,則將自動合並到當前所在分支上。如下:

git pull origin master

注:如果你想參與github上的一些優秀的項目,則下面提供一個通用的例子: 
首先,需要一個github的賬號,並fork一個你感興趣的repository。 
下面描述過程中會涉及兩個遠程主分支,為了很好的區別,我們把fork出來的主分支稱為遠程A repository,本fork的分支稱為遠程B repository

$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 web界面上將my_test分支合並到你需改的遠程B repository 分支上。等待管理員review,如果有問題,就繼續在develop分支當修改,並commit –amend,在之前的commit上修改。知道被meger。

git push與git pull是一對推送/拉取分支的git命令。 
git push 使用本地的對應分支來更新對應的遠程分支。

$ git push <遠程主機名> <本地分支名>:<遠程分支名>
  • 1

注意: 命令中的本地分支是指將要被推送到遠端的分支,而遠程分支是指推送的目標分支,即將本地分支合並到遠程分支。 
如果省略遠程分支名,則表示將本地分支推送與之存在”追蹤關系”的遠程分支(通常兩者同名),如果該遠程分支不存在,則會被新建。

$ git push origin master
  • 1

上面命令表示,將本地的master分支推送到origin主機的master分支。如果后者不存在,則會被新建。 
origin是一個遠程廠庫地址。

如果省略本地分支名,則表示刪除指定的遠程分支,因為這等同於推送一個空的本地分支到遠程分支,這條命令是刪除遠程master分支。

$ git push origin :master
# 等同於
$ git push origin --delete master
  • 1
  • 2
  • 3

上面命令表示刪除origin主機的master分支。

如果當前分支與遠程分支之間存在追蹤關系(即分支名相同),則本地分支和遠程分支都可以省略。

$ git push origin
  • 1

上面命令表示,將當前分支推送到origin主機的對應分支。

如果當前分支只有一個追蹤分支,那么主機名都可以省略。

$ git push
  • 1

如果當前分支與多個主機存在追蹤關系,則可以使用-u選項指定一個默認主機,這樣后面就可以不加任何參數使用git push。

$ git push -u origin master
  • 1

上面命令將本地的master分支推送到origin主機,同時指定origin為默認主機,后面就可以不加任何參數使用git push了。

不帶任何參數的git push,默認只推送當前分支,這叫做simple方式。此外,還有一種matching方式,會推送所有有對應的遠程分支的本地分支。Git 2.0版本之前,默認采用matching方法,現在改為默認采用simple方式。如果要修改這個設置,可以采用git config命令。

$ git config --global push.default matching
# 或者
$ git config --global push.default simple
  • 1
  • 2
  • 3

還有一種情況,就是不管是否存在對應的遠程分支,將本地的所有分支都推送到遠程主機,這時需要使用–all選項。

$ git push --all origin
  • 1

上面命令表示,將所有本地分支都推送到origin主機。

如果遠程主機的版本比本地版本更新,推送時Git會報錯,要求先在本地做git pull合並差異,然后再推送到遠程主機。這時,如果你一定要推送,可以使用–force選項。

$ git push --force origin
  • 1

上面命令使用–force選項,結果導致在遠程主機產生一個”非直進式”的合並(non-fast-forward merge)。除非你很確定要這樣做,否則應該盡量避免使用–force選項。

最后,git push不會推送標簽(tag),除非使用–tags選項。

$ git push origin --tags
  • 1

git pull 獲取並合並其他的廠庫,或者本地的其他分支。

git pull 與 git push操作的目的相同,但是操作的目標相反。命令格式如下:

git pull <遠程主機> <遠程分支>:<本地分支>
  • 1

例如:

git pull origin master:my_test
  • 1

上面的命令是將origin廠庫的master分支拉取並合並到本地的my_test分支上。

如果省略本地分支,則將自動合並到當前所在分支上。如下:

git pull origin master
  • 1

注:如果你想參與github上的一些優秀的項目,則下面提供一個通用的例子: 
首先,需要一個github的賬號,並fork一個你感興趣的repository。 
下面描述過程中會涉及兩個遠程主分支,為了很好的區別,我們把fork出來的主分支稱為遠程A repository,本fork的分支稱為遠程B repository

$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分支上
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17

然后在github web界面上將my_test分支合並到你需改的遠程B repository 分支上。等待管理員review,如果有問題,就繼續在develop分支當修改,並commit –amend,在之前的commit上修改。知道被meger。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM