git是一個分佈式版本管理工具git
官網下載安裝,安裝完成後須要最後一步設置bash
git config -global user.name "your name"
git config -global user.email "****.qq.com"
複製代碼
初始化一個git倉庫,使用 git init
命令ssh
添加文件到git倉庫,分兩步:分佈式
(1)使用命令git add <file>
,注意可反覆屢次使用,添加多個文件;工具
(2)使用命令git commit -m "message"
,完成。學習
要隨時掌握工做區的狀態,使用 git status
命令;spa
若是git status
告訴你文件被修改過,用git diff
能夠查看修改內容code
HEAD指向的版本就是當前版本,所以,git容許咱們在版本的歷史之間穿梭,使用命令git reset --hard commit_id
;orm
穿梭前,用git log
能夠查看提交歷史,以便肯定 要回退到哪一個版本;server
要重返將來,用git reflog
查看命令歷史,以便肯定要回到將來的哪一個版本。
咱們本地寫代碼的地方就是工做區;
git add
把文件添加到暫存區;
git commit
實際上就是把暫存區全部內容添加到暫存區
場景一:當你亂改了工做區某個文件的內容,想直接丟棄工做區的修改時,用命令git checkout --file
;
場景二:當你不但亂改了工做區某個文件的內容,還添加到了暫存區,想丟棄修改,分兩步,第一步用命令git reset HEAD <file>
,就回到了場景一,第二部按照場景一操做
命令git rm
用於刪除一個文件
若是一個文件已經被提交到了版本庫,那麼你永遠不用擔憂誤刪,可是要當心,你只能恢復文件到最新版本,你會丟失最後一次提交後你修改的內容
要關聯一個遠程倉庫,使用命令git remote add origin git@server-name:path/repo-name.git
關聯後,使用命令git push -u origin master
第一次推送master分支的全部內容;伺候,就可使用命令git push origin master
推送最新修改
要克隆一個倉庫,首先必須知道倉庫的地址 ,而後能夠經過git clone
命令克隆; git 支持多種協議,包括https,但經過ssh支持原生git協議速度最快。
查看分支:git branch
建立分支:git branch <name>
切換分支: git checkout <name>
建立+切換分支:git checkout -b <name>
合併某分支到當前分支:git merge <name>
刪除分支:git branch -d <name>
當git沒法自動合併時,就必須首先解決衝突,解決衝突後,再提交,合併完成。
解決衝突就是把git合併失敗的文件手動編輯成咱們但願的內容,再提交。
用git log --graph
命令能夠看到分支合併圖
合併分支時,加上--no-off
參數就能夠用普通模式合併,合併後的歷史有分支,能看出來曾經作過合併,而fast forward
合併就看不出來曾經作合併
修復bug時間,咱們會經過建立新的bug分支進行提交,而後 合併,最後刪除; 當手頭工做沒有完成時,先把工做現場git stash
一下,而後去修復bug,修復後,再git stash pop
,回到工做現場。
開發一個新feature,最好新建一個分支;
若是要丟棄一個沒有被合併過的分支,能夠經過git branch -D <name>
強行刪除。
多人協做的工做模式一般是這樣:
首先,能夠試圖用git push origin <branch-name>
推送本身的修改;
若是推送失敗,則由於遠程分支比你的本地更新,須要先用git pull
試圖合併;
若是合併有衝突,則解決衝突,並在本地提交;
沒有衝突或者解決掉衝突後,再用git push origin <branch-name>
推送就能成功!
若是git pull
提示no tracking information,則說明本地分支和遠程分支的連接關係沒有建立,用命令git branch --set-upstream-to <branch-name> origin/<branch-name>
。 小結: 查看遠程庫信息,使用git remote -v
;
本地新建的分支若是不推送到遠程,對其餘人就是不可見的;
從本地推送分支,使用git push origin branch-name
,若是推送失敗,先用git pull
抓取遠程的新提交;
在本地建立和遠程分支對應的分支,使用git checkout -b branch-name origin/branch-name
,本地和遠程分支的名稱最好一致;
創建本地分支和遠程分支的關聯,使用git branch --set-upstream branch-name origin/branch-name
;
從遠程抓取分支,使用git pull
,若是有衝突,要先處理衝突。
rebase操做能夠把本地未push的分叉提交歷史整理成直線;
rebase的目的是使得咱們在查看歷史提交的變化時更容易,由於分叉的提交須要三方對比。 15. 建立標籤 命令git tag <tagname>
用於新建一個標籤,默認爲HEAD,也能夠指定一個commit id;
命令git tag -a <tagname> -m "blablabla..."
能夠指定標籤信息;
命令git tag
能夠查看全部標籤。
命令git push origin <tagname>
能夠推送一個本地標籤;
命令git push origin --tags
能夠推送所有未推送過的本地標籤;
命令git tag -d <tagname>
能夠刪除一個本地標籤;
命令git push origin :refs/tags/<tagname>
能夠刪除一個遠程標籤。