Git 學習筆記

根據廖雪峰老師的Git學習教程整理的筆記,在此再次感謝廖老師和像廖老師那樣無私奉獻的前輩!

1 安裝Git


2 創建版本庫


2.1.1 通過git init命令建好倉庫

$ git init
Initialized empty Git repository in /Users/michael/learngit/.git/

ps:

pwd命令用于顯示當前目錄,這樣就在當前的目錄下多了一個.git的目錄,這個目錄是Git來跟蹤管理版本庫的,沒事千萬不要手動修改這個目錄里面的文件,不然改亂了,就把Git倉庫給破壞了。

如果你沒有看到.git目錄,那是因為這個目錄默認是隱藏的,用ls -ah命令就可以看見。

2.1.2 增加了文件之后,用命令git add <file>,可以多次使用添加多個文件,或者使用git add -A添加所有文件


2.1.3 使用命令git commit,完成

ps: 完整實例命令如下:
$ git add file1.txt
$ git add file2.txt file3.txt
$ git commit -m "add 3 files."

2.2.1 時光機穿梭

ps

.用命令git status查看倉庫的狀態

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


2.2.2 <a name="versionBack"></a>版本回退

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

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

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


2.2.3 管理修改

ps

git diff HEAD -- readme.txt命令可以查看工作區和版本庫里面最新版本的區別

$ git diff HEAD -- readme.txt 
diff --git a/readme.txt b/readme.txt
index 76d770f..a9c5755 100644
--- a/readme.txt
+++ b/readme.txt
@@ -1,4 +1,4 @@
 Git is a distributed version control system.
 Git is free software distributed under the GPL.
 Git has a mutable index called stage.
-Git tracks changes.
+Git tracks changes of files.
工作區和版本庫的區別.png

2.2.4 撤銷修改

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

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

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


2.2.4 刪除文件

命令git rm用于刪除一個文件。如果一個文件已經被提交到版本庫,那么你永遠不用擔心誤刪,但是要小心,你只能恢復文件到最新版本,你會丟失最近一次提交后你修改的內容。


3 遠程倉庫

第1步:創建SSH Key。在用戶主目錄下,看看有沒有.ssh目錄,如果有,再看看這個目錄下有沒有id_rsa和id_rsa.pub這兩個文件,如果已經有了,可直接跳到下一步。如果沒有,打開Shell(Windows下打開Git Bash),創建SSH Key:

$ ssh-keygen -t rsa -C "youremail@example.com"
你需要把郵件地址換成你自己的郵件地址,然后一路回車,使用默認值即可,由于這個Key也不是用于軍事目的,所以也無需設置密碼。

如果一切順利的話,可以在用戶主目錄里找到.ssh目錄,里面有id_rsa和id_rsa.pub兩個文件,這兩個就是SSH Key的秘鑰對,id_rsa是私鑰,不能泄露出去,id_rsa.pub是公鑰,可以放心地告訴任何人。

第2步:登陸GitHub,打開“Account settings”,“SSH Keys”頁面:

然后,點“Add SSH Key”,填上任意Title,在Key文本框里粘貼id_rsa.pub文件的內容:


3.1 添加遠程庫

現在的情景是,你已經在本地創建了一個Git倉庫后,又想在GitHub創建一個Git倉庫,并且讓這兩個倉庫進行遠程同步,這樣,GitHub上的倉庫既可以作為備份,又可以讓其他人通過該倉庫來協作,真是一舉多得。

在GitHub上的這個learngit倉庫還是空的,GitHub告訴我們,可以從這個倉庫克隆出新的倉庫,也可以把一個已有的本地倉庫與之關聯,然后,把本地倉庫的內容推送到GitHub倉庫。

要關聯一個遠程庫
使用命令git remote add origin git@server-name:path/repo-name.git

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

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


3.2 從遠程庫克隆

上次我們講了先有本地庫,后有遠程庫的時候,如何關聯遠程庫。
現在,假設我們從零開發,那么最好的方式是先創建遠程庫,然后,從遠程庫克隆。
首先,登陸GitHub,創建一個新的倉庫,名字叫gitskills:

如果有多個人協作開發,那么每個人各自從遠程克隆一份就可以了。

你也許還注意到,GitHub給出的地址不止一個,還可以用https://github.com/michaelliao/gitskills.git這樣的地址。實際上,Git支持多種協議,默認的git://使用ssh,但也可以使用https等其他協議。

使用https除了速度慢以外,還有個最大的麻煩是每次推送都必須輸入口令,但是在某些只開放http端口的公司內部就無法使用ssh協議而只能用https。

小結

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

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


4 分支管理

4.1 創建與合并分支

git checkout命令加上-b參數表示創建并切換
git branch命令查看當前分支,當前分支前面會標一個*號。

dev分支的工作完成后,切換回master分支, git checkout master

然后,把dev分支的工作成果合并到master分支上:

$ git merge dev
Updating d17efd8..fec145a
Fast-forward
 readme.txt |    1 +
 1 file changed, 1 insertion(+)

git merge命令用于合并指定分支到當前分支。

合并完成之后,就可以放心的刪除dev 分支了:

git branch -d dev

ps:

Git鼓勵大量使用分支:

查看分支:git branch

創建分支:git branch <name>

切換分支:git checkout <name>

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

合并某分支到當前分支:git merge <name>

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


4.2 解決沖突

當Git無法自動合并分支時,就必須首先解決沖突。解決沖突后,再提交,合并完成。
git log --graph命令可以看到分支合并圖
git log --graph --pretty=oneline --abbrev-commit


4.3 分支管理策略

準備合并dev分支,請注意--no-ff參數,表示禁用Fast forward

$ git merge --no-ff -m "merge with no-ff" dev
Merge made by the 'recursive' strategy.
 readme.txt |    1 +
 1 file changed, 1 insertion(+)

因為本次合并要創建一個新的commit,所以加上-m參數,把commit描述寫進去。


4.4 bug分支

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

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

ps:

git stash list查看“隱藏”的分支,恢復有兩個辦法:

一是用git stash apply恢復,但是恢復后,stash內容并不刪除,你需要用git stash drop來刪除;

另一種方式是用git stash pop,恢復的同時把stash內容也刪了


4.5 新功能分支

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

如果要丟棄一個沒有被合并過的分支,可以通過git branch -D <name>強行刪除。


4.6 多人協作

你的小伙伴要在dev分支上開發,就必須創建遠程origindev分支到本地,于是他用這個命令創建本地dev分支:
git checkout -b dev origin/dev

因此,多人協作的工作模式通常是這樣:

首先,可以試圖用git push origin branch-name推送自己的修改;

如果推送失敗,則因為遠程分支比你的本地更新,需要先用git pull試圖合并;

如果合并有沖突,則解決沖突,并在本地提交;

沒有沖突或者解決掉沖突后,再用git push origin branch-name推送就能成功!

如果git pull提示“no tracking information”,則說明本地分支和遠程分支的鏈接關系沒有創建,用命令git branch --set-upstream-to origin/dev dev

這就是多人協作的工作模式,一旦熟悉了,就非常簡單。

小結

查看遠程庫信息,使用git remote -v

本地新建的分支如果不推送到遠程,對其他人就是不可見的;

從本地推送分支,使用git push origin branch-name,如果推送失敗,先用git pull抓取遠程的新提交;

在本地創建和遠程分支對應的分支,使用git checkout -b branch-name origin/branch-name,本地和遠程分支的名稱最好一致;

建立本地分支和遠程分支的關聯,使用git branch --set-upstream-to origin/dev dev

從遠程抓取分支,使用git pull,如果有沖突,要先處理沖突。


5 標簽管理

5.1 創建標簽

命令git tag <name>用于新建一個標簽,默認為HEAD,也可以指定一個commit id

git tag -a <tagname> -m "blablabla..."可以指定標簽信息;

git tag -s <tagname> -m "blablabla..."可以用PGP簽名標簽;

命令git tag可以查看所有標簽


5.2 操作標簽

  • 命令 git push origin <tagname> 可以推送一個本地標簽;

  • 命令git push origin --tags可以推送全部未推送過的本地標簽;

  • 命令git tag -d <tagname>可以刪除一個本地標簽;

  • 命令git push origin :refs/tags/<tagname>可以刪除一個遠程標簽。


后續:

1. 刪除github遠程dev分支(git push [遠程名] :[分支名])

  • git push origin :dev
  • 注意:origin后有空格

2. git add -u,使用-u參數調用了git add命令,會將本地有改動(包括刪除和修改)的已經追蹤的文件標記到暫存區中。

3.刪除所有存儲的進度

git stash clear

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • Git教程 一、Git簡介 1.1. Git的誕生1.2.集中式的vs分布式 二、安裝Git 三、創建版本庫 四、...
    曹淵說創業閱讀 959評論 0 2
  • 1. 安裝 Github 查看是否安裝git: $ git config --global user.name "...
    Albert_Sun閱讀 13,721評論 9 163
  • ◆◆◆特別聲明◆◆◆ 本篇文章系本人學習《廖雪峰Git教程》筆記,主要用作自己復習使用。首先向廖雪峰老師表示感謝,...
    CalvinNing閱讀 588評論 0 1
  • “那你準備好等死了嗎?” 紫云真君平靜得不帶絲毫漣漪的聲音在天地間傳開,這種話如果從旁人的嘴中說出來,怕是會讓人感...
    混沌天書閱讀 529評論 0 0
  • 章節目錄 第五十三章:失竊 眾人之中,唯有赫連傾看得清獨孤求敗出招,不禁大吃一驚,心想這位少年小小年紀,武功深不可...
    南語上閱讀 297評論 1 14