協(xié)作開發(fā)的質(zhì)量保證穆端?忠售?
分布式管理控制系統(tǒng)---GIT
客戶端并不只提取最新版本的快照传惠,而是把代碼倉(cāng)庫(kù)完整的鏡像下來(lái)。
GIT特點(diǎn)
1.多數(shù)操作只添加數(shù)據(jù)
2.直接記錄快照稻扬,而不用比較差異
比較差異:從文件A到A1卦方,不會(huì)記錄兩個(gè)文件,而是記錄A和A1的差異腐螟。好處是減少倉(cāng)庫(kù)體積愿汰;缺點(diǎn):想得到文件最新版本,需要訪問追溯到原始版本和后面所有版本的差異 乐纸。
3.所有操作在本地進(jìn)行(離線操作)
4.數(shù)據(jù)完整性(SHA-1哈希值)
5.文件流轉(zhuǎn)的三個(gè)區(qū)域(工作區(qū)衬廷、暫存區(qū)、本地倉(cāng)庫(kù))
工作目錄汽绢、暫存區(qū)吗跋、本地倉(cāng)庫(kù)
工作區(qū):在當(dāng)前倉(cāng)庫(kù)中進(jìn)行的增刪改操作區(qū)
暫存區(qū):【index】(在版本庫(kù)的.git目錄下的index文件)--->是一個(gè) 包含文件索引的目錄樹(tree),虛擬的工作區(qū);記錄了文件名跌宛,狀態(tài)信息(時(shí)間戳/文件長(zhǎng)度等)酗宋;
文件內(nèi)容數(shù)據(jù)不存在此處,而在Git對(duì)象庫(kù)(.git/objects)中疆拘;
文件索引建立起文件和對(duì)象庫(kù)中對(duì)象實(shí)體之間的對(duì)應(yīng)蜕猫;如果本地倉(cāng)庫(kù) 使用命令git add ,更新就會(huì)出現(xiàn)在暫存區(qū)哎迄。
版本庫(kù):如果當(dāng)前倉(cāng)庫(kù)沒有任何提交回右,則版本庫(kù)還是上次提交后的內(nèi)容。
GIT工作流程
- 在工作目錄中修改某些文件
- 對(duì)修改后的文件進(jìn)行快照漱挚,保存到暫存區(qū)
- 提交更新翔烁,將暫存區(qū)中的文件快照永遠(yuǎn)轉(zhuǎn)存到Git目錄中
Git對(duì)象:內(nèi)容尋址文件系統(tǒng),以鍵值對(duì)(key-value)存儲(chǔ)旨涝,允許插入任意類型內(nèi)容蹬屹,并返回一個(gè)鍵值,通過(guò)該鍵值可在任何時(shí)候取白华。
配置GIT
- 配置用戶名和電子郵件地址---在commit log中可看到
#git config --global user.name "guanguan"
#git config --global user.email "guan.furong@eisoo.com" - 查看已有的配置信息
#git config --list - 配置單個(gè)git項(xiàng)目
#git config user.email "guan.furong@eisoo.com" - 配置core.autocrlf
#git config --global core.autocrlf true Windows系統(tǒng)
#git config --global core.autocrlf input Linux系統(tǒng) - 獲取幫助
git <verb> --help
$man git-<verb>
使用GIT倉(cāng)庫(kù)
- 工作目錄初始化新的git倉(cāng)庫(kù)
#mkdir hello //創(chuàng)建工作目錄
#cd hello
#git init //當(dāng)前目錄生成.git文件夾 - 創(chuàng)建一個(gè)bare倉(cāng)庫(kù)(無(wú)工作目錄慨默,在服務(wù)器上)
#mkdir hello.git
#cd hello.git
#git init --bare - Clone一個(gè)倉(cāng)庫(kù)
$git clone URL - 提交
$git add filename //將未跟蹤或已修改文件加入暫存區(qū)
$git commit //將暫存區(qū)文件提交到版本庫(kù),選項(xiàng)(-a)將已跟蹤已修改未暫存的文件也會(huì)提交
#git commit -m "msg xxxxxxxxxx" //提交信息 - 查看
$git status //查看工作狀態(tài)
三種文件狀態(tài):Changes to be commited <已暫存未提交>
changes not staged for commit <以跟蹤的文件修改后未提交>
Untracked files <尚未跟蹤的文件>
- 查看日志
$git log //顯示提交的日志
commit hash(SHA-1 校驗(yàn)和)
作者的名字和電子郵件地址
提交時(shí)間
提交說(shuō)明
GIT分支
除了第一個(gè)提交衬鱼,每次提交(commit)有1個(gè)父親业筏,每個(gè)合并(merge)都有2個(gè)父親
分支操作
- 基于當(dāng)前分支憔杨,新建一個(gè)名為develop分支
#git branch develop - 切換至develop分支
#git checkout develop
1+2. 組合成一個(gè)命令
#git checkout -b develop - 從某個(gè)歷史提交創(chuàng)建分支
#git checkout -b temp 8f7a493c
分支合并
執(zhí)行以下命令得到下圖:
#git checkout master //切換到主分支
#git merge dumbidea //合并dumbidea(git內(nèi)部把master快進(jìn)到C13)
#git merge iss91v2 //合并此分支鸟赫,此操作會(huì)自動(dòng)創(chuàng)建一個(gè)新提交c14
#git branch -D iss91 //強(qiáng)制刪除該分支(因?yàn)镃5 C6未合并,需使用選項(xiàng)-D強(qiáng)制刪除)
#git checkout master //轉(zhuǎn)到主分支
#git merge bugfix //合并一個(gè)bug修復(fù)分支
#git merge newfeature //合并1個(gè)新需求分支
遠(yuǎn)程倉(cāng)庫(kù)
與服務(wù)器同步
為遠(yuǎn)程倉(cāng)庫(kù)URL添加別名
#git remote add origin user@server:/path/repo.git
#git fetch origin //同步服務(wù)器上的數(shù)據(jù)至本地
#git merge origin/master //合并
#git pull merge master
#git push origin [local_branch:remote_branch] //更新遠(yuǎn)程倉(cāng)庫(kù)
#git push origin :serverfix //刪除遠(yuǎn)程的serverfix分支比較差異(版本目錄消别、文件)
#git diff //工作區(qū)和版本庫(kù)差異
#git diff --cached //暫存區(qū)和版本庫(kù)差異
#git diff HEAD // 工作區(qū)和版本庫(kù)差異
每次commit后抛蚤,暫存區(qū)和版本區(qū)是沒有差異的撤銷
(1)用于重新整理提交
#git reset -mixed <id> //將git的HEAD變了,并依據(jù)HEAD更新暫存區(qū)寻狂,但工作區(qū)的tree沒有改變
#git reset -soft <id> //在上一個(gè)命令下岁经,由做了一次add操作
(2)放棄id之后的修改
#git reset -herd <id> //將HEAD變了,文件也變了=回到某個(gè)提交蛇券,id之后的改變?nèi)?/p>過(guò)濾文件
#git ignore //過(guò)濾臨時(shí)文件缀壤、中間文件、編輯器產(chǎn)生的文件等纠亚,使用塘慕!強(qiáng)制不過(guò)濾某些文件
規(guī)則:
a. 空行用于分割,#表示注釋
b. *匹配文件或目錄名0或多個(gè)字符蒂胞,不包括表示文件目錄的反斜杠/ ; ?匹配單個(gè)字符图呢; [ ]匹配其中一個(gè)字符
c. 反斜杠開頭的表示只匹配當(dāng)前目錄/abc,不匹配子目錄
d. 反斜杠結(jié)尾的表示匹配整個(gè)目錄/abc
e. !規(guī)則取反