git init
在當前目錄中初始化Git倉庫git init [project-name]
建立一個新目錄並初始化倉庫
初始化git倉庫會默認建立一個mater分支,建立名爲.git的子目錄,內含初始化Git倉庫中全部的骨幹文件,此時倉庫中的文件尚未被跟蹤。
經過git add命令來實現對指定文件的跟蹤,而後執行git commit提交。git
git add . git commit -m 'initial project version'
.git倉庫目錄以下:
A、HEAD:當前處於哪一個分支
B、config:項目的配置信息
C、description:項目描述信息
D、index:索引文件(暫存區)
E、hooks/:系統默認鉤子腳本目錄
F、logs/:各個refs的歷史信息
G、objects/:git倉庫的全部對象(commit,tree,blog,tag)
H、refs/:標識目錄中每個分支指向哪一個commitgithub
Git克隆倉庫的命令格式: git clone [url]
當執行git clone命令的時候,默認配置下遠程Git倉庫中的每個文件的每個版本都將被拉取下來。全部本地分支默認與遠程主機的同名分支,並創建追蹤關係。
克隆Git的可連接庫libgit2的命令以下:
git clone https://github.com/libgit2/libgit2
在當前目錄下建立一個名爲libgit2的目錄,並在目錄下初始化一個.git目錄,從遠程倉庫拉取下全部數據放入.git目錄,而後從中讀取最新版本的文件的拷貝。
若是指定本地建立的倉庫名字變爲libgit,可使用:
git clone https://github.com/libgit2/libgit2 libgit
git clone是一個封裝了其它命令的命令,執行git clone命令會執行如下操做:建立一個新目錄,切換到新的目錄,而後git init來初始化一個空的Git倉庫,而後爲指定的URL添加一個(默認名稱爲origin)遠程倉庫(git remote add),再針對遠程倉庫執行git fetch,最後經過git checkout將遠程倉庫的最新提交檢出到本地的工做目錄。
git clone支持四種協議,HTTP(S)、SSH、Git、本地文件協議。git clone -o newname [url]
從url克隆倉庫時指定建立目錄爲newname
2、Git文件操做
一、Git文件狀態
Untracked: 未跟蹤,文件在工做目錄中,但沒有加入到倉庫,不參與版本控制。經過git add將狀態變爲Staged。
Unmodified: 文件已經加入版本庫,未修改,即版本庫中的文件快照內容與工做目錄中徹底一致。若是被修改,變爲Modified;若是使用git rm移出版本庫,則成爲Untracked。
Modified: 文件被修改,並無進行其它操做。經過git add可進入暫存staged狀態,使用git checkout則丟棄修改,返回到unmodified狀態。git checkout即從版本庫中取出文件,覆蓋當前修改。
Staged: 暫存狀態。執行git commit則將修改同步到版本庫中,此時版本庫中的文件和本地文件一致,文件爲Unmodified狀態。執行git reset HEAD filename取消暫存,文件狀態爲Modified。
文件狀態的查看可使用以下命令:git status [filename]
查看指定文件狀態git status
查看全部文件狀態緩存
git add將工做目錄的變化添加到暫存區,以備下次提交。 git add [file1] [file2] ...
添加指定文件到暫存區git add [dir]
添加指定目錄到暫存區,包括子目錄app
git add . 添加新文件和被修改文件到暫存區,但不包括被刪除文件 git add -u 提交被修改和被刪除文件到暫存區,不包括新文件 git add -A 添加工做目錄的全部變化到暫存區
git rm --cached <file>
直接從暫存區刪除文件,工做區則不作改變git reset HEAD <file>...
若是已經用add把文件加入暫存區,先須要從暫存區中撤銷;
當執行git reset HEAD命令時,暫存區的目錄樹會被重寫,被當前分支指向的目錄樹所替換,但工做區不受影響。git clean [options]
移除全部未跟蹤文件,-d表示包含目錄,-f表示強制清除。git rm filename
刪除暫存區、工做目錄中的文件ide
git diff用於查看工做目錄中的文件和暫存區文件的差別git diff [files]
當暫存區中沒有文件時,比較工做區中的文件與上次提交到版本庫中文件的差別;當暫存區中有文件時,比較當前工做區中文件與暫存區中文件的差別。git diff --cached
比較暫存區的文件與已經提交過的文件git diff HEAD~n
比較某個歷史版本與工做目錄中的文件差別fetch
git checkout用於Git版本庫檢出,會重寫工做目錄,是危險的命令。git checkout branch
檢出branch分支。將HEAD指向branch分支,用branch 的當前目錄樹更新暫存區和工做目錄。url
git checkout git checkout HEAD
顯示工做目錄、暫存區與HEAD的差別。git checkout -- filename
用暫存區中filename文件來覆蓋工做目錄中的filename文件。git checkout .
用暫存區所有文件覆蓋工做目錄的所有文件git checkout -- filename
用暫存區的指定文件覆蓋工做目錄的指定文件git checkout HEAD .
用HEAD指向分支中的所有文件覆蓋暫存區和工做目錄中的文件3d
git checkout HEAD <file>
用HEAD指向分支中的指定文件覆蓋暫存區和工做目錄中的文件git checkout branch -- filename
維持HEAD的指向不變,用branch所指向提交中filename文件覆蓋暫存區和工做區中相應的文件。git checkout commit_id -- file_name
維持HEAD的指向不變,用commit_id,所指向提交中filename文件覆蓋暫存區和工做區中相應的文件。版本控制
當git commit命令執行時,將暫存區的全部文件內容在版本庫中建立一個持久的快照,而後將當前分支上的HEAD指針移到新建立的快照上。每一次提交會生成一個commit對象,每個commit對象指向一個tree對象,每一個tree對象指向一個文件夾或文件。git commit -m [message]
提交暫存區到本地倉庫git commit [file1] [file2] ... -m [message]
提交暫存區的指定文件到本地倉庫git commit -a
提交工做區的變化直接到本地倉庫,對新文件無效git commit -v
提交時顯示全部diff信息git commit --amend -m [message]
修訂提交,使用一次新的commit,替代上一次提交。若是代碼沒有任何新變化,則用來改寫上一次commit的提交信息git commit --amend [file1] [file2] ...
重作上一次commit,幷包括指定文件的新變化git revert commit-id
撤回指定版本的內容並提交一個新的commit,不影響以前提交的內容指針
查看提交日誌可使用git loggit log --graph
以圖形化的方式顯示提交歷史的關係git reflog
記錄倉庫中全部的分支的全部更新記錄,包括已經撤銷的更新。git log --pretty=oneline
單行顯示全部提交日誌信息git log -n
打印最近n次的提交日誌信息
git ls-files用於查看指定狀態的文件列表git ls-files
默認查看全部緩存的文件git ls-files -o
查看未被跟蹤的文件git ls-files --modified
查看被修改的文件git ls-files -s
查看暫存區中文件詳細
在實際工程開發中,可能須要緊急修復某個bug,但當前工做目錄中工做可能沒有完成,須要臨時保存,以便清理工做目錄,切換到其它分支進行修復。此時,可使用壓棧儲藏功能。git stash
將工做區的全部文件壓棧到儲藏區git stash --list
查看壓棧儲藏區的全部stash列表git stash pop [stash_id]
從儲藏棧彈出棧頂的數據,恢復到工做目錄,,能夠指定stash_idgit stash drop [stash_id]
將儲藏棧棧頂的數據彈出拋棄,能夠指定stash_idgit stash apply [--index] [stash_id]
若是執行git stash時工做區的狀態是部分文件已經加入暫存區,部分文件沒有,當執行git stash apply後會發現全部文件都變成未暫存的,若是想維持原來暫存的文件仍然是暫存狀態,能夠加上--index參數。能夠指定stash_id。git stash clear
刪除儲藏棧中全部的數據
git reset [options] commit_id
git reset命令主要用來根據傳遞給動做的參數來執行撤銷操做。 git reset會使HEAD指向指定的commit_id,通常會用到3個參數,參數會影響到工做區與暫存區中的修改:
--soft: 只改變HEAD的State,不更改工做區與暫存區的內容
--mixed(默認): 撤銷暫存區的修改,暫存區的修改會轉移到工做區
--hard: 撤銷工做區與暫存區的修改
git rm -f filename
刪除暫存區、工做目錄中的fiename文件git rm --cached filename
刪除暫存區中的filename文件,工做目錄中不作修改
對於未跟蹤狀態的文件,直接刪除文件便可
git branch
列出全部本地分支git branch -r
列出全部遠程分支git branch -a
列出全部本地分支和遠程分支
git branch [branch-name]
新建一個branch-name分支,但停留在當前分支git checkout -b [branch]
新建一個branch分支並切換到該分支git branch [branch] [commit_id]
新建一個分支,指向指定commit_id提交git branch --track [branch] [remote-branch]
新建一個分支,並與遠程分支創建追蹤關係
git checkout [branch-name]
切換到指定分支,並更新工做目錄git checkout -
切換到上一個分支git branch --set-upstream [branch] [remote-branch]
在現有指定分支與指定的遠程分支之間創建追蹤關係
git merge用來合併一個或者多個分支到當前分支中,而後將HEAD指針移動到合併結果的提交快照上。git merge branchname
將branchname分支合併到當前分支git merge [remote/branch]
合併獲取的遠程分支到當前分支git merge –ff branch
使用快進式(fast-forward)合併分支,不會產生新的合併提交快照,是默認合併方式。git merge –no-ff branch
使用非快進式合併,會建立一個新的合併提交快照
fast-forward:
no-fast-forwar:git cherry-pick [commit]
選擇一個commit,合併進當前分支
當前分支再mywork,當使用git merge將origin分支合併到mywork分支上時,Git建立一個新的提交C7。
若是使用git rebase將origin分支rebase到mywork分支時,Git會將當前分支mywork分支自分叉提交點(C2)後面的每一個提交(commit)拷貝到origin分支後面,並將HEAD指針指向最新的提交點。git rebase [startpoint] [endpoint]
將從startpoint到endpoint的屢次提×××併爲一次提交。git rebase -i HEAD~3
將最後三次提×××併爲一次提交git rebase [startpoint] [endpoint] --onto [branchName]
將[startpoint]到[endpoint]開閉區間內的提交複製到[branchName]分支上
此時,當前HEAD處於遊離狀態,Git只是將C~E部分的提交內容複製一份粘貼到master所指向的提交後面,須要將master所指向的提交id設置爲當前HEAD所指向的提交。git reset --hard commit_id
merge不會修改提交歷史,rebase會修改提交歷史。 rebase只應用於本地沒有提交的代碼,不能用於遠程分支,get merge能夠應用於遠程分支。
git branch -d [branch-name]
刪除本地分支,-D(大寫)強制刪除
git push [remote] --delete [branch-name] git push [remote] :remote-branch git branch -dr [remote/branch]
刪除遠程分支
git fetch [remote-name] [branch]
獲取倉庫中指定分支的更新,但不自動合併當前分支git fetch [remote-name]
獲取倉庫全部更新,但不自動合併當前分支git pull [remote] [remote-branch]:[local-branch]
取回遠程主機某個分支的更新,再與本地的指定分支合併git pull
獲取當前分支的惟一遠程追蹤分支,並自動合併到當前分支git pull [remote] [branch]
取回遠程倉庫的branch分支,並與本地當前分支合併git pull [remote]
獲取當前分支的遠程倉庫追蹤分支,並與本地當前分支合併git pull -p
若是遠程主機刪除了某個分支,默認狀況下,git pull不會在拉取遠程分支的時候,刪除對應的本地分支。使用參數-p能夠在本地刪除遠程已經刪除的分支。git remote -v
顯示全部遠程倉庫git remote show [remote]
顯示某個遠程倉庫的信息git remote add [shortname] [url]
增長一個新的遠程倉庫,並命名git remote
簡單查看遠程全部倉庫(只能查看遠程倉庫的名字)git remote show [remote-branch-name]
查看單個倉庫git remote add [branchname] [url]
新建遠程倉庫git remote rename [oldname] [newname]
修改遠程倉庫git remote rm [remote-name]
刪除遠程倉庫
git push [remote] [local-branch]:[remote-branch] git push [remote] [local-branch]
上傳本地指定分支到遠程倉庫的追蹤分支,若是遠程分支不存在,則會被新建。git push [remote] --force
強行推送當前分支到遠程倉庫,即便有衝突git push [remote] --all
推送全部分支到遠程倉庫git push [remote] :[remote-branch]
刪除遠程倉庫的指定遠程分支,等同於:git push [remote] --delete [remote-branch]