1) 遠程倉庫相關命令jquery
檢出倉庫:$ git clone git://github.com/jquery/jquery.git
查看遠程倉庫:$ git remote -v
添加遠程倉庫:$ git remote add [name] [url]
刪除遠程倉庫:$ git remote rm [name]
修改遠程倉庫:$ git remote set-url --push[name][newUrl]
拉取遠程倉庫:$ git pull [remoteName] [localBranchName]
推送遠程倉庫:$ git push [remoteName] [localBranchName]git
2)分支(branch)操做相關命令github
查看本地分支:$ git branch
查看遠程分支:$ git branch -r
建立本地分支:$ git branch [name] ----注意新分支建立後不會自動切換爲當前分支
切換分支:$ git checkout [name]
建立新分支並當即切換到新分支:$ git checkout -b [name]
刪除分支:$ git branch -d [name] ---- -d選項只能刪除已經參與了合併的分支,對於未有合併的分支是沒法刪除的。若是想強制刪除一個分支,可使用-D選項
合併分支:$ git merge [name] ----將名稱爲[name]的分支與當前分支合併
建立遠程分支(本地分支push到遠程):$ git push origin [name]
刪除遠程分支:$ git push origin :heads/[name]
我從master分支建立了一個issue5560分支,作了一些修改後,使用git push origin master提交,可是顯示的結果倒是'Everything up-to-date',發生問題的緣由是git push origin master 在沒有track遠程分支的本地分支中默認提交的master分支,由於master分支默認指向了origin master 分支,這裏要使用git push origin issue5560:master 就能夠把issue5560推送到遠程的master分支了。
若是想把本地的某個分支test提交到遠程倉庫,並做爲遠程倉庫的master分支,或者做爲另一個名叫test的分支,那麼能夠這麼作。bash
$ git push origin test:master // 提交本地test分支做爲遠程的master分支 //好像只寫這一句,遠程的github就會自動建立一個test分支
$ git push origin test:test // 提交本地test分支做爲遠程的test分支工具
若是想刪除遠程的分支呢?相似於上面,若是:左邊的分支爲空,那麼將刪除:右邊的遠程的分支。url
$ git push origin :test // 剛提交到遠程的test將被刪除,可是本地還會保存的,不用擔憂ip
3)版本(tag)操做相關命令rem
查看版本:$ git tag
建立版本:$ git tag [name]
刪除版本:$ git tag -d [name]
查看遠程版本:$ git tag -r
建立遠程版本(本地版本push到遠程):$ git push origin [name]
刪除遠程版本:$ git push origin :refs/tags/[name]
推送全部tag: git push origin --tagsit
tag遷出branch:
git checkout tagname
git checkout -b new_branch_nameast
4)git stash暫存相關命令
git stash: 備份當前的工做區的內容,從最近的一次提交中讀取相關內容,讓工做區保證和上次提交的內容一致。同時,將當前的工做區內容保存到Git棧中。
git stash pop: 從Git棧中讀取最近一次保存的內容,恢復工做區的相關內容。因爲可能存在多個Stash的內容,因此用棧來管理,pop會從最近的一個stash中讀取內容並恢復。
git stash list: 顯示Git棧內的全部備份,能夠利用這個列表來決定從那個地方恢復。
git stash clear: 清空Git棧。此時使用gitg等圖形化工具會發現,原來stash的哪些節點都消失了。
5)git rebase 使用
當前分支問題develop,從master拉取最新代碼
git pull --rebase origin master 或者 git rebase develop
先將develop分支的代碼checkout出來,做爲工做目錄
而後將master分支從develop分支建立起的全部改變的補丁,依次打上。若是打補丁的過程沒問題,rebase就搞定了
若是打補丁的時候出現了問題,就會提示你處理衝突。處理好了,能夠運行git rebase –continue繼續直到完成
若是你不想處理,你仍是有兩個選擇,一個是放棄rebase過程(運行git rebase –abort),另外一個是直接用test分支的取代當前分支的(git rebase –skip)。
6) 工具
SourceTree & git bash