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>來恢復到以前的提交