工做這些年,本身總結了一些經常使用的git命令,進行了一些總結,也算是一些經常使用的工具套路。後續會繼續整理一些git工具常見的問題或者解決方法。可能有總結得不對的地方,還請輕噴。
後續會持續更新本身這些年的一些筆記,後續陸續搬到網上。 歡迎指正,共同進步!git
1.git config --system --unset credential.helper
2.git config --global credential.helper store
3.而後再執行pull或者push 操做提示輸入用戶名和新密碼
複製代碼
//在當前目錄新建一個Git代碼庫
$ git init
//新建一個目錄,將其初始化爲Git代碼庫
$ git init [project-name] (不含[ ]號)
//下載一個項目和它的整個代碼歷史
$ git clone [url] (不含[ ]號)
複製代碼
//顯示當前的Git配置
$ git config --list
//編輯Git配置文件
$ git config -e [--global]
//設置提交代碼時的用戶信息
$ git config [--global] user.name "[name]"
$ git config [--global] user.email "[email address]"
複製代碼
//添加指定文件到暫存區
$ git add [file1] [file2] ...
//添加指定目錄到暫存區,包括子目錄
$ git add [dir]
//添加當前目錄的全部文件到暫存區
$ git add .
//添加每一個變化前,都會要求確認
//對於同一個文件的多處變化,能夠實現分次提交
$ git add -p
//刪除工做區文件,而且將此次刪除放入暫存區
$ git rm [file1] [file2] ...
// 中止追蹤指定文件,但該文件會保留在工做區
$ git rm --cached [file]
//更名文件,而且將這個更名放入暫存區
$ git mv [file-original] [file-renamed]
複製代碼
//提交暫存區到倉庫區
$ git commit -m [message]
//提交暫存區的指定文件到倉庫區
$ git commit [file1] [file2] ... -m [message]
//提交工做區自上次commit以後的變化,直接到倉庫區
$ git commit -a
提交時顯示全部diff信息
$ git commit -v
//使用一次新的commit,替代上一次提交
//若是代碼沒有任何新變化,則用來改寫上一次commit的提交信息
$ git commit --amend -m [message]
//重作上一次commit,幷包括指定文件的新變化
$ git commit --amend [file1] [file2] [別的file...]
複製代碼
1 //提交分支數據到遠程服務器
git push origin <本地分支名>:<遠程分支名>
2 //分支重命名
git branch -m 舊分支名 新分支名
3 //當2個獨立倉庫進行合併分支,本地推到遠程的時候,會提示不相關的版本,這個時候,須要在須要推的分支上執行
git pull origin master --allow-unrelated-histories
而後解決衝突,再 add commit push 上去
而後git fetch 更新遠程
而後git push origin <本地分支名>:<遠程分支名>
4 //列出全部本地分支
$ git branch
5 //列出全部遠程分支
$ git branch -r
6 //列出全部本地分支和遠程分支
$ git branch -a
7 //新建一個分支,但依然停留在當前分支
$ git branch [branch-name]
8 //新建一個分支,並切換到該分支
$ git checkout -b [branch]
9 //新建一個分支,指向指定commit
$ git branch [branch] [commit]
10 //新建一個分支,與指定的遠程分支創建追蹤關係
$ git branch --track [branch] [remote-branch]
11 //切換到指定分支,並更新工做區
$ git checkout [branch-name]
12 //切換到上一個分支
$ git checkout -
13 //創建追蹤關係,在現有分支與指定的遠程分支之間
$ git branch --set-upstream [branch] [remote-branch]
14 //合併指定分支到當前分支
$ git merge [branch]
15 //選擇一個commit,合併進當前分支
$ git cherry-pick [commit]
16 //刪除分支
$ git branch -d [branch-name]
17 //刪除遠程分支
$ git push origin --delete [branch-name]
$ git branch -dr [remote/branch]
18 //git重命名遠程分支
18.1 //先刪除遠程分支
git push origin --delete dev
18.2 //重命名本地分支
git branch -m dev develop
18.3 //從新提交一個遠程分支
git push origin develop
複製代碼
//列出全部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]
複製代碼
如:(注意 -a 後的V1.0-2018.9。14 須要和 下面一條命令origin 後面的保持一致,才能將tag推上去,不然報錯)
1:git tag -a V1.0-2018.9.14 -m "描述信息:xxxx V1.0.0版本";
2:git push origin V1.0-2018.9.14
複製代碼
1 //下載遠程倉庫的全部變更
$ git fetch [remote]
2 //顯示全部遠程倉庫
$ git remote -v
3 //顯示某個遠程倉庫的信息
$ git remote show [remote]
4 //增長一個新的遠程倉庫,並命名
$ git remote add [shortname] [url]
5 //取回遠程倉庫的變化,並與本地分支合併
$ git pull [remote] [branch]
6 //上傳本地指定分支到遠程倉庫
$ git push [remote] [branch]
7 //強行推送當前分支到遠程倉庫,即便有衝突
$ git push [remote] --force
8 //推送全部分支到遠程倉庫
$ git push [remote] --all
複製代碼
1 //恢復暫存區的指定文件到工做區
$ git checkout [file]
2 //恢復某個commit的指定文件到暫存區和工做區
$ git checkout [commit] [file]
3 //恢復暫存區的全部文件到工做區
$ git checkout .
4 //重置暫存區的指定文件,與上一次commit保持一致,但工做區不變
$ git reset [file]
5 //重置暫存區與工做區,與上一次commit保持一致
$ git reset --hard
6 //重置當前分支的指針爲指定commit,同時重置暫存區,但工做區不變
$ git reset [commit]
7 //重置當前分支的HEAD爲指定commit,同時重置暫存區和工做區,與指定commit一致
$ git reset --hard [commit]
8 //重置當前HEAD爲指定commit,但保持暫存區和工做區不變
$ git reset --keep [commit]
9 //新建一個commit,用來撤銷指定commit
10 //後者的全部變化都將被前者抵消,而且應用到當前分支
$ git revert [commit]
11 //暫時將未提交的變化移除,稍後再移入
$ git stash
$ git stash pop
複製代碼
//git回退到某個歷史版本
1.git reset --hard 139dcfaa558e3276b30b6b2e5cbbb9c00bbdca96
複製代碼
//撤銷提交信息,重置至指定版本的提交,達到撤銷提交的目的,回滾到某一條記錄,參數soft指的是:保留當前工做區,能夠修改內容後再次提交
//參數hard,會撤銷相應工做區的修改,清除工做區的修改
git reset –soft <該記錄的哈希值>
//撤銷,強制提交當前版本號,以達到撤銷版本號的目的
git push origin master --force
//修改代碼,從新提交和推送
git add .
//從新提交
git commit -m "從新提交時的日誌信息"
//從新推送
git push origin master
複製代碼
1.revert是放棄指定提交的修改,可是會生成一次新的提交,須要填寫提交註釋,之前的歷史記錄都在;
2.reset是指將HEAD指針指到指定提交,歷史記錄中不會出現放棄的提交記錄。
複製代碼
一、//先將本地修改存儲起來
$ git stash
這樣本地的全部修改就都被暫時存儲起來 。
其中stash@{0}就是剛纔保存的標記。
二、//pull內容
暫存了本地修改以後,就能夠pull了。
$ git pull
三、//還原暫存的內容
$ git stash pop stash
或者
//將之前一半的工做應用回來
$ git stash apply
4.有衝突的話,就會報衝突
5.//給stash 加上版本信息記錄
實際應用中推薦給每一個stash加一個message,用於記錄版本,
使用git stash save取代git stash命令:
$ git stash save "test-cmd-stash"
6.//從新應用緩存的stash.
$ git stash pop
命令恢復以前緩存的工做目錄,這個指令將緩存堆棧中的第一個stash刪除
也可使用git stash apply命令,將緩存堆棧中的stash屢次應用到工做目錄中,但並不刪除stash拷
7.//查看現有stash棧列表
$ git stash list命令
8.//在使用git stash apply命令時能夠經過名字指定使用哪一個stash,默認使用最近的stash(即stash@{0})。
$ git stash apply stash@{0}
9.//移除stash,後面能夠跟着stash名字
$ git stash drop stash@{0}
10.//清除全部stash緩存list
git stash clear命令,刪除全部緩存的stash
11.//從stash建立分支
$ git stash branch testchanges
複製代碼
1 //顯示有變動的文件
$ git status
2 //顯示當前分支的版本歷史
$ git log
3 //顯示commit歷史,以及每次commit發生變動的文件
$ git log --stat
4 //搜索提交歷史,根據關鍵詞
$ git log -S [keyword]
5 //顯示某個commit以後的全部變更,每一個commit佔據一行
$ git log [tag] HEAD --pretty=format:%s
6 //顯示某個commit以後的全部變更,其"提交說明"必須符合搜索條件
$ git log [tag] HEAD --grep feature
7 //顯示某個文件的版本歷史,包括文件更名
$ git log --follow [file]
$ git whatchanged [file]
8 //顯示指定文件相關的每一次diff
$ git log -p [file]
9 //顯示過去5次提交
$ git log -5 --pretty --oneline
10 //顯示全部提交過的用戶,按提交次數排序
$ git shortlog -sn
11 //顯示指定文件是什麼人在什麼時間修改過
$ git blame [file]
12 //顯示暫存區和工做區的差別
$ git diff
13 //顯示暫存區和上一個commit的差別
$ git diff --cached [file]
14 //顯示工做區與當前分支最新commit之間的差別
$ git diff HEAD
15 //顯示兩次提交之間的差別
$ git diff [first-branch]...[second-branch]
16 //顯示今天你寫了多少行代碼
$ git diff --shortstat "@{0 day ago}"
17 //顯示某次提交的元數據和內容變化
$ git show [commit]
18 //顯示某次提交發生變化的文件
$ git show --name-only [commit]
19 //顯示某次提交時,某個文件的內容
$ git show [commit]:[filename]
20 //顯示當前分支的最近幾回提交
$ git reflog
複製代碼
//查看最新
1.git show
//查看最近n次提交的修改
2. git log -p -n
//能夠查找某一個做者全部的提交
3.git log --author=「author」
//列出文件的全部修改記錄
4.git log -p filename
//查看遠程倉庫日誌
5.git log origin/master -n 3
//git查看遠程與本地之間的差別
6.git diff origin/master master --minimal
//在git bash窗口,將每條記錄單獨一行列出來
7.git log --pretty=format:"%h - %an, %ar : %s"
git log --pretty=format:"%h %s" --graph ---》》》 圖像化輸出
### 參數列表
%H 提交對象(commit)的完整哈希字串
%h 提交對象的簡短哈希字串
%T 樹對象(tree)的完整哈希字串
%t 樹對象的簡短哈希字串
%P 父對象(parent)的完整哈希字串
%p 父對象的簡短哈希字串
%an 做者(author)的名字
%ae 做者的電子郵件地址
%ad 做者修訂日期(能夠用 -date= 選項定製格式)
%ar 做者修訂日期,按多久之前的方式顯示
%cn 提交者(committer)的名字
%ce 提交者的電子郵件地址
%cd 提交日期
%cr 提交日期,按多久之前的方式顯示
%s 提交說明
如何使用git查看commit修改了哪些內容,以便後續的代碼工做。與之相關的命令就是:
git log 查看全部的commit提交記錄
git show 查看提交的詳情
具體步驟:
首先,須要經過git log打印全部commit記錄,例如
複製代碼
以後的git show都是基於commit hashID輸出的。
1.查看最新的commit
git show
2.查看指定commit hashID的全部修改:
git show commitId
3.查看某次commit中具體某個文件的修改:
git show commitId fileName
使用git log --author=「author」 能夠查找某一個做者全部的提交
複製代碼
//生成一個可供發佈的壓縮包
$ git archive
複製代碼
待續,後續持續更新。。。緩存