1.初始化
git init 初始化倉庫,新建一個(gè)Git倉庫(新建了一個(gè)隱藏目錄.git)
把遠(yuǎn)程倉庫克隆到本地
git clone git@github.com:lioilwin/lioilwin.github.io.git
git clone git@git.coding.net:lifec/lioilwin.git
把本地倉庫關(guān)聯(lián)到遠(yuǎn)程倉庫
git remote add github git@github.com:lioilwin/lioilwin.github.io.git
git remote add coding git@git.coding.net:lifec/lioilwin.git
遠(yuǎn)程倉庫別名
如果git clone一個(gè)遠(yuǎn)程倉庫, Git會自動添加url,別名為origin
git remote 列出遠(yuǎn)程倉庫別名
git remote -v 遠(yuǎn)程倉庫別名對應(yīng)的實(shí)際url
git remote add [alias] [url] 添加一個(gè)新遠(yuǎn)程倉庫
git remote rm [alias] 刪除遠(yuǎn)程倉庫別名
git remote rename [old-alias] [new-alias] 重命名
git remote set-url [alias] [url] 更改url,可以加上—push和fetch參數(shù),為同一個(gè)別名set不同地址
2.常用
git status
git add .
git commit -m "注釋..."
git push -u origin master
git fetch origin master
git pull origin master
git pull = git fetch + git merge
特殊符號:
~<n>相當(dāng)于連續(xù)的<n>個(gè)^
^代表父提交,當(dāng)一個(gè)提交有多個(gè)父提交時(shí),可以通過在^后面跟上一個(gè)數(shù)字,表示第幾個(gè)父提交 ^相當(dāng)于^1
3.日志/回滾重置
git log --name-only --oneline fileName
git log --oneline --number 每條log只顯示一行,顯示number條
git log --oneline --graph 圖形化顯示分支合并歷史
git log branchname 顯示特定分支
git log --decorate
git log --author=[author name] 指定作者的提交歷史.
git log --since --before --until --after 根據(jù)提交時(shí)間篩選
git log --grep 根據(jù)commit信息過濾
git log --stat 改動信息
git reflog
reflog記錄分支變化或者HEAD引用變化, 當(dāng)git reflog不指定引用時(shí), 默認(rèn)列出HEAD的reflog,
HEAD@{0}代表HEAD當(dāng)前的值, HEAD@{3}代表HEAD在3次變化之前的值,
git會將變化記錄到HEAD對應(yīng)的reflog文件中, 其路徑為.git/logs/HEAD, 分支reflog文件都放在.git/logs/refs的子目錄
git show commitID
git diff
不加參數(shù): show diff of unstaged changes.
git diff --cached 命令
已經(jīng)暫存的文件和上次提交之間的差異
git diff HEAD
show diff of all staged or unstated changes.
git checkout commitID fileName
git revert
git reset --hard
git分為三個(gè)區(qū)域:
1.工作區(qū)(working directry)
2.暫緩區(qū)(stage index)
3.歷史記錄區(qū)(history)
git reset --mixed id history變了(提交記錄變了),但staged 和 working沒變 (默認(rèn)方式)
git reset --soft id history變了(提交記錄變了)和staged區(qū)都變了,但working沒變
git reset --hard id 全都變了
變化范圍:
soft (history) < mixed (history + stage) < hard (history + stage + working)
4.分支
git branch -v 每一個(gè)分支的最后一次提交.
git branch 列出本地所有分支,當(dāng)前分支會被星號標(biāo)示出
git branch mybranch 創(chuàng)建分支
git branch -D mybranch 刪除分支
git checkout mybranch 切換分支
git checkout -b mybranch 創(chuàng)建并切換分支
git rebase master 把master分支更新到當(dāng)前分支
git merge mybranch 分支合并
git push [remote-name] :branch-name 刪除遠(yuǎn)程分支
5.徹底清除垃圾文件,縮減git倉庫
參考GitHub官網(wǎng): https://help.github.com/articles/removing-sensitive-data-from-a-repository
例如, 我的jekyll博客代碼庫提交了大量mp3文件, 使用下面命令清除后代碼庫由233M縮小為1.3M, 提交到GitHub部署博客輕快飛速
# 清除垃圾文件(大量無用的mp3文件)
git filter-branch --force --index-filter 'git rm --cached --ignore-unmatch *.mp3' --prune-empty --tag-name-filter cat -- --all
# 提交到遠(yuǎn)程倉庫(如GitHub, 我再次從git clone GitHub代碼庫會變小為1.3M)
git push origin --force --all
# 必須回收垃圾,本地倉庫才變小
git for-each-ref --format='delete %(refname)' refs/original | git update-ref --stdin
git reflog expire --expire=now --all
git gc --prune=now
rm -rf .git/refs/original
git reflog expire --expire=now --all
git gc --prune=now
git gc --aggressive --prune=now
簡書: http://www.reibang.com/p/6217949e87a3
CSDN博客: http://blog.csdn.net/qq_32115439/article/details/79357615
GitHub博客: http://lioil.win/2018/02/23/Git-Cmd.html
Coding博客: http://c.lioil.win/2018/02/23/Git-Cmd.html