作者: 車東chedong@bigfoot.com
http://www.chedong.com/tech/cvs_card.html
版權(quán)聲明:可以任意轉(zhuǎn)載,轉(zhuǎn)載時請務(wù)必標(biāo)明原始出處和作者信息
概述:CVS是一個C/S系統(tǒng),多個開發(fā)人員通過一個中心版本控制系統(tǒng)來記錄文件版本,從而達(dá)到保證文件同步的目的。工作模式如下:
CVS服務(wù)器(文件版本庫)
/ |
(版 本 同 步)
/ |
開發(fā)者1 開發(fā)者2 開發(fā)者3
本文主要內(nèi)容:開發(fā)人員入門可以主要挑選2,6看可以了,CVS的管理員則更需要懂的更多一些,后還簡單介紹了一些Windows下的cvs客戶端使用,遠(yuǎn)程用戶認(rèn)證的選擇,及與BUG跟蹤系統(tǒng)等開發(fā)環(huán)境的集成問題。
CVS環(huán)境初始化:CVS環(huán)境的搭建 管理員
CVS的日常使用:日常開發(fā)中常用的CVS命令, 開發(fā)人員 管理員
CVS的分支開發(fā):項目按照不同進(jìn)度和目標(biāo)并發(fā)進(jìn)行 管理員
CVS的用戶認(rèn)證:通過SSH的遠(yuǎn)程用戶認(rèn)證,安全,簡單 管理員
CVSWEB:CVS的WEB訪問界面大大提高代碼版本比較的效率 管理員
CVS TAG:將$Header$加入代碼注釋中,方便開發(fā)過程的跟蹤 開發(fā)人員
CVS vs VSS: CVS和Virsual SourceSafe的比較 開發(fā)人員 管理員
WinCVS: 通過SSH認(rèn)證的WinCVS認(rèn)證設(shè)置
CVS的小組協(xié)同開發(fā):開發(fā)組級的開發(fā)環(huán)境搭建,通過CVSTrac實現(xiàn)web界面的CVS用戶管理及集成的BUG跟蹤和WIKI交流。
一個系統(tǒng)20%的功能往往能夠滿足80%的需求,CVS也不例外,以下是CVS常用的功能,可能還不到它全部命令選項的20%,更多的功能在實際應(yīng)用過程中體會,你想用多少學(xué)多少,不時回頭看看經(jīng)常有意外的收獲。
CVS環(huán)境初始化
============
環(huán)境設(shè)置:指定CVS庫的路徑CVSROOT
tcsh
setenv CVSROOT /path/to/cvsroot
bash
CVSROOT=/path/to/cvsroot ; export CVSROOT
后面還提到遠(yuǎn)程CVS服務(wù)器的設(shè)置:
CVSROOT=:ext:$USER@test.server.address#port:/path/to/cvsroot CVS_RSH=ssh; export CVSROOT CVS_RSH
初始化:CVS版本庫的初始化。
cvs init
一個項目的首次導(dǎo)入
cvs import -m "write some comments here" project_name vendor_tag release_tag
執(zhí)行后:會將所有源文件及目錄導(dǎo)入到/path/to/cvsroot/project_name目錄下
vender_tag: 開發(fā)商標(biāo)記
release_tag: 版本發(fā)布標(biāo)記
項目導(dǎo)出:將代碼從CVS庫里導(dǎo)出
cvs checkout project_name
cvs 將創(chuàng)建project_name目錄,并將新版本的源代碼導(dǎo)出到相應(yīng)目錄中。這個checkout和Virvual SourceSafe中的check out不是一個概念,相對于Virvual SourceSafe的check out是cvs update, check in是cvs commit。
CVS的日常使用
=============
注意:第一次導(dǎo)出以后,不是通過cvs checkout來同步文件了,而是要進(jìn)入剛才cvs checkout project_name導(dǎo)出的project_name目錄下進(jìn)行具體文件的版本同步(添加,修改,刪除)操作。
將文件同步到新的版本
cvs update
不制定文件名,cvs將同步所有子目錄下的文件,也可以制定某個文件名/目錄進(jìn)行同步
cvs update file_name
好每天開始工作前或?qū)⒆约旱墓ぷ鲗?dǎo)入到CVS庫里前都要做一次,并養(yǎng)成“先同步 后修改”的習(xí)慣,和Virvual SourceSafe不同,CVS里沒有文件鎖定的概念,所有的沖突是在commit之前解決,如果你修改過程中,有其他人修改并commit到了CVS庫中,CVS會通知你文件沖突,并自動將沖突部分用
>>>>>>
content on cvs server
<<<<<<
content in your file
>>>>>>
標(biāo)記出來,由你確認(rèn)沖突內(nèi)容的取舍。
版本沖突一般是在多個人修改一個文件造成的,但這種項目管理上的問題不應(yīng)該指望由CVS來解決。
確認(rèn)修改寫入到CVS庫里
cvs commit -m "write some comments here" file_name
注意:CVS的很多動作都是通過cvs commit進(jìn)行后確認(rèn)并修改的,好每次只修改一個文件。在確認(rèn)的前,還需要用戶填寫修改注釋,以幫助其他開發(fā)人員了解修改的原因。如果不用寫-m "comments"而直接確認(rèn)`cvs commit file_name` 的話,cvs會自動調(diào)用系統(tǒng)缺省的文字編輯器(一般是vi)要求你寫入注釋。
注釋的質(zhì)量很重要:所以不僅必須要寫,而且必須寫一些比較有意義的內(nèi)容:以方便其他開發(fā)人員能夠很好的理解
不好的注釋,很難讓其他的開發(fā)人員快速的理解:比如: -m "bug fixed" 甚至 -m ""
好的注釋,甚至可以用中文: -m "在用戶注冊過程中加入了Email地址校驗"
修改某個版本注釋:每次只確認(rèn)一個文件到CVS庫里是一個很好的習(xí)慣,但難免有時候忘了指定文件名,把多個文件以同樣注釋commit到CVS庫里了,以下命令可以允許你修改某個文件某個版本的注釋:
cvs admin -m 1.3:"write some comments here" file_name