git指令操作
本地庫操作
初始化本地倉庫
-
初始化指令
git init
$ work % cd workspace
$ workspace % mkdir WebService //建立檔案夾
$ workspace % git init //初始化
Initialized empty Git repository in /Users/jack/work/workspace/.git/
$ workspace %
-
初始化後的效果
會在初始化後的目錄中生成一個.git隐藏檔案夾
$ workspace % cd .git
$ .git % ls
HEAD branches config description hooks info objects refs
$ .git % ls -l
total 24
-rw-r--r-- 1 jack staff 23 Sep 25 22:16 HEAD
drwxr-xr-x 2 jack staff 64 Sep 25 22:16 branches
-rw-r--r-- 1 jack staff 137 Sep 25 22:16 config
-rw-r--r-- 1 jack staff 73 Sep 25 22:16 description
drwxr-xr-x 13 jack staff 416 Sep 25 22:16 hooks
drwxr-xr-x 3 jack staff 96 Sep 25 22:16 info
drwxr-xr-x 4 jack staff 128 Sep 25 22:16 objects
drwxr-xr-x 4 jack staff 128 Sep 25 22:16 refs
$ .git %
注意:.git目錄中的檔案不要删除也不要修改,否則git不能正常工作。
設定簽名
-
形式
使用者名:XXX
Email位址:[email protected]
-
作用
隻是為了區分成員身份,不會給郵件位址發送郵件。而且郵件位址可以是不存在位址。
-
注意
這裡的簽名和遠端倉庫的郵件位址密碼沒有任何關系
- 指令
$ WebService % git config user.name njzy $ WebService % git config user.email [email protected] $ WebService %
$ WebService % git config --global user.name njzy_global $ WebService % git config --global user.email [email protected] $ WebService %
-
系統使用者級别
登入目前系統的使用者範圍
git config --global user.name 使用者名
git config --global user.email 郵箱位址
-
項目級别/倉庫級别
僅在目前本地倉庫有效
git config user.name 使用者名
git config user.email 郵箱位址
-
簽名儲存位置
1.項目級别
目前項目下的.git檔案夾下的config檔案中。
檢視指令:cat .git/config
$ WebService % cat .git/config //檢視目前項目的簽名資訊 [core] repositoryformatversion = 0 filemode = true bare = false logallrefupdates = true ignorecase = true precomposeunicode = true [user] name = njzy //被設定的項目使用者名 email = [email protected] //被設定的項目郵件位址 $ WebService %
2.系統使用者級别
目前使用者檔案夾下的.gitconfig檔案中。
檢視指令:cat .gitconfig
$ ~ % cd ~ //切換到目前使用者根目錄 $ ~ % pwd //檢視目前位置 /Users/jack $ ~ % cat .gitconfig //檢視全局簽名資訊 [user] name = njzy_global //被設定的全局使用者名 email = [email protected] //被設定的全局郵件位址 $ ~ %
-
項目級别和系統使用者級别的簽名的優先(就近原則)
1.> 兩個都設定情況下
項目級别優先于系統使用者級别
2.> 隻設定系統使用者級别簽名
以系統使用者級簽名别為準
3.> 隻設定項目級别
以項目級别為準
4.> 兩個都沒有設定的話不允許。
檢視git狀态
-
作用
确認git的暫存區,本地倉庫的情況。
-
指令
git status
添加操作
-
目的
把内容從工作區添加到暫存區,也叫追蹤。
-
1.添加單個檔案
git add 檔案名
2.添加多個檔案
1.> git add 檔案名1 檔案名2 檔案名3 ....
2.> git add -A
3.> git add .
詳細參考git幫助文檔
usage: git add [<options>] [--] <pathspec>... -n, --dry-run dry run -v, --verbose be verbose -i, --interactive interactive picking -p, --patch select hunks interactively -e, --edit edit current diff and apply -f, --force allow adding otherwise ignored files -u, --update update tracked files //更新追蹤的檔案 --renormalize renormalize EOL of tracked files (implies -u) -N, --intent-to-add record only the fact that the path will be added later -A, --all add changes from all tracked and untracked files //添加所有被追蹤檔案的更新,和沒有被追蹤的檔案 --ignore-removal ignore paths removed in the working tree (same as --no-all) //忽略工作區被删除的檔案 --refresh don't add, only refresh the index --ignore-errors just skip files which cannot be added because of errors //忽略由于檔案的錯誤不能被追蹤 --ignore-missing check if - even missing - files are ignored in dry run --chmod (+|-)x override the executable bit of the listed files
-
使用例
為了清除git各個階段的狀态,在進行添加操作之前先檢視一下git的狀态。
(下面例子是從工作區檔案的建立到追加暫存區的過程)
1.檢視工作區被初始化後的狀态
2.建立檔案testGIt.txt檔案$ WebService % git status On branch master No commits yet //本地倉庫沒有可送出的東西 nothing to commit (create/copy files and use "git add" to track) //暫存區沒有可以送出的東西 $ WebService %
3.檢視檔案建立完後git狀态$ WebService % vim testGit.txt $ WebService % cat testGit.txt //檢視檔案内容 hello ! this is my first git test file ! $ WebService %
4.将檔案添加到暫存區并檢視狀态$ WebService % git status On branch master No commits yet //本地倉庫沒有樂意送出的東西。 Untracked files: //沒有追加跟蹤的檔案 (use "git add <file>..." to include in what will be committed) //使用git add <file> 指令可以追加檔案到暫存區 testGit.txt //剛才新建立的檔案,此時檔案名字型為紅色 nothing added to commit but untracked files present (use "git add" to track) //使用git add指令 $ WebService %
$ WebService % git add testGit.txt $ WebService % git status On branch master No commits yet Changes to be committed: (use "git rm --cached <file>..." to unstage) //已經把檔案放到暫存區,如果想清除暫存區,可以使用git rm --cached 檔案名來擦除暫存區 testGit.txt new file: testGit.txt //此時檔案為綠色 $ WebService %
送出操作
- 将檔案從暫存區送出到本地倉庫
-
1.送出單個檔案
git commit -m "送出時注釋資訊" 檔案名
2.送出複數個檔案
git comit -a -m "送出時注釋資訊"
更多詳細可以參考git幫助文檔
usage: git commit [<options>] [--] <pathspec>... -q, --quiet suppress summary after successful commit -v, --verbose show diff in commit message template Commit message options -F, --file <file> read message from file --author <author> override author for commit --date <date> override date for commit -m, --message <message> commit message -c, --reedit-message <commit> reuse and edit message from specified commit -C, --reuse-message <commit> reuse message from specified commit --fixup <commit> use autosquash formatted message to fixup specified commit --squash <commit> use autosquash formatted message to squash specified commit --reset-author the commit is authored by me now (used with -C/-c/--amend) -s, --signoff add Signed-off-by: -t, --template <file> use specified template file -e, --edit force edit of commit --cleanup <mode> how to strip spaces and #comments from message --status include status in commit message template -S, --gpg-sign[=<key-id>] GPG sign commit Commit contents options -a, --all commit all changed files -i, --include add specified files to index for commit --interactive interactively add files -p, --patch interactively add changes -o, --only commit only specified files -n, --no-verify bypass pre-commit and commit-msg hooks --dry-run show what would be committed --short show status concisely --branch show branch information --ahead-behind compute full ahead/behind values --porcelain machine-readable output --long show status in long format (default) -z, --null terminate entries with NUL --amend amend previous commit --no-post-rewrite bypass post-rewrite hook -u, --untracked-files[=<mode>] show untracked files, optional modes: all, normal, no. (Default: all)
- 送出檔案到本地倉庫并檢視git狀态
$ WebService % git commit -m "first commit:new file testGit.txt" testGit.txt [master (root-commit) c970a17] first commit:new file testGit.txt //first commit:new file testGit.txt 是送出時候的注釋資訊 1 file changed, 2 insertions(+) //改變了一個檔案,追加了兩行資訊。 create mode 100644 testGit.txt $ WebService % git status On branch master nothing to commit, working tree clean //暫存區沒有可以送出的東西 $ WebService %
擦除暫存區操作
- 擦除暫存區的内容
- git rm --cached 檔案名
$ WebService % git rm --cached testGit.txt rm 'testGit.txt' $ WebService % git status On branch master No commits yet Untracked files: (use "git add <file>..." to include in what will be committed) testGit.txt //沒有被追蹤的檔案 nothing added to commit but untracked files present (use "git add" to track) $ WebService %
檢視曆史版本資訊
- 檢視送出版本的曆史資訊
-
1.git log
顯示完整資訊,包含送出的版本号,送出使用者,送出日期,送出注釋等資訊。
2.git log --pretty=oneline
隻包含送出後的完整版本号和送出時的注釋資訊
3.git log --oneline
包含送出後的簡略版本号和送出時的注釋資訊
- 隻能檢視已經被送出(commit)的檔案的曆史資訊。
- 使用例1
$ WebService % git log //第二次被送出的資訊 commit 148942fd3c0ff3e01e09bf98d883f97a3b0a9c86 (HEAD -> master) //送出版本的hash值 Author: njzy <[email protected]> //送出使用者資訊 Date: Sat Sep 26 15:53:52 2020 +0900 //送出日期 this is my second commit, modify testGit.txt //送出時注釋 //第一次被送出的資訊 commit c970a176de13abc4d436e4a08df329046ef193e7 Author: njzy <[email protected]> Date: Sat Sep 26 12:30:20 2020 +0900 first commit:new file testGit.txt $ WebService %
- 使用例2
$ WebService % git log --pretty=oneline 148942fd3c0ff3e01e09bf98d883f97a3b0a9c86 (HEAD -> master) this is my second commit, modify testGit.txt c970a176de13abc4d436e4a08df329046ef193e7 first commit:new file testGit.txt $ WebService %
- 使用例3
$ WebService % git log --oneline 148942f (HEAD -> master) this is my second commit, modify testGit.txt c970a17 first commit:new file testGit.txt $ WebService %
曆史版本的前進或者回退
檢視帶head資訊的日志
- 檢視帶有指針和hash位址的日志資訊,友善進行版本的前進或者後退。
- git reflog
-
$ WebService % git reflog 148942f (HEAD -> master) HEAD@{0}: commit: this is my second commit, modify testGit.txt //148942f:簡短的hash位址 //HEAD@{0}:指針0的位置 c970a17 HEAD@{1}: commit (initial): first commit:new file testGit.txt //HEAD@{1} 指針1的位置 $ WebService %
版本的前進或者和回退
基于hash位址的版本指定【推薦】
- 對版本進行前進操作或者回退操作
- git reset --hard 指定版本的hash位址
- 從第五個版本跳轉到第三個版本
$ WebService % git reflog //首先檢視各種版本資訊 d3c9608 (HEAD -> master) HEAD@{0}: commit: this is my fifth updata,updata testGit.txt 364024e HEAD@{1}: commit: this is my fourth commit,updata testGit.txt 9dba7c5 HEAD@{2}: commit: this is my third commit,updata testGit.txt 148942f HEAD@{3}: commit: this is my second commit, modify testGit.txt c970a17 HEAD@{4}: commit (initial): first commit:new file testGit.txt $ WebService % cat testGit.txt //檢視目前版本的檔案内容 hello ! this is my first git test file ! this is added this is my third updata! this is my four updata! this is my fifth updata! $ WebService % git reset --hard 9dba7c5 //然後根據檢視的版本位址資訊,指定到要恢複到的版本。 HEAD is now at 9dba7c5 this is my third commit,updata testGit.txt $ WebService % cat testGit.txt //然後檢視回退後的目前版本檔案内容 hello ! this is my first git test file ! this is added this is my third updata! $ WebService % git reflog //然後我們再來看一下log資訊 9dba7c5 (HEAD -> master) HEAD@{0}: reset: moving to 9dba7c5 d3c9608 HEAD@{1}: commit: this is my fifth updata,updata testGit.txt 364024e HEAD@{2}: commit: this is my fourth commit,updata testGit.txt 9dba7c5 (HEAD -> master) HEAD@{3}: commit: this is my third commit,updata testGit.txt 148942f HEAD@{4}: commit: this is my second commit, modify testGit.txt c970a17 HEAD@{5}: commit (initial): first commit:new file testGit.txt $ WebService %
使用^符号(隻能進行版本的後退不能前進)
- 進行版本的回退
-
git reset --hard HEAD^
(注意:一個^代表倒退一個版本)
- 從第四個版本倒退到一個版本到第三個版本
倒退兩個版本$ WebService % git reset --hard HEAD^ HEAD is now at 9dba7c5 this is my third commit,updata testGit.txt $ WebService % cat testGit.txt hello ! this is my first git test file ! this is added this is my third updata! $ WebService %
$ WebService % git reset --hard HEAD^^ HEAD is now at c970a17 first commit:new file testGit.txt $ WebService % cat testGit.txt hello ! this is my first git test file ! $ WebService %
使用~符号
-
退回指定版本
(隻能倒退,但是可以指定指定退幾步)
- git reset --hard HEAD~要退的步數
- 從目前版本第五版後退兩步到第三個版本
$ WebService % git reset --hard HEAD~2 HEAD is now at 9dba7c5 this is my third commit,updata testGit.txt $ WebService % cat testGit.txt hello ! this is my first git test file ! this is added this is my third updata! $ WebService %
reset三個參數的對比(對比詳細圖文參照文末圖檔1,2,3)
--soft參數
-
說明
僅在本地倉庫移動HEAD指針
- git reset -soft 指定版本号
-
$ WebService % cat testGit.txt //退回版本之前檢視檔案内容 hello ! this is my first git test file ! this is added this is my third updata! $ WebService % git reset --soft 148942f //退回版本操作 $ WebService % cat testGit.txt //退回版本資訊後檢視檔案内容 hello ! this is my first git test file ! this is added this is my third updata! $ WebService % git status //檢視狀态 On branch master Changes to be committed: (use "git restore --staged <file>..." to unstage) modified: testGit.txt //檢視完後顯示為綠色字型,表示被更改了。為哈如此呢? //是由于原來本地倉庫,暫存區,工作區的指針是相同的。而經過soft操作後,本地倉庫的指針發生變化,導緻暫存區的指針相對的産生了變化。是以顯示是發生了變化。 $ WebService %
--mixd參數
- 在本地倉庫移動HEAD指針,重置暫存區。
- git reset --mixed 指定版本号
-
$ WebService % cat testGit.txt //跳轉到其他版本之前檔案内容 hello ! this is my first git test file ! this is added this is my third updata! $ WebService % git reset --mixed d3c9608 //指定到指定版本 Unstaged changes after reset: M testGit.txt $ WebService % git reflog //指定版本後的日志 d3c9608 (HEAD -> master) HEAD@{0}: reset: moving to d3c9608 148942f HEAD@{1}: reset: moving to 148942f 9dba7c5 HEAD@{2}: reset: moving to HEAD~2 d3c9608 (HEAD -> master) HEAD@{3}: reset: moving to d3c9608 c970a17 HEAD@{4}: reset: moving to HEAD^^ 9dba7c5 HEAD@{5}: reset: moving to HEAD^ 364024e HEAD@{6}: reset: moving to 364024e 9dba7c5 HEAD@{7}: reset: moving to 9dba7c5 d3c9608 (HEAD -> master) HEAD@{8}: commit: this is my fifth updata,updata testGit.txt 364024e HEAD@{9}: commit: this is my fourth commit,updata testGit.txt 9dba7c5 HEAD@{10}: commit: this is my third commit,updata testGit.txt 148942f HEAD@{11}: commit: this is my second commit, modify testGit.txt c970a17 HEAD@{12}: commit (initial): first commit:new file testGit.txt $ WebService % cat testGit.txt //檢視切換版本後的檔案内容 hello ! this is my first git test file ! this is added this is my third updata! $ WebService % git status On branch master Changes not staged for commit: (use "git add <file>..." to update what will be committed) (use "git restore <file>..." to discard changes in working directory) modified: testGit.txt //此時檔案名是紅色 no changes added to commit (use "git add" and/or "git commit -a") $ WebService %
--hard參數
-
說明
在本地倉庫移動HEAD指針
重置暫存區
重置工作區
- git reset --hard 指定版本
-
使用例
參照上面各種版本前進或者後退的例子。
删除檔案并找回
-
前提
送出到本地庫後删除才能找回
-
删除
實體删除即可
-
找回版本
通過跳轉到指定版本指令即可找回删除的内容。
- 建立檔案->追加到暫存區->送出到本地倉庫->删除檔案->添加到暫存區->送出到本地倉庫
$ WebService % vim test2.txt //1.建立一個新的測試檔案 $ WebService % git add test2.txt //2.添加到暫存區 $ WebService % git commit -m "add new test2.txt" test2.txt //3.送出到本地倉庫 [master 8a4e57d] add new test2.txt 1 file changed, 3 insertions(+) create mode 100644 test2.txt $ WebService % ls -l //檢視目前檔案夾檔案 total 16 -rw-r--r-- 1 jack staff 27 Sep 27 07:11 test2.txt -rw-r--r-- 1 jack staff 134 Sep 26 22:33 testGit.txt $ WebService % git status //檢視git狀态 On branch master nothing to commit, working tree clean $ WebService % $ WebService % $ WebService % $ WebService % rm test2.txt //4.本地實體删除檔案 $ WebService % ls -l //5.删除後确認 total 8 -rw-r--r-- 1 jack staff 134 Sep 26 22:33 testGit.txt $ WebService % git status //6.檢視删除後 On branch master Changes not staged for commit: (use "git add/rm <file>..." to update what will be committed) (use "git restore <file>..." to discard changes in working directory) deleted: test2.txt //紅色字型,表示這個操作沒有被添加到暫存區 no changes added to commit (use "git add" and/or "git commit -a") $ WebService % git add test2.txt //7.将删除後的狀态添加到暫存區 $ WebService % git status //檢視添加後的git狀态 On branch master Changes to be committed: (use "git restore --staged <file>..." to unstage) deleted: test2.txt //文字為綠色,表示暫存區已被更新。 $ WebService % git commit -m "delete file test2.txt" test2.txt //8.把暫存區内容送出到本地倉庫 [master f8373c4] delete file test2.txt 1 file changed, 3 deletions(-) delete mode 100644 test2.txt $ WebService % git status //檢視git狀态 On branch master nothing to commit, working tree clean $ WebService % ls testGit.txt $ WebService % git reflog //9.檢視日志資訊 f8373c4 (HEAD -> master) HEAD@{0}: commit: delete file test2.txt //10/1檔案被删除的曆史記錄 8a4e57d HEAD@{1}: commit: add new test2.txt d3c9608 HEAD@{2}: reset: moving to d3c9608 d3c9608 HEAD@{3}: reset: moving to d3c9608 148942f HEAD@{4}: reset: moving to 148942f 9dba7c5 HEAD@{5}: reset: moving to HEAD~2 d3c9608 HEAD@{6}: reset: moving to d3c9608 c970a17 HEAD@{7}: reset: moving to HEAD^^ 9dba7c5 HEAD@{8}: reset: moving to HEAD^ 364024e HEAD@{9}: reset: moving to 364024e 9dba7c5 HEAD@{10}: reset: moving to 9dba7c5 d3c9608 HEAD@{11}: commit: this is my fifth updata,updata testGit.txt 364024e HEAD@{12}: commit: this is my fourth commit,updata testGit.txt 9dba7c5 HEAD@{13}: commit: this is my third commit,updata testGit.txt 148942f HEAD@{14}: commit: this is my second commit, modify testGit.txt c970a17 HEAD@{15}: commit (initial): first commit:new file testGit.txt $ WebService % git reset --hard 8a4e57d //2.恢複到删除之前的版本 HEAD is now at 8a4e57d add new test2.txt $ WebService % ls -l//3.檢視本地檔案是否恢複? total 16 -rw-r--r-- 1 jack staff 27 Sep 27 07:25 test2.txt//檔案又被恢複回來了 -rw-r--r-- 1 jack staff 134 Sep 26 22:33 testGit.txt $ WebService %
恢複暫存區的檔案
- 使暫存區檔案恢複
-
git reset --hard HEAD
通過上面重新整理讓三個區保持一緻即可
-
條件
要恢複的檔案送出到了本地庫
版本比較
比較工作區和暫存區
- git diff 檔案名
-
比較修改後的test2.txt的工作區和暫存區
工作區,暫存區,本地倉庫test2.txt内容一緻
修改後的工作區test2.txtaaaaaaaa bbbbbbbb cccccccc
比較後結果aaaaaaaa bbbbbbbb cccccccc@@@@@@
送出到暫存區後再比較$ WebService % git diff test2.txt diff --git a/test2.txt b/test2.txt index 092b923..0c08686 100644 --- a/test2.txt +++ b/test2.txt @@ -1,3 +1,3 @@ aaaaaaaa bbbbbbbb -cccccccc //-代表删除 +cccccccc@@@@@@ //+代表追加。git是以行尾機關來管理版本的,是以cccccccc表示為删除,cccccccc@@@@@@表示為追加。 $ WebService %
$ WebService % git add test2.txt $ WebService % git diff test2.txt $ WebService %
工作區和本地倉庫版本比較
- git diff 指定版本 [檔案名]
-
指定版本
HEAD:目前本地倉庫的版本
HEAD^:本地倉庫的上一個版本
HEAD^^:本地倉庫的上兩個版本
HEAD~n:本地倉庫的上n個版本
版本号的hash值
- 檔案名不寫的話是所有目前檔案夾的所有檔案
- 工作區和本地倉庫的目前版本比較
和本地倉庫的上一個版本進行比較$ WebService % git reset --hard HEAD //先把三個區同步一下,恢複到同一狀态 HEAD is now at 8a4e57d add new test2.txt $ WebService % git status On branch master nothing to commit, working tree clean $ WebService % cat test2.txt aaaaaaaa bbbbbbbb cccccccc $ WebService % vim test2.txt //對工作區修改 $ WebService % git diff HEAD test2.txt//修改後進行比較 diff --git a/test2.txt b/test2.txt index 092b923..0c08686 100644 --- a/test2.txt +++ b/test2.txt @@ -1,3 +1,3 @@ aaaaaaaa bbbbbbbb -cccccccc +cccccccc@@@@@@ $ WebService %
$ WebService % git diff HEAD^ test2.txt diff --git a/test2.txt b/test2.txt new file mode 100644 index 0000000..0c08686 --- /dev/null +++ b/test2.txt @@ -0,0 +1,3 @@ +aaaaaaaa +bbbbbbbb +cccccccc@@@@@@ $ WebService %
分支
分支概述
在版本控制過程中,使用多條線同時推進多個任務。
分支好處
- 同時推進多個功能開發,提高生産效率。
- 各個分支在開發過程中,如有某個分支失敗,不會對其他分支有影響。失敗的分支可以重新擷取mastaer分支,進行再次開發。
建立分支
- git branch 分支名
$ WebService % git branch hot_fix
檢視分支
- git branch -v
-
$ WebService % git branch -v hot_fix 8a4e57d add new test2.txt * master 8a4e57d add new test2.txt //*所在的位值就是我們現在是以在的分支 $ WebService %
切換分支
- 把分支從目前分支切換到其他分支
- git checkout 分支名
-
$ WebService % git checkout hot_fix Switched to branch 'hot_fix' $ WebService % git branch -v * hot_fix 8a4e57d add new test2.txt //現在已經切換到hot_fix分支 master 8a4e57d add new test2.txt $ WebService %
合并分支
- 把指定分支的内容合并到目前分支
- git merge 要合并内容的分支名
$ WebService % git branch -v //檢視目前分支 * hot_fix a360edf hox_fix one add master 8a4e57d add new test2.txt $ WebService % git checkout master //切換到内容要合并到的分支 Switched to branch 'master' $ WebService % git branch -v //再次确認切換後的分支 hot_fix a360edf hox_fix one add * master 8a4e57d add new test2.txt $ WebService % git merge hot_fix //進行分支合并 Updating 8a4e57d..a360edf Fast-forward test2.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) $ WebService % cat test2.txt//檢視合并後的内容 aaaaaaaa bbbbbbbb cccccccc edit by hox_fix//次内容是hot_fix分支内容,證明已經合并成功。 $ WebService % git branch -v hot_fix a360edf hox_fix one add //當兩個分支内容一樣的時候,此時兩個分支的hash值是一樣的。 * master a360edf hox_fix one add //當兩個分支内容一樣的時候,此時兩個分支的hash值是一樣的。 $ WebService %
解決合并沖突
- 當要合并兩個分支的時候,兩個分支修改内容不一樣,導緻不能自動進行合并操作,是以需要手動進行合并操作。
-
解決思路
1.删除沖突檔案内容的特殊符号
2.修改沖突内容
3.修改後的檔案添加到暫存區。(git add 檔案名)
4.從暫存區送出到本地倉庫。
(指令:git commit -m "注釋") 注:這裡的commit指令不能帶檔案名稱參數。
上面執行完merge指令後,test2.txt檔案的内容,$ WebService % vim test2.txt //修改mster分支的test2檔案 $ WebService % git add test2.txt //把修改後的檔案添加到暫存區 $ WebService % git commit test2.txt //把暫存區檔案送出到本地倉庫 [master 4a902f1] updata master 1 file changed, 1 insertion(+) $ WebService % git branch -v //檢視目前分支 hot_fix a360edf hox_fix one add * master 4a902f1 updata master $ WebService % $ WebService % git checkout hot_fix //切換到hot_fix分支 Switched to branch 'hot_fix' $ WebService % git branch -v //檢視分支 * hot_fix a360edf hox_fix one add master 4a902f1 updata master $ WebService % vim test2.txt //編輯test2.txt $ WebService % git add test2.txt //修改後的檔案添加到暫存區 $ WebService % git commit -m "updata hox_fix" test2.txt //送出檔案到本地倉庫 [hot_fix ee3ae4c] updata hox_fix 1 file changed, 1 insertion(+) $ WebService % $ WebService % git merge master //合并分支 Auto-merging test2.txt CONFLICT (content): Merge conflict in test2.txt Automatic merge failed; fix conflicts and then commit the result. //自動合并分支失敗,接下來需要手動修改檔案後在進行送出來解決沖突 $ WebService % ls -l total 16 -rw-r--r-- 1 jack staff 126 Sep 27 11:02 test2.txt -rw-r--r-- 1 jack staff 134 Sep 26 22:33 testGit.txt $ WebService % vim test2.txt //打開檔案進行手動合并檔案内容 $ WebService % git status //檢視git狀态 On branch hot_fix //在hot_fix分支上 You have unmerged paths.//沒有合并的路徑 (fix conflicts and run "git commit") //修理沖突并執行 (use "git merge --abort" to abort the merge) //終止合并 Unmerged paths: (use "git add <file>..." to mark resolution) //使用git add <file> 指令去标記為解決 both modified: test2.txt no changes added to commit (use "git add" and/or "git commit -a") $ WebService % git add test2.txt //解決沖突後的檔案添加到暫存區 $ WebService % git status On branch hot_fix All conflicts fixed but you are still merging.//所有的沖突已經解決了,但是你仍然處于“合并中”狀态。 (use "git commit" to conclude merge) //使用git commit 指令去變換”合并中“的狀态 Changes to be committed: modified: test2.txt $ WebService % git commit -m "resolve conflict" test2.txt fatal: cannot do a partial commit during a merge. //注意:在這中特殊場合下的commit不能再後面使用檔案名 $ WebService % git commit -m "resolve conflict" //去掉檔案名再次執行送出。 [hot_fix 0d62477] resolve conflict //沖突解決了。 $ WebService % git status //檢視git狀态 On branch hot_fix nothing to commit, working tree clean $ WebService % vim test2.txt //确認合并後的内容 $ WebService %
上面修改後的檔案内容aaaaaaaa bbbbbbbb cccccccc edit by hox_fix <<<<<<< HEAD //指針版本内容 eeeeeeee add by hox_fix ======= dddddddd add by master >>>>>>> master //master版本内容
aaaaaaaa bbbbbbbb cccccccc edit by hox_fix dddddddd add by master eeeeeeee add by hox_fix
遠端庫操作
注冊賬戶
- 注冊github賬戶
- 注冊碼雲賬戶
- 兩個賬戶任意一個即可
建立項目倉庫
-
建立新倉庫
(在這裡不做叙述)
遠端倉庫别名設定
- 起别名的目的為了在推送到遠端倉庫的時候比較簡單,不至于敲很長的位址。
- git remote add 别名 遠端倉庫位址.git
-
$ WebService % git remote add origin https://github.com/jack2019/WebService.git $ WebService %
檢視遠端倉庫别名資訊
- 在設定遠端倉庫别名後,檢視設定是否成功。
- git remote -v
-
$ WebService % git remote -v origin https://github.com/jack2019/WebService.git (fetch) origin https://github.com/jack2019/WebService.git (push) $ WebService %
推送到遠端倉庫
- 把本地倉庫的内容上傳到遠端倉庫
- git push 遠端庫别名 分支名
-
$ WebService % git push origin hot_fix Enumerating objects: 30, done. Counting objects: 100% (30/30), done. Delta compression using up to 16 threads Compressing objects: 100% (22/22), done. Writing objects: 100% (30/30), 2.52 KiB | 1.26 MiB/s, done. Total 30 (delta 4), reused 0 (delta 0) remote: Resolving deltas: 100% (4/4), done. remote: remote: Create a pull request for 'hot_fix' on GitHub by visiting: remote: https://github.com/jack2019/WebService/pull/new/hot_fix remote: To https://github.com/jack2019/WebService.git * [new branch] hot_fix -> hot_fix $ WebService %
推送發生失敗
- 當推送到遠端倉庫時莫名發生失敗,此時可以進行強行推送
- git push 遠端倉庫名稱.git 分支名 -f
-
$ WebService % git push origin master //首次推送 To https://github.com/jack2019/WebService.git ! [rejected] master -> master (fetch first) error: failed to push some refs to 'https://github.com/jack2019/WebService.git' //推送失敗 hint: Updates were rejected because the remote contains work that you do hint: not have locally. This is usually caused by another repository pushing hint: to the same ref. You may want to first integrate the remote changes hint: (e.g., 'git pull ...') before pushing again. hint: See the 'Note about fast-forwards' in 'git push --help' for details. $ WebService % git push origin master -f //進行強行推送 Total 0 (delta 0), reused 0 (delta 0) To https://github.com/jack2019/WebService.git + 6cfbddc...4a902f1 master -> master (forced update) //強行推送成功,可以去github倉庫檢視是否已經有上傳的内容。 $ WebService %
遠端倉庫克隆
- 當我們想從github或者碼雲下載下傳他人的項目進行學習閱讀的時候,我們可以使用克隆指令。
- git clone 遠端倉庫位址
- 克隆操作在完成下載下傳檔案到本地的同時還完成了兩件事情。分别是初始化遠端倉庫别名,初始話本地倉庫(也就是git init指令執行過程。)
-
➜ IdeaProjects git clone https://github.com/jack2019/gitLearnning.git //克隆遠端倉庫庫 Cloning into 'gitLearnning'... remote: Enumerating objects: 52, done. remote: Counting objects: 100% (52/52), done. remote: Compressing objects: 100% (34/34), done. remote: Total 52 (delta 10), reused 51 (delta 10), pack-reused 0 Unpacking objects: 100% (52/52), done. //克隆成功 ➜ IdeaProjects cd gitLearnning //進入下載下傳的檔案夾 ➜ gitLearnning git:(master) ls -al //檢視下載下傳的檔案 total 16 drwxr-xr-x 5 jack staff 160 Oct 6 21:34 . drwxr-xr-x@ 21 jack staff 672 Oct 6 21:34 .. drwxr-xr-x 13 jack staff 416 Oct 6 21:34 .git -rw-r--r-- 1 jack staff 219 Oct 6 21:34 test2.txt -rw-r--r-- 1 jack staff 134 Oct 6 21:34 testGit.txt ➜ gitLearnning git:(master) git status //檢視git狀态 On branch master Your branch is up to date with 'origin/master'. //被下載下傳到了origin/master下 nothing to commit, working tree clean ➜ gitLearnning git:(master)
從遠端庫拉取最新的内容
fetch操作
- 遠端庫的内容被更新後,我們想取得最新的到本地,這時候就用到了fetch指令。如果我們還想和本地的版本進行合并。我們還需要使用merge指令進行合并。
- git fetch 遠端倉庫别名 分支名
-
$ git fetch origin master //抓取内容 remote: Enumerating objects: 5, done. remote: Counting objects: 100% (5/5), done. remote: Compressing objects: 100% (2/2), done. remote: Total 3 (delta 1), reused 3 (delta 1), pack-reused 0 Unpacking objects: 100% (3/3), done. From https://github.com/jack2019/WebService * branch master -> FETCH_HEAD f1a3142..da6a4ee master -> origin/master Window-PC MINGW64 /e/workspace/web/webservice (master) $ ls -l total 2 -rw-r--r-- 1 laofan 197121 100 九月 28 21:30 test2.txt -rw-r--r-- 1 laofan 197121 144 九月 28 21:30 testGit.txt Window-PC MINGW64 /e/workspace/web/webservice (master) $ cat test2.txt aaaaaaaa bbbbbbbb cccccccc edit by hox_fix dddddddd add by master mmmmmmm push after updata! Window-PC MINGW64 /e/workspace/web/webservice (master) $ git checkout origin/master //fetch下來的内容放在origin/master下,切換分支到origin、master下。 Note: checking out 'origin/master'. You are in 'detached HEAD' state. You can look around, make experimental changes and commit them, and you can discard any commits you make in this state without impacting any branches by performing another checkout. If you want to create a new branch to retain commits you create, you may do so (now or later) by using -b with the checkout command again. Example: git checkout -b <new-branch-name> HEAD is now at da6a4ee... mac commit ,window fetch Window-PC MINGW64 /e/workspace/web/webservice ((da6a4ee...)) $ git branch -v //檢視目前分支 * (HEAD detached at origin/master) da6a4ee mac commit ,window fetch master f1a3142 [behind 1] push after updata test2.txt //目前所處的分支是origin/master下 Window-PC MINGW64 /e/workspace/web/webservice ((da6a4ee...)) $ cat test2.txt //檢視目前分支下的檔案内容 aaaaaaaa bbbbbbbb cccccccc edit by hox_fix dddddddd add by master mmmmmmm push after updata nnnnnnn macbook add! //目前分支新追加的内容 Window-PC MINGW64 /e/workspace/web/webservice ((da6a4ee...)) $ git checkout master //切換分支到master Previous HEAD position was da6a4ee... mac commit ,window fetch Switched to branch 'master' Your branch is behind 'origin/master' by 1 commit, and can be fast-forwarded. (use "git pull" to update your local branch) Window-PC MINGW64 /e/workspace/web/webservice (master) $ git branch -v //檢視目前分支 * master f1a3142 [behind 1] push after updata test2.txt Window-PC MINGW64 /e/workspace/web/webservice (master) $ cat test2.txt //檢視目前分支内容 aaaaaaaa bbbbbbbb cccccccc edit by hox_fix dddddddd add by master mmmmmmm push after updata! Window-PC MINGW64 /e/workspace/web/webservice (master) $ git merge origin/master //把origin/master分支内容合并到master Updating f1a3142..da6a4ee Fast-forward test2.txt | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) Window-PC MINGW64 /e/workspace/web/webservice (master) $ cat test2.txt //檢視合并後的master分支檔案内容 aaaaaaaa bbbbbbbb cccccccc edit by hox_fix dddddddd add by master mmmmmmm push after updata nnnnnnn macbook add! //origin/master追加的内容 Window-PC MINGW64 /e/workspace/web/webservice (master)
pull操作
- pull操作等價于fetch操作 + merge操作
- git pull 遠端倉庫别名 分支名
-
$ git pull origin master remote: Enumerating objects: 5, done. remote: Counting objects: 100% (5/5), done. remote: Compressing objects: 100% (2/2), done. remote: Total 3 (delta 1), reused 3 (delta 1), pack-reused 0 Unpacking objects: 100% (3/3), done. From https://github.com/jack2019/WebService * branch master -> FETCH_HEAD da6a4ee..494ed55 master -> origin/master Updating da6a4ee..494ed55 Fast-forward test2.txt | 1 + 1 file changed, 1 insertion(+) Window-PC MINGW64 /e/workspace/web/webservice (master) $ cat test2.txt aaaaaaaa bbbbbbbb cccccccc edit by hox_fix dddddddd add by master mmmmmmm push after updata nnnnnnn macbook add! jjjjjjj macbook add2! Window-PC MINGW64 /e/workspace/web/webservice (master) $
協同開發沖突的解決
- 如果不基于遠端庫最新版本進行修改的話則不能推送,必須先拉取最新的遠端庫。拉取後發生沖突,則按照“分支沖突解決”的操作即可。
-
例子
mac端更新後送出github
window端不拉取最新的github直接更新進行送出github。此時需要先拉取最新的遠端庫進行,并進行遠端庫和本地庫的合并。
跨團隊協作
- 當需要團隊外部的人員進行代碼的變更時,由于團隊外的人沒有push的權限,是以需要團隊外人員對項目進行fork操作。
-
正常流程
1.github使用者1fork使用者2的項目
(fork之後,在遠端庫自動建立一個同樣的項目)
2.clone到本地
3.本地修改内容
4.送出到暫存區,本地庫
5.push到github使用者1
6.向使用者2申請送出請求
pull requests
new pull request
7.使用者2進行pull requestes的處理,并進行merge操作。
git知識補充
-
Q:當不小心對整個系統的檔案夾進行git inint操作後該如何取消?
A:通過指令rm -rf .git對git檔案進行删除操作就即可。
-
Q:如何檢視幫助文檔?
A:通過指令git help 要檢視的指令 進行檢視即可。

往期精彩推薦
騰訊、阿裡、滴滴背景面試題彙總總結 — (含答案)
面試:史上最全多線程面試題 !
最新阿裡内推Java後端面試題
JVM難學?那是因為你沒認真看完這篇文章
—END—
關注作者微信公衆号 —《JAVA爛豬皮》
了解更多java後端架構知識以及最新面試寶典