git config --global user.name "Your Name"git
git config --global user.email "youremail@domain.com"緩存
# 客戶端需先設置連接用戶名和密碼(避免其後失誤),填寫用戶名和郵箱做爲一個標識dom
1、新建代碼庫fetch
# 在當前目錄新建一個代碼庫,經過這個命令把這個目錄變成git能夠管理的倉庫,這個目錄是Git來跟蹤管理版本的url
$ git initspa
2、配置指針
# Git的配置文件爲.gitconfigorm
# 顯示當前的git配置blog
$ git config --list排序
3、增長/刪除
# 添加指定文件到暫存區
$ git add 「文件名」 可爲文件夾和文件
$ git add . 添加本文件夾下的全部文件到緩存區
# 添加每一個變化前,都會要求確認
# 對於同一個文件的多處變化,能夠實現分次提交
$ git add -p
# 刪除工做區文件,而且將此次刪除放入暫存區
$ git rm 「文件名」
# 中止追蹤指定文件,但該文件會保留在工做區
$ git rm --cached 「文件名」
# 更名文件,而且將這個更名放入暫存區
$ git mv 「修改前文件名」 「修改後文件名」
4、代碼提交
# 首先將文件提交到緩存區
$ git add ‘文件’
# 將緩存區文件提交到倉庫區
$ git commit -m」註釋」
# 提交工做區自上commit以後的變化,直接到倉庫區
$ git commit -a
# 提交時顯示全部diff信息
$ git commit -v
# 使用一次新的commit,替代上一次提交 若是代碼沒有任何新變化,則用來改寫上一次commit提交的信息
$ git commit --amend -m ‘文件名’
# 重複上一次commit,幷包括指定文件的新變化
$ git commit --amend ‘文件名’
# 創建遠程鏈接
$ git remote add ‘別名’ 「遠程鏈接地址」
# 若是代碼需從本地更新並上傳執行推命令(建議:用本身所建新分支)
$ git push ‘與遠程鏈接地址別名一致’ ‘分支名’
# 若是須要從遠程連接獲取代碼執行拉命令
# 執行拉命令不須要執行add、commit命令
# 首先創建遠程鏈接
$ git remote add ‘別名’ ‘遠程鏈接地址’
# 執行拉命令
$ git pull 「與遠程鏈接別名一致」 ‘分支名’
# 建立別名太多容易衝突 (建議:執行完命令以後進行刪除別名)
$ git remote remove ‘別名’ //取消本地目錄下關聯的遠程庫
# 克隆創建遠程鏈接
$ git clone 「遠程鏈接地址」
5、分支的操做
# 分支的建立
$ git branch ‘分支名’
# 切換分支
$ git checkout ‘分支名’
# 列出分支
$ git branch // 列出全部本地分支
$ git branch -r // 列出全部遠程分支
$ git branch -a // 列出全部本地和遠程分支
# 新建分支,並切換到該分支
$ git checkout -b [‘分支名’]
# 切換到上個分支
$ git checkout -
# 新建分支,依然停留在當前分支
$ git branch [‘分支名’]
# 新建分支,與指定的遠程分支創建追蹤關係
$ git branch --track [‘分支名’] [remote-‘遠程分支名’]
# 創建追蹤關係,在現有分支與指定的遠程分值之間
$ git branch --set-upstream [‘分支名’] [‘遠程分支名’]
# 合併指定分支到當前分支
$ git merge [‘分支名’]
# 刪除分支
$ git branch -d [‘分支名’]
# 刪除遠程分支
$ git push origin --delete [‘分支名’]
$ git branch -dr [remote/’分支名’]
6、標籤
# 列出全部tag
$ git tag
# 新建一個tag在當前commit
$ git tag [tag]
# 新建一個tag在指定commit
$ git tag [tag] [commit]
# 刪除本地tag
$ git tag -d [tag]
# 刪除遠程tag
$ git push origin :refs/tags/[‘tagName’]
# 查看tag 信息
$ git show [tag]
# 提交指定tag
$ git push [remote] [tag]
# 提交全部tag
$ git push [remote] --tags
# 新建分支,指向某個tag
$ git checkout -b [branch] [tag]
7、查看信息
# 顯示有變動的文件
$ git status
# 顯示當前分支的版本歷史
$ git log
# 顯示commit歷史,以及每次commit發生變動的文件
$ git log --stat
# 搜索提交歷史,根據關鍵詞
$ git log -S [keyword]
# 顯示某commit後的全部變更,每個commit佔據一行
$ git log [tag] HEAD --pretty=format:%s
# 顯示某個commit以後的全部變更,其"提交說明"必須符合搜索條件
$ git log [tag] HEAD --grep feature
# 顯示某個文件的版本歷史,包括文件更名
$ git log --follow [file]
$ git whatchanged [file]
# 顯示指定文件相關的每一次diff
$ git log -p [file]
# 顯示過去5次提交
$ git log -5 --pretty --oneline
# 顯示全部提交過的用戶,按提交次數排序
$ git shortlog -sn
# 顯示指定文件是什麼人在什麼時間修改過
$ git blame [file]
# 顯示暫存區和工做區的差別
$ git diff
# 顯示暫存區和上一個commit的差別
$ git diff --cached [file]
# 顯示工做區與當前分支最新commit之間的差別 $ git diff HEAD
# 顯示兩次提交之間的差別
$ git diff [first-branch]...[second-branch]
# 顯示今天你寫了多少行代碼
$ git diff --shortstat "@{0 day ago}"
# 顯示某次提交的元數據和內容變化
$ git show [commit]
# 顯示某次提交發生變化的文件
$ git show --name-only [commit]
# 顯示某次提交時,某個文件的內容
$ git show [commit]:[filename]
# 顯示當前分支的最近幾回提交
$ git reflog
8、遠程同步
# 下載遠程倉庫的全部變更
$ git fetch [remote]
# 顯示全部遠程倉庫
$ git remote -v
# 顯示某個遠程倉庫的信息
$ git remote show [remote]
# 增長一個新的遠程倉庫,並命名
$ git remote add [shortname] [url]
# 取回遠程倉庫的變化,並與本地分支合併
$ git pull [remote] [branch]
# 上傳本地指定分支到遠程倉庫
$ git push [remote] [branch]
# 強行推送當前分支到遠程倉庫,即便有衝突
$ git push [remote] --force
# 推送全部分支到遠程倉庫
$ git push [remote] --all
9、撤銷操做
# 恢復暫存區的指定文件到工做區
$ git checkout [file]
# 恢復某個commit的指定文件到暫存區和工做區
$ git checkout [commit] [file]
# 恢復暫存區的全部文件到工做區
$ git checkout .
# 重置暫存區的指定文件,與上一次commit保持一致,但工做區不變
$ git reset [file]
# 重置暫存區與工做區,與上一次commit保持一致 $ git reset --hard
# 重置當前分支的指針爲指定commit,同時重置暫存區,但工做區不變
$ git reset [commit]
# 重置當前分支的HEAD爲指定commit,同時重置暫存區和工做區,與指定commit一致
$ git reset --hard [commit]
# 重置當前HEAD爲指定commit,但保持暫存區和工做區不變
$ git reset --keep [commit]
# 新建一個commit,用來撤銷指定commit# 後者的全部變化都將被前者抵消,而且應用到當前分支
$ git revert [commit]
# 暫時將未提交的變化移除,稍後再移入
$ git stash
$ git stash pop
10、錯誤解決方法
A) CRLF與LF錯誤
B)
a) 解決方式:
# 執行命令進行修改core.autocrlf
git config --global core.autocrlf true