Git命令大全

1.$ git config --global user.name "Your Name"
  $ git config --global user.email "email@example.com"git

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

3.添加文件到Git倉庫,分兩步:
    第一步,使用命令git add <file>,注意,可反覆屢次使用,添加多個文件;
    第二步,使用命令git commit,完成。服務器

4.查看全部文件ls -ah
  查看某一個文件的歷史提交信息,git blame [file_name]app

5.要隨時掌握工做區的狀態,使用git status命令。ssh

6.若是git status告訴你有文件被修改過,用git diff能夠查看修改內容。日誌

7.HEAD指向的版本就是當前版本,所以,Git容許咱們在版本的歷史之間穿梭,使用命令git reset --hard commit_id(7位)或git reset --hard HEAD^。
 HEAD^上一個版本
 HEAD^^上上個版本
 HEAD~100上100個版本orm

8.穿梭前,用git log能夠查看提交歷史,以便肯定要回退到哪一個版本。server

9.要重返將來,用git reflog查看命令歷史,以便肯定要回到將來的哪一個版本。開發

10.直接丟棄工做區的修改時,用命令git checkout -- file,此時返回的是上一次保存暫存區的版本,若是沒有保存暫存區,那麼返回上一次提交的版本rem

11.丟棄暫存區的修改git reset HEAD file,和回退到最新版本一個意思,工做區的內容不會變更

12.命令git rm用於刪除一個文件。一樣只是對暫存區的操做,須要git commit

13.$ ssh-keygen -t rsa -C "youremail@example.com"
  這個命令用來建立與github鏈接用的非對稱密鑰對

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

15.git push -u origin master第一次推送master分支的全部內容

16.每次本地提交後,只要有必要,就可使用命令git push origin master推送最新修改
壓縮本地的多個commit,git rebase -i HEAD~[number_of_commits],這一過程本質上重寫了你的commit歷史。


17.要克隆一個倉庫,首先必須知道倉庫的地址,而後使用git clone git@github.com:wjwjtftf/gitskills.git命令克隆。
  Git支持多種協議,包括https,但經過ssh支持的原生git協議速度最快。

18.Git鼓勵大量使用分支:
  查看分支:git branch
  建立分支:git branch <name>
  刪除分支:git branch -d <name>

  切換分支:git checkout <name>
  建立+切換分支:git checkout -b <name>
  合併某分支到當前分支:git merge <name>
 
19.用git log --graph --pretty=oneline --abbrev-commit命令能夠看到分支合併圖

20.合併分支時,git merge --no-ff -m "merge with no-ff" dev。加上--no-ff參數就能夠用普通模式合併,合併後的歷史有分支,能看出來曾經作過合併,而fast forward合併就看不出來曾經作過合併。
另外一個本地分支的commit修改應用到當前分支,git check-pick <commit id>

21.當手頭工做沒有完成時,先把工做現場git stash一下,而後去修復bug,修復後,再git stash pop,回到工做現場。
  stash(儲藏)功能:git stash list 查看全部的工做現場
  恢復工做現場:一是用git stash apply恢復,可是恢復後,stash內容並不刪除,你須要用git stash drop來刪除;另外一種方式是用git stash pop,恢復的同時把stash內容也刪了

22.開發一個新feature,最好新建一個分支;若是要丟棄一個沒有被合併過的分支,能夠經過git branch -D <name>強行刪除。

23.查看遠程庫信息,使用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 push remote 本地分支名:遠程分支名

24.命令git tag <name> <commit-id>用於新建一個標籤,默認爲HEAD,也能夠指定一個commit id;
  git tag -a <tagname> -m "blablabla..."能夠指定標籤信息;
  git tag -s <tagname> -m "blablabla..."能夠用PGP簽名標籤;
  命令git tag能夠查看全部標籤。
  git show <tagname>能夠查看標籤詳情

25.命令git push origin <tagname>能夠推送一個本地標籤;
  命令git push origin --tags能夠推送所有未推送過的本地標籤;
  命令git tag -d <tagname>能夠刪除一個本地標籤;
  命令git push origin :refs/tags/<tagname>能夠刪除一個遠程標籤。

26.忽略某些文件時,須要編寫.gitignore;
  .gitignore文件自己要放到版本庫裏,而且能夠對.gitignore作版本管理!
  https://github.com/github/gitignore上能夠查找現現成的

27.git log -1查看最近一第二天志
  --global參數是全局參數,也就是這些命令在這臺電腦的全部Git倉庫下都有用
    全局配置在當前用戶主目錄下.gitconfig文件
    倉庫的配置在.git/config文件

28.配置別名
  默認st標示status,co表示checkout
  git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit"
 
29.搭建git遠程倉庫
  git init --bare sample.gitGit就會建立一個裸倉庫,裸倉庫沒有工做區,由於服務器上的Git倉庫純粹是爲了共享,因此不讓用戶直接登陸到服務器上去改工做區,而且服務器上的Git倉庫一般都以.git結尾.

30.檢查丟失的提交git fsck --lost-foundgit show <commit_id>,查看提交以後的改變或者運行git merge <commit_id>來恢復到以前的提交

相關文章
相關標籤/搜索