GIT 常用命令



  1. 初始化一個Git倉庫,使用git init命令。
  2. 添加文件到Git倉庫,分兩步:
    第一步,使用命令git add file,注意,可反覆多次使用,添加多個文件;
    第二步,使用命令git commit,完成。
  3. 要隨時掌握工作區的狀態,使用git status命令。
  4. 如果git status告訴你有文件被修改過,用git diff可以查看修改內容。
  5. HEAD指向的版本就是當前版本,因此,Git允許我們在版本的歷史之間穿梭,使用命令git reset –hard commit_id。
  6. 穿梭前,用git log可以查看提交歷史,以便確定要回退到哪個版本。
  7. 要重返未來,用git reflog查看命令歷史,以便確定要回到未來的哪個版本。
  8. 場景1:當你改亂了工作區某個文件的內容,想直接丟棄工作區的修改時,用命令git checkout – file
    場景2:當你不但改亂了工作區某個文件的內容,還添加到了暫存區時,想丟棄修改,分兩步,第一步用命令git reset HEAD file,就回到了場景1,第二步按場景1操作。
    場景3:已經提交了不合適的修改到版本庫時,想要撤銷本次提交,參考版本回退一節,不過前提是沒有推送到遠程庫。
  9. 命令git rm用於刪除一個文件。如果一個文件已經被提交到版本庫,那麼你永遠不用擔心誤刪,但是要小心,你只能恢復文件到最新版本,你會丟失最近一次提交後你修改的內容。
  10. 要關聯一個遠程庫,使用命令git remote add origin git@server-name:path/repo-name.git;關聯後,使用命令git push -u origin master第一次推送master分支的所有內容;此後,每次本地提交後,只要有必要,就可以使用命令git push origin master推送最新修改;
  11. 要克隆一個倉庫,首先必須知道倉庫的地址,然後使用git clone命令克隆。
  12. Git支持多種協議,包括https,但通過ssh支持的原生git協議速度最快。
  13. 查看分支:git branch
  14. 創建分支:git branch name
  15. 切換分支:git checkout name
  16. 創建+切換分支:git checkout -b name
  17. 合併某分支到當前分支:git merge name
  18. 刪除分支:git branch -d name
  19. 當Git無法自動合併分支時,就必須首先解決衝突。解決衝突後,再提交,合併完成;用git log –graph命令可以看到分支合併圖。
  20. 合併分支時,加上–no-ff參數就可以用普通模式合併,合併後的歷史有分支,能看出來曾經做過合併,而fast forward合併就看不出來曾經做過合併。
  21. 修復bug時,我們會通過創建新的bug分支進行修復,然後合併,最後刪除;當手頭工作沒有完成時,先把工作現場git stash一下,然後去修復bug,修復後,再git stash pop,回到工作現場。
  22. 開發一個新feature,最好新建一個分支;如果要丟棄一個沒有被合併過的分支,可以通過git branch -D name強行刪除。
  23. 查看遠程庫信息,使用git remote -v
  24. 本地新建的分支如果不推送到遠程,對其他人就是不可見的;
  25. 從本地推送分支,使用git push origin branch-name,如果推送失敗,先用git pull抓取遠程的新提交;
  26. 在本地創建和遠程分支對應的分支,使用git checkout -b branch-name origin/branch-name,本地和遠程分支的名稱最好一致;
  27. 建立本地分支和遠程分支的關聯,使用git branch –set-upstream branch-name origin/branch-name
  28. 從遠程抓取分支,使用git pull,如果有衝突,要先處理衝突。
  29. 命令git tag name用於新建一個標籤,默認爲HEAD,也可以指定一個commit id
  30. git tag -a tagname -m “blablabla…”可以指定標籤信息;
  31. git tag -s tagname -m “blablabla…”可以用PGP簽名標籤;
  32. 命令git tag可以查看所有標籤。
  33. 命令git push origin tagname可以推送一個本地標籤;
  34. 命令git push origin –tags可以推送全部未推送過的本地標籤;
  35. 命令git tag -d tagname可以刪除一個本地標籤;
  36. 命令git push origin :refs/tags/tagname可以刪除一個遠程標籤。
  37. GitHub上,可以任意Fork開源倉庫;
  38. 自己擁有Fork後的倉庫的讀寫權限;
  39. 可以推送pull request給官方倉庫來貢獻代碼。
  40. 忽略某些文件時,需要編寫.gitignore
  41. .gitignore文件本身要放到版本庫裏,並且可以對.gitignore做版本管理!



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章