1. 程式人生 > >git參考, 小結

git參考, 小結

建立 git log 無法自動 版本回退 無法 pat 參考 最新版本 修復

git官網: https://git-scm.com

菜鳥教程: http://www.runoob.com/git/git-tutorial.html

廖雪峰: https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000

武沛齊: https://www.cnblogs.com/wupeiqi/p/7295372.html

git小結

創建版本庫

初始化一個Git倉庫,使用git init命令。

添加文件到Git倉庫,分兩步:

  1. 使用命令git add <file>,註意,可反復多次使用,添加多個文件;

  2. 使用命令git commit -m <message>,完成。

版本管理

  • 要隨時掌握工作區的狀態,使用git status命令。

  • 如果git status告訴你有文件被修改過,用git diff可以查看修改內容。

版本回退

  • HEAD指向的版本就是當前版本,因此,Git允許我們在版本的歷史之間穿梭,使用命令git reset --hard commit_id

  • 穿梭前,用git log可以查看提交歷史,以便確定要回退到哪個版本。

  • 要重返未來,用git reflog查看命令歷史,以便確定要回到未來的哪個版本。

管理修改

Git是如何跟蹤修改的,每次修改,如果不用git add到暫存區,那就不會加入到commit

撤銷修改

場景1:當你改亂了工作區某個文件的內容,想直接丟棄工作區的修改時,用命令git checkout -- file

場景2:當你不但改亂了工作區某個文件的內容,還添加到了暫存區時,想丟棄修改,分兩步,第一步用命令git reset HEAD <file>,就回到了場景1,第二步按場景1操作。

場景3:已經提交了不合適的修改到版本庫時,想要撤銷本次提交,參考版本回退一節,不過前提是沒有推送到遠程庫。

刪除文件

命令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鼓勵大量使用分支:

查看分支: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-ff參數就可以用普通模式合並,合並後的歷史有分支,能看出來曾經做過合並,而fast forward合並就看不出來曾經做過合並。

Bug分支

修復bug時,我們會通過創建新的bug分支進行修復,然後合並,最後刪除;

當手頭工作沒有完成時,先把工作現場git stash一下,然後去修復bug,修復後,再git stash pop,回到工作現場。

Feature分支

開發一個新feature,最好新建一個分支;

如果要丟棄一個沒有被合並過的分支,可以通過git branch -D <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

  • rebase操作可以把本地未push的分叉提交歷史整理成直線;

  • rebase的目的是使得我們在查看歷史提交的變化時更容易,因為分叉的提交需要三方對比。

標簽管理

創建標簽

  • 命令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>可以刪除一個遠程標簽。

git參考, 小結