push

http://www.yiibai.com/git/git_push.htmlhtml

 

git push

git push命令用於將本地分支的更新,推送到遠程主機。它的格式與git pull命令相仿。git

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

注意,分支推送順序的寫法是<來源地>:<目的地>,因此git pull是<遠程分支>:<本地分支>,而git push是<本地分支>:<遠程分支>。web

若是省略遠程分支名,則表示將本地分支推送與之存在」追蹤關係」的遠程分支(一般二者同名),若是該遠程分支不存在,則會被新建。swift

$ git push origin master

上面命令表示,將本地的master分支推送到origin主機的master分支。若是後者不存在,則會被新建。app

若是省略本地分支名,則表示刪除指定的遠程分支,由於這等同於推送一個空的本地分支到遠程分支。yii

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

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

若是當前分支與遠程分支之間存在追蹤關係,則本地分支和遠程分支均可以省略。this

$ git push origin

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

若是當前分支只有一個追蹤分支,那麼主機名均可以省略。url

$ 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
相關文章
相關標籤/搜索