版本管理工具 Git

 

Git是目前世界上最早進的分佈式版本控制系統(沒有之一)。git

 

文章參考來源:github

https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/0013743256916071d599b3aed534aaab22a0db6c4e07fd0000網絡

 

安裝Git 建立初始化倉庫

 

安裝Git...  ssh

使用 分佈式

建立一個文件夾svg

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

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

  1. 使用命令git add <file>,注意,可反覆屢次使用,添加多個文件;
  2. 使用命令git commit -m <message>,完成。
git add file1.txt
git add file2.txt file3.txt
git commit -m "add 3 files."

 

git status命令可讓咱們時刻掌握倉庫當前的狀態3d

git diff file 顧名思義就是查看difference查看修改內容版本控制

 

  • 要隨時掌握工做區的狀態,使用git status命令。
  • 若是git status告訴你有文件被修改過,用git diff能夠查看修改內容。

 

時空機穿梭

HEAD 版本切換

  • HEAD指向的版本就是當前版本,所以,Git容許咱們在版本的歷史之間穿梭,
  • 穿梭前,用git log能夠查看提交歷史,以便肯定要回退到哪一個版本。
  • git log 查看日誌 輸出信息太多,看得眼花繚亂的,能夠試試加上--pretty=oneline參數:
  • git log --pretty=oneline
  • 回退當前版本的上一個版本 用 
  • git reset --hard HEAD^
  • 回退到指定版本 就指定版本的HEAD Id (通常取前4位就好了 git會本身去查找)
  • 使用命令git reset --hard commit_id
  • git reset --hard 4ffd(HEAD版本號)
  • 要重返將來,用git reflog查看命令歷史,以便肯定要回到將來的哪一個版本。

 

 查看日誌:

git log --graph --pretty=oneline --abbrev-commit
 

暫存區的瞭解,明白Git的操做是怎麼回事兒

 

暫存區是Git很是重要的概念,弄明白了暫存區,就弄明白了Git的不少操做到底幹了什麼。

 

     image.png
 
   

 

第一步是用git add把文件添加進去,實際上就是把文件修改添加到暫存區;  stage

第二步是用git commit提交更改,實際上就是把暫存區的全部內容提交到當前分支。 master /  other branch 

Git核心是跟蹤 修改

如今,你又理解了Git是如何跟蹤修改的,每次修改,若是不用git add到暫存區,那就不會加入到commit中。

 

git diff HEAD -- readme.txt命令能夠查看工做區和版本庫裏面最新版本的區別

 

 

撤銷工做區內容和暫存區內容

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

 

場景2:當你不但改亂了工做區某個文件的內容,還添加到了暫存區時,想丟棄修改,分兩步,

 

第一步用命令git reset HEAD file,就回到了場景1,

 

第二步按場景1操做。git checkout -- file

 

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

刪除文件

命令git rm <file>用於刪除版本庫裏的一個文件。若是一個文件已經被提交到版本庫,那麼你永遠不用擔憂誤刪,可是要當心,你只能恢復文件到最新版本,你會丟失最近一次提交後你修改的內容。

rm <file> 用於刪除工做區的文件  ;  若是誤刪了,版本庫裏面還有呢,用

git checkout -- <file>  還原

git checkout 實際上是用版本庫裏的版本替換工做區的版本,不管工做區是修改仍是刪除,均可以「一鍵還原」

刪除遠程庫的文件/文件夾

  1. git rm -r -n --cached  *
  2. git rm -r --cached *
  3. git commit -m"移除src目錄下全部文件的版本控制"
  4. git push origin master

 

遠程倉庫

 

遠程庫- 註冊GitHub 把本地關聯到遠程庫

要關聯一個遠程庫,

使用命令git remote add origin git@server-name:path/repo-name.git

path是 GitHub帳號名, 

repo-name 是倉庫名,

 

關聯後,使用命令git push -u origin master第一次推送master分支的全部內容;

此後,每次本地提交後,只要有必要,就可使用命令git push origin master推送最新修改;

分佈式版本系統的最大好處之一是在本地工做徹底不須要考慮遠程庫的存在,也就是有沒有聯網均可以正常工做,而SVN在沒有聯網的時候是拒絕幹活的!當有網絡的時候,再把本地提交推送一下就完成了同步,真是太方便了!

 

從遠程倉庫克隆到本地

使用命令 

git clone git@github.com:GitHub帳戶名/gitskills.git (文件名)

要克隆一個倉庫,首先必須知道倉庫的地址,而後使用git clone命令克隆。

Git支持多種協議,包括https,但經過ssh支持的原生git協議速度最快。

參數: --depth=1 

depth用於指定克隆深度,爲1即表示只克隆最近一次commit.

 

分支管理

建立切換分支 合併分支 拉取分支 

Git鼓勵大量使用分支:

查看本地分支:git branch

查看遠程庫分支:git branch -r  

查看本地 和 遠程庫分支:git branch -a 

建立分支:git branch <name>

切換分支:git checkout <name>

建立+切換分支:git checkout -b <name>

合併某分支到當前分支:git merge <name>  但會丟掉分支的信息

 

合併某分支到當前分支  帶 --no-ff參數  和 -m 「」添加合併信息的描述:

git merge --no-ff -m "message" <name>  

 

 

刪除分支:git branch -d <name>

刪除遠程庫分支:git push origin -d <name>

 

從遠程庫拉取指定分支:

git checkout -b dev origin/dev

 

git checkout -b dev(本地分支名稱) origin/dev(遠程分支名稱)

 

從遠程庫刪除分支

git push --delete origin testdel (分支名稱)

 

本地分支重命名

git branch -m name rename 

 

 

推送本地分支到遠程倉庫

git push origin dev(分支名稱)

 

從查看分支合併信息:git log --graph

 

分支合併衝突解決

當混賬沒法自動合併分支時,就必須首先解決衝突。解決衝突後,再提交,合併完成。

解決衝突就是把Git的合併失敗的文件手動編輯爲咱們但願的內容,再提交。

git log --graph命令能夠看到分支合併圖產品。

 

分支管理策略

 

image.png                             

Git分支十分強大,在團隊開發中應該充分應用。

合併分支時,加上--no-ff參數就能夠用普通模式合併,合併後的歷史有分支,能看出來曾經作過合併,而fast forward合併就看不出來曾經作過合併。

 

 

image.png                             

 

 

 

Bug分支

忽然要修bug

先把正在開發的現場暫停保存一下

工做現場git stash一下,  修好後回來 git stash pop 回到工做現場

 

 

修復bug時,咱們會經過建立新的bug分支進行修復,而後合併,最後刪除;

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

 

 

開發新功能,建立新的分支

開發一個新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,若是有衝突,要先處理衝突。

 

標籤管理

 

  • 命令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>能夠刪除一個遠程標籤。
相關文章
相關標籤/搜索