本文記錄了在Git學習中的一些要點,主要涉及Git日常使用的一些基礎操作和簡單使用。

首先,我們需要熟悉Git的幾個操作區域:

Workspace: 工作區

Index / Stage: 暫存區

Respository: 本地倉庫

Remote: 遠程倉庫


Git操作在各區域間的體現

Git基礎


創建版本庫

  • 初始化一個Git倉庫,使用git init命令。
  • 添加文件到Git倉庫,分兩步:
  1. 第一步,使用命令git add <file>,注意,可反覆多次使用,添加多個文件,若需添加所有,則可使用git add .git add -A
  1. 第二步,使用命令git commit -m '<message>',完成。

代碼提交

  • 提交暫存區文件到倉庫區git commit -m 'message'
  • 提交暫存區的指定文件到倉庫區git commit <file1> <file2> ... -m '<message>'
  • 提交工作去自上次commit之後的變化到倉庫區git commit -a
  • 提交時显示diff信息git commit -v
  • 使用一次新的commit,替代上一次commit(如果無任何改變則改寫上一次提交信息)git commit --amend -m '<message>'

時光穿梭

  • 要隨時掌握工作區的狀態,使用git status命令。
  • 如果git status告訴你有文件被修改過,用git diff可以查看修改內容。

版本回退

  • HEAD指向的版本就是當前版本,因此,Git允許我們在版本的歷史之間穿梭,使用命令git reset --hard commit_id
  • 穿梭前,用git log可以查看提交歷史,以便確定要回退到哪個版本。
  • 要重返未來,用git reflog查看命令歷史,以便確定要回到未來的哪個版本。

撤銷修改

  • 場景1:當你改亂了工作區某個文件的內容,想直接丟棄工作區的修改時,用命令git checkout -- file
  • 場景2:當你不但改亂了工作區某個文件的內容,還添加到了暫存區時,想丟棄修改,分兩步,第一步用命令git reset HEAD file,就回到了場景1,第二步按場景1操作。
  • 場景3:已經提交了不合適的修改到版本庫時,想要撤銷本次提交,參考版本回退一節,不過前提是沒有推送到遠程庫。

刪除文件

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

添加遠程庫

  • 要關聯一個遠程庫,使用命令git remote add origin [email protected]:path/repo-name.git
  • 關聯后,使用命令git push -u origin master第一次推送master分支的所有內容;
  • 此後,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改。

從遠程庫克隆

  • 要克隆一個倉庫,首先必須知道倉庫的地址,然後使用git clone命令克隆。
  • Git支持多種協議,包括https,但通過ssh支持的原生git協議速度最快。

解決衝突

  • 當Git無法自動合併分支時,就必須首先解決衝突。解決衝突后,再提交,合併完成。
  • git log --graph命令可以看到分支合併圖。

分支

普通分支

  • 查看分支:git branch
  • 查看所有遠程分支: git branch -r
  • 列出所有本地分支和遠程分支:git branch -a
  • 創建分支,但仍然停留在當前分支:git branch <branch name>
  • 創建分支並切換到新分支:git checkout -b <branch>
  • 創建分支,與指定的遠程分支建立追蹤關係:git branch --track <branch name> <remote-branch>
  • 切換分支,並更新工作區:git checkout <branch name>
  • 切換到上一個分支:git checkout -
  • 合併某分支到當前分支:git merge <branch name>
  • 刪除分支:git branch -d <name>
  • 查看歷史日誌:git log --graph --pretty=oneline --abbrev-commit

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,如果有衝突,要先處理衝突。

創建標籤

  • 命令git tag <name>用於新建一個標籤,默認為HEAD,也可以指定一個commit id;
  • git tag -a <tagname> -m "blablabla..."可以指定標籤信息;
  • git tag -s <tagname> -m "blablabla..."可以用PGP簽名標籤;
  • 命令git tag可以查看所有標籤。

操作標籤

  • 命令git push origin <tagname>可以推送一個本地標籤;
  • 命令git push origin --tags可以推送全部未推送過的本地標籤;
  • 命令git tag -d <tagname>可以刪除一個本地標籤;
  • 命令git push origin :refs/tags/<tagname>可以刪除一個遠程標籤。

忽略文件

  • 忽略某些文件時,需要編寫.gitignore;
  • .gitignore文件本身要放到版本庫里,並且可以對.gitignore做版本管理!

Git使用


配置SSH公鑰驗證(免密碼登錄)

  1. 首先進入賬戶目錄下,查看是否有id_rsa.pub 和 id_rsa文件;
  1. 如果沒有,需要創建公鑰和密鑰:ssh-keygen,此時需要輸入兩次密碼,如果不需要設置密碼,直接回車,默認生成的兩個文件是:
  • id_rsa
  • id_rsa.pub
  1. 查看並將公鑰添加到git源碼服務器即可。先查看公鑰:cat id_rsa.pub,然後將公鑰內容添加到服務器的~/.ssh/authorized_keys 文件中。

了解更多

  • Git官方文檔
  • 廖雪峰Git教程

歡迎訪問我的個人博客查看其他文章。


分享