Git常用命令的操作
一、創建版本庫
初始化一個Git倉庫,使用git init
命令。
添加文件到Git倉庫,分兩步:
-
使用命令
git add <file>
,註意,可反復多次使用,添加多個文件; -
使用命令
git commit -m <message>
,完成。
二、本地倉庫管理
1、版本回退
-
HEAD
指向的版本就是當前版本,因此,Git允許我們在版本的歷史之間穿梭,使用命令git reset --hard commit_id
。 -
穿梭前,用
git log
可以查看提交歷史,以便確定要回退到哪個版本。 -
要重返未來,用
git reflog
2、工作區和暫存區
3、管理修改
如果不用git add
4、撤銷修改
場景1:當你改亂了工作區某個文件的內容,想直接丟棄工作區的修改時,用命令git checkout -- file
。
場景2:當你不但改亂了工作區某個文件的內容,還添加到了暫存區時,想丟棄修改,分兩步,第一步用命令git reset HEAD <file>
,就回到了場景1,第二步按場景1操作。
場景3:已經提交了不合適的修改到版本庫時,想要撤銷本次提交,參考版本回退一節,不過前提是沒有推送到遠程庫。
5、刪除文件
命令git rm
用於刪除一個文件。如果一個文件已經被提交到版本庫,那麽你永遠不用擔心誤刪,但是要小心,你只能恢復文件到最新版本,你會丟失最近一次提交後你修改的內容。
三、遠程倉庫
1、添加遠程庫
· 要關聯一個遠程庫,使用命令git remote add origin [email protected]:path/repo-name.git
;
· 關聯後,使用命令git push -u origin master
第一次推送master分支的所有內容;
· 此後,每次本地提交後,只要有必要,就可以使用命令git push origin master
分布式版本系統的最大好處之一是在本地工作完全不需要考慮遠程庫的存在,也就是有沒有聯網都可以正常工作,而SVN在沒有聯網的時候是拒絕幹活的!當有網絡的時候,再把本地提交推送一下就完成了同步,真是太方便了!
2、從遠程庫克隆
要克隆一個倉庫,首先必須知道倉庫的地址,然後使用git clone
命令克隆。
Git支持多種協議,包括https
,但通過ssh
支持的原生git
協議速度最快。
四、分支管理
1、創建與合並分支
Git鼓勵大量使用分支:
查看分支:git branch
創建分支:git branch <name>
切換分支:git checkout <name>
創建+切換分支:git checkout -b <name>
合並某分支到當前分支:git merge <name>
刪除分支:git branch -d <name>
用git log --graph
命令可以看到分支合並圖。
2、分支管理策咯
合並分支時,加上--no-ff
參數就可以用普通模式合並,合並後的歷史有分支,能看出來曾經做過合並,而fast forward
合並就看不出來曾經做過合並。
3、Bug分支
修復bug時,我們會通過創建新的bug分支進行修復,然後合並,最後刪除;
當手頭工作沒有完成時,先把工作現場git stash
一下,然後去修復bug,修復後,再git stash pop
,回到工作現場。
強行刪除分支:可以通過git branch -D <name>
刪除。
4、多人協作
-
查看遠程庫信息,使用
git remote -v
; -
本地新建的分支如果不推送到遠程,對其他人就是不可見的;
-
從本地推送分支,使用
git push origin branch-name
,如果推送失敗,先用git pull
抓取遠程的新提交; -
在本地創建和遠程分支對應的分支,使用
git checkout -b branch-name origin/branch-name
,本地和遠程分支的名稱最好一致; -
建立本地分支和遠程分支的關聯,使用
git branch --set-upstream branch-name origin/branch-name
; -
從遠程抓取分支,使用
git pull
,如果有沖突,要先處理沖突。
5、rebase
輸入命令git rebase
-
rebase操作可以把本地未push的分叉提交歷史整理成直線;
-
rebase的目的是使得我們在查看歷史提交的變化時更容易,因為分叉的提交需要三方對比。
五、標簽管理
1、創建標簽
-
命令
git tag <tagname>
用於新建一個標簽,默認為HEAD
,也可以指定一個commit id; -
命令
git tag -a <tagname> -m "blablabla..."
可以指定標簽信息; -
命令
git tag
可以查看所有標簽。
2、操作標簽
-
命令
git push origin <tagname>
可以推送一個本地標簽; -
命令
git push origin --tags
可以推送全部未推送過的本地標簽; -
命令
git tag -d <tagname>
可以刪除一個本地標簽; -
命令
git push origin :refs/tags/<tagname>
可以刪除一個遠程標簽。
六、使用GitHub
-
在GitHub上,可以任意Fork開源倉庫;
-
自己擁有Fork後的倉庫的讀寫權限;
-
可以推送pull request給官方倉庫來貢獻代碼。
七、使用碼雲Gitee
1、切換成碼雲倉庫
-
使用命令
git remote add
把它和碼雲的遠程庫關聯就可以正常地用git push
和git pull
推送了!
-
如果在使用命令
git remote add
時報錯 -
用
git remote -v
查看遠程庫信息
2、同時關聯github和gitee
git remote add github <github‘s SSh>
git remote add gitee <github‘s SSh>
用git remote -v
查看遠程庫信息,可以看到兩個遠程庫:
git remote -v
gitee [email protected]:liaoxuefeng/learngit.git (fetch)
gitee [email protected]:liaoxuefeng/learngit.git (push)
github [email protected]:michaelliao/learngit.git (fetch)
github [email protected]:michaelliao/learngit.git (push)
八、自定義Git
1、忽略特殊文件
-
忽略某些文件時,需要編寫
.gitignore
; -
.gitignore
文件本身要放到版本庫裏,並且可以對.gitignore
做版本管理!
2、配置別名
兩種別名配置形式:
1、配置別名關鍵字
$ git config --global alias.st status
2、配置常用關鍵字字符串
$ git config --global alias.unstage ‘reset HEAD‘
配置文件
配置Git的時候,加上--global
是針對當前用戶起作用的,如果不加,那只針對當前的倉庫起作用。
配置文件放哪了?每個倉庫的Git配置文件都放在.git/config
文件中
3、搭建Git服務器
廖雪峰搭建Git服務器
Git常用命令的操作