Sung in Blog

                     一些技術(shù)文章 & 一些生活雜碎

          內(nèi)容摘要:

          CVS是一個(gè)C/S系統(tǒng),多個(gè)開發(fā)人員通過一個(gè)中心版本控制系統(tǒng)來記錄文件版本,從而達(dá)到保證文件同步的目的。工作模式如下:

                 CVS服務(wù)器(文件版本庫)
               /     |       \
               (版 本 同 步)
             /       |         \
          開發(fā)者1  開發(fā)者2   開發(fā)者3
          

          作為一般開發(fā)人員挑選2,6看就可以了,CVS的管理員則更需要懂的更多一些,最后還簡單介紹了一些Windows下的cvs客戶端使用,CVS遠(yuǎn)程用戶認(rèn)證的選擇及與BUG跟蹤系統(tǒng)等開發(fā)環(huán)境的集成問題。

          1. CVS環(huán)境初始化:CVS環(huán)境的搭建 管理員
          2. CVS的日常使用:日常開發(fā)中最常用的CVS命令, 開發(fā)人員 管理員
          3. CVS的分支開發(fā):項(xiàng)目按照不同進(jìn)度和目標(biāo)并發(fā)進(jìn)行 管理員
          4. CVS的用戶認(rèn)證:通過SSH的遠(yuǎn)程用戶認(rèn)證,安全,簡單 管理員
          5. CVSWEB:CVS的WEB訪問界面大大提高代碼版本比較的效率 管理員
          6. CVS TAG:將$Id$ 加入代碼注釋中,方便開發(fā)過程的跟蹤開發(fā)人員
          7. CVS vs VSS: CVS和Virsual SourceSafe的比較 開發(fā)人員 管理員
          8. WinCVS: 通過SSH認(rèn)證的WinCVS認(rèn)證設(shè)置
          9. 基于CVSTrac的小組開發(fā)環(huán)境搭建:通過CVSTrac實(shí)現(xiàn)web界面的CVS用戶管理,集成的BUG跟蹤和WIKI交流
          10. CVS中的用戶權(quán)限管理:基于系統(tǒng)用戶的CVS權(quán)限管理和基于CVSROOT/passwd的虛擬用戶管理

          一個(gè)系統(tǒng)20%的功能往往能夠滿足80%的需求,CVS也不例外,以下是CVS最常用的功能,可能還不到它全部命令選項(xiàng)的20%,作為一般開發(fā)人員平時(shí)會用cvs update和cvs commit就夠了,更多的需求在實(shí)際應(yīng)用過程中自然會出現(xiàn),不時(shí)回頭看看相關(guān)文檔經(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

          一個(gè)項(xiàng)目的首次導(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)記

          項(xiàng)目導(dǎo)出:將代碼從CVS庫里導(dǎo)出
          cvs checkout project_name
          cvs 將創(chuàng)建project_name目錄,并將最新版本的源代碼導(dǎo)出到相應(yīng)目錄中。這個(gè)checkout和Virvual SourceSafe中的check out不是一個(gè)概念,相對于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將同步所有子目錄下的文件,也可以制定某個(gè)文件名/目錄進(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)容的取舍。
          版本沖突一般是在多個(gè)人修改一個(gè)文件造成的,但這種項(xiàng)目管理上的問題不應(yīng)該指望由CVS來解決。

          確認(rèn)修改寫入到CVS庫里
          cvs commit -m "write some comments here" file_name

          注意:CVS的很多動作都是通過cvs commit進(jìn)行最后確認(rèn)并修改的,最好每次只修改一個(gè)文件。在確認(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地址校驗(yàn)"


          修改某個(gè)版本注釋:每次只確認(rèn)一個(gè)文件到CVS庫里是一個(gè)很好的習(xí)慣,但難免有時(shí)候忘了指定文件名,把多個(gè)文件以同樣注釋commit到CVS庫里了,以下命令可以允許你修改某個(gè)文件某個(gè)版本的注釋:
          cvs admin -m 1.3:"write some comments here" file_name

          添加文件
          創(chuàng)建好新文件后,比如:touch new_file
          cvs add new_file
          注意:對于圖片,Word文檔等非純文本的項(xiàng)目,需要使用cvs add -kb選項(xiàng)按2進(jìn)制文件方式導(dǎo)入(k表示擴(kuò)展選項(xiàng),b表示binary),否則有可能出現(xiàn)文件被破壞的情況
          比如:
          cvs add -kb new_file.gif
          cvs add -kb readme.doc

          如果關(guān)鍵詞替換屬性在首次導(dǎo)入時(shí)設(shè)置錯(cuò)了怎么辦?
          cvs admin -kkv new_file.css

          然后確認(rèn)修改并注釋
          cvs ci -m "write some comments here"

          刪除文件
          將某個(gè)源文件物理刪除后,比如:rm file_name
          cvs rm file_name
          然后確認(rèn)修改并注釋
          cvs ci -m "write some comments here"
          以上面前2步合并的方法為:
          cvs rm -f file_name
          cvs ci -m "why delete file"
          注意:很多cvs命令都有縮寫形式:commit=>ci; update=>up; checkout=>co/get; remove=>rm;

          添加目錄
          cvs add dir_name

          查看修改歷史
          cvs log file_name
          cvs history file_name

          查看當(dāng)前文件不同版本的區(qū)別
          cvs diff -r1.3 -r1.5 file_name
          查看當(dāng)前文件(可能已經(jīng)修改了)和庫中相應(yīng)文件的區(qū)別
          cvs diff file_name
          cvs的web界面提供了更方便的定位文件修改和比較版本區(qū)別的方法,具體安裝設(shè)置請看后面的cvsweb使用

          正確的通過CVS恢復(fù)舊版本的方法
          如果用cvs update -r1.2 file.name
          這個(gè)命令是給file.name加一個(gè)STICK TAG: "1.2" ,雖然你的本意只是想將它恢復(fù)到1.2版本
          正確的恢復(fù)版本的方法是:cvs update -p -r1.2 file_name >file_name
          如果不小心已經(jīng)加成STICK TAG的話:用cvs update -A 解決

          移動文件/文件重命名
          cvs里沒有cvs move或cvs rename,因?yàn)檫@兩個(gè)操作是可以由先cvs remove old_file_name,然后cvs add new_file_name實(shí)現(xiàn)的。

          刪除/移動目錄
          最方便的方法是讓管理員直接移動,刪除CVSROOT里相應(yīng)目錄(因?yàn)镃VS一個(gè)項(xiàng)目下的子目錄都是獨(dú)立的,移動到$CVSROOT目錄下都可以作為新的獨(dú)立項(xiàng)目:好比一顆樹,其實(shí)砍下任意一枝都能獨(dú)立存活),對目錄進(jìn)行了修改后,要求其開發(fā)人員重新導(dǎo)出項(xiàng)目cvs checkout project_name 或者用cvs update -dP同步。

          項(xiàng)目發(fā)布導(dǎo)出不帶CVS目錄的源文件
          做開發(fā)的時(shí)候你可能注意到了,每個(gè)開發(fā)目錄下,CVS都創(chuàng)建了一個(gè)CVS/目錄。里面有文件用于記錄當(dāng)前目錄和CVS庫之間的對應(yīng)信息。但項(xiàng)目發(fā)布的時(shí)候你一般不希望把文件目錄還帶著含有CVS信息的CVS目錄吧,這個(gè)一次性的導(dǎo)出過程使用cvs export命令,不過export只能針對一個(gè)TAG或者日期導(dǎo)出,比如:
          cvs export -r release1 project_name
          cvs export -D 20021023 project_name
          cvs export -D now project_name

          CVS Branch:項(xiàng)目多分支同步開發(fā)

          確認(rèn)版本里程碑:多個(gè)文件各自版本號不一樣,項(xiàng)目到一定階段,可以給所有文件統(tǒng)一指定一個(gè)階段里程碑版本號,方便以后按照這個(gè)階段里程碑版本號導(dǎo)出項(xiàng)目,同時(shí)也是項(xiàng)目的多個(gè)分支開發(fā)的基礎(chǔ)。

          cvs tag release_1_0

          開始一個(gè)新的里程碑
          cvs commit -r 2 標(biāo)記所有文件開始進(jìn)入2.x的開發(fā)

          注意:CVS里的revsion和軟件包的發(fā)布版本可以沒有直接的關(guān)系。但所有文件使用和發(fā)布版本一致的版本號比較有助于維護(hù)。

          版本分支的建立
          在開發(fā)項(xiàng)目的2.x版本的時(shí)候發(fā)現(xiàn)1.x有問題,但2.x又不敢用,則從先前標(biāo)記的里程碑:release_1_0導(dǎo)出一個(gè)分支 release_1_0_patch
          cvs rtag -b -r release_1_0 release_1_0_patch proj_dir

          一些人先在另外一個(gè)目錄下導(dǎo)出release_1_0_patch這個(gè)分支:解決1.0中的緊急問題,
          cvs checkout -r release_1_0_patch
          而其他人員仍舊在項(xiàng)目的主干分支2.x上開發(fā)

          在release_1_0_patch上修正錯(cuò)誤后,標(biāo)記一個(gè)1.0的錯(cuò)誤修正版本號
          cvs tag release_1_0_patch_1

          如果2.0認(rèn)為這些錯(cuò)誤修改在2.0里也需要,也可以在2.0的開發(fā)目錄下合并release_1_0_patch_1中的修改到當(dāng)前代碼中:
          cvs update -j release_1_0_patch_1

          CVS的遠(yuǎn)程認(rèn)證通過SSH遠(yuǎn)程訪問CVS

          使用cvs本身基于pserver的遠(yuǎn)程認(rèn)證很麻煩,需要定義服務(wù)器和用戶組,用戶名,設(shè)置密碼等,

          常見的登陸格式如下:
          cvs -d :pserver:cvs_user_name@cvs.server.address:/path/to/cvsroot login
          例子:
          cvs -d :pserver:cvs@samba.org:/cvsroot login

          不是很安全,因此一般是作為匿名只讀CVS訪問的方式。從安全考慮,通過系統(tǒng)本地帳號認(rèn)證并通過SSH傳輸是比較好的辦法,通過在客戶機(jī)的 /etc/profile里設(shè)置一下內(nèi)容:
          CVSROOT=:ext:$USER@cvs.server.address#port:/path/to/cvsroot CVS_RSH=ssh; export CVSROOT CVS_RSH
          所有客戶機(jī)所有本地用戶都可以映射到CVS服務(wù)器相應(yīng)同名帳號了。

          比如:

          CVS服務(wù)器是192.168.0.3,上面CVSROOT路徑是/home/cvsroot,另外一臺開發(fā)客戶機(jī)是192.168.0.4,如果 tom在2臺機(jī)器上都有同名的帳號,那么從192.168.0.4上設(shè)置了:
          export CVSROOT=:ext:tom@192.168.0.3:/home/cvsroot
          export CVS_RSH=ssh
          tom就可以直接在192.168.0.4上對192.168.0.3的cvsroot進(jìn)行訪問了(如果有權(quán)限的話)
          cvs checkout project_name
          cd project_name
          cvs update
          ...
          cvs commit

          如果CVS所在服務(wù)器的SSH端口不在缺省的22,或者和客戶端與CVS服務(wù)器端SSH缺省端口不一致,有時(shí)候設(shè)置了:
          :ext:$USER@test.server.address#port:/path/to/cvsroot

          仍然不行,比如有以下錯(cuò)誤信息:
          ssh: test.server.address#port: Name or service not known
          cvs [checkout aborted]: end of file from server (consult above messages if any)

          解決的方法是做一個(gè)腳本指定端口轉(zhuǎn)向(不能使用alias,會出找不到文件錯(cuò)誤):
          創(chuàng)建一個(gè)/usr/bin/ssh_cvs文件,假設(shè)遠(yuǎn)程服務(wù)器的SSH端口是非缺省端口:34567
          #!/bin/sh
          /usr/bin/ssh -p 34567 "$@"
          然后:chmod +x /usr/bin/ssh_cvs
          并CVS_RSH=ssh_cvs; export CVS_RSH

          注意:port是指相應(yīng)服務(wù)器SSH的端口,不是指cvs專用的pserver的端口

          CVSWEB:提高文件瀏覽效率

          CVSWEB就是CVS的WEB界面,可以大大提高程序員定位修改的效率:

          使用的樣例可以看:http://www.freebsd.org/cgi/cvsweb.cgi

          CVSWEB的下載:CVSWEB從最初的版本已經(jīng)演化出很多功能界面更豐富的版本,這個(gè)是我個(gè)人感覺安裝設(shè)置比較方便的:
          原先在:http://www.spaghetti-code.de/software/linux/cvsweb/,但目前已經(jīng)刪除,目前仍可以在本站下載CVSWEB,其實(shí)最近2年FreeBSD的CVSWeb項(xiàng)目已經(jīng)有了更好的發(fā)展吧,而當(dāng)初沒有用FreeBSD那個(gè)版本主要就是因?yàn)闆]有彩色的文件Diff功能。
          下載解包:
          tar zxf cvsweb.tgz
          把配置文件cvsweb.conf放到安全的地方(比如和apache的配置放在同一個(gè)目錄下),
          修改:cvsweb.cgi讓CGI找到配置文件:
          $config = $ENV{'CVSWEB_CONFIG'} || '/path/to/apache/conf/cvsweb.conf';

          轉(zhuǎn)到/path/to/apache/conf下并修改cvsweb.conf:

          1. 修改CVSROOT路徑設(shè)置:
            %CVSROOT = (
            'Development' => '/path/to/cvsroot', #<==修改指向本地的CVSROOT
            );
          2. 缺省不顯示已經(jīng)刪除的文檔:
            "hideattic" => "1",#<==缺省不顯示已經(jīng)刪除的文檔
          3. 在配置文件cvsweb.conf中還可以定制頁頭的描述信息,你可以修改$long_intro成你需要的文字

          CVSWEB可不能隨便開放給所有用戶,因此需要使用WEB用戶認(rèn)證:
          先生成 passwd:
          /path/to/apache/bin/htpasswd -c cvsweb.passwd user

          修改httpd.conf: 增加
          <Directory "/path/to/apache/cgi-bin/cvsweb/">
          AuthName "CVS Authorization"
          AuthType Basic
          AuthUserFile /path/to/cvsweb.passwd
          require valid-user
          </Directory>

          CVS TAGS: $Id: cvs_card.html,v 1.5 2003/03/09 08:41:46 chedong Exp $

          將$Id: cvs_card.html,v 1.9 2003/11/09 07:57:11 chedong Exp $ 加在程序文件開頭的注釋里是一個(gè)很好的習(xí)慣,cvs能夠自動解釋更新其中的內(nèi)容成:file_name version time user_name 的格式,比如:cvs_card.txt,v 1.1 2002/04/05 04:24:12 chedong Exp,可以這些信息了解文件的最后修改人和修改時(shí)間


          幾個(gè)常用的缺省文件:
          default.php
          <?php
          /*
           * Copyright (c) 2002 Company Name.
           * $Header: /home/cvsroot/tech/cvs_card.html,v 1.9 2003/11/09 07:57:11 chedong Exp $
           */
          
          ?>
          ====================================
          Default.java: 注意文件頭一般注釋用 /* 開始 JAVADOC注釋用 /** 開始的區(qū)別
          /*
           * Copyright (c) 2002 MyCompany Name.
           * $Header: /home/cvsroot/tech/cvs_card.html,v 1.9 2003/11/09 07:57:11 chedong Exp $
           */
          
          package com.mycompany;
          
          import java.;
          
          /**
           * comments here
           */
          public class Default {
              /**
               * Comments here
               * @param
               * @return
               */
              public toString() {
          
              }
          }
          ====================================
          default.pl:
          #!/usr/bin/perl -w
          # Copyright (c) 2002 Company Name.
          # $Header: /home/cvsroot/tech/cvs_card.html,v 1.9 2003/11/09 07:57:11 chedong Exp $
          
          # file comments here
          
          use strict;
          
          

          CVS vs VSS

          CVS沒有文件鎖定模式,VSS在check out同時(shí),同時(shí)記錄了文件被導(dǎo)出者鎖定。

          CVS的update和commit, VSS是get_lastest_version和check in

          對應(yīng)VSS的check out/undo check out的CVS里是edit和unedit

          在CVS中,標(biāo)記自動更新功能缺省是打開的,這樣也帶來一個(gè)潛在的問題,就是不用-kb方式添加binary文件的話在cvs自動更新時(shí)可能會導(dǎo)致文件失效。

          $Header: /home/cvsroot/tech/cvs_card.html,v 1.5 2003/03/09 08:41:46 chedong Exp $ $Date: 2003/11/09 07:57:11 $這樣的標(biāo)記在Virsual SourceSafe中稱之為Keyword Explaination,缺省是關(guān)閉的,需要通過OPITION打開,并指定需要進(jìn)行源文件關(guān)鍵詞掃描的文件類型:*.txt,*.java, *.html...

          對于Virsual SourceSafe和CVS都通用的TAG有:
          $Header: /home/cvsroot/tech/cvs_card.html,v 1.5 2003/03/09 08:41:46 chedong Exp $
          $Author: chedong $
          $Date: 2003/11/09 07:57:11 $
          $Revision: 1.9 $

          我建議盡量使用通用的關(guān)鍵詞保證代碼在CVS和VSS都能方便的跟蹤。

          WinCVS

          下載:

          cvs Windows客戶端:目前穩(wěn)定版本為1.2
          http://cvsgui.sourceforge.net
          ssh Windows客戶端
          http://www.networksimplicity.com/openssh/

          安裝好以上2個(gè)軟件以后:
          WinCVS客戶端的admin==>preference設(shè)置
          1 在general選單里
          設(shè)置CVSROOT: username@192.168.0.123:/home/cvsroot
          設(shè)置Authorization: 選擇SSH server

          2 Port選單里
          鉤上:check for alternate rsh name
          并設(shè)置ssh.exe的路徑,缺省是裝在 C:\Program Files\NetworkSimplicity\ssh\ssh.exe

          然后就可以使用WinCVS進(jìn)行cvs操作了,所有操作都會跳出命令行窗口要求你輸入服務(wù)器端的認(rèn)證密碼。

          當(dāng)然,如果你覺得這樣很煩的話,還有一個(gè)辦法就是生成一個(gè)沒有密碼的公鑰/私鑰對,并設(shè)置CVS使用基于公鑰/私鑰的SSH認(rèn)證(在general 選單里)。

          可以選擇的diff工具:examdiff
          下載:
          http://www.prestosoft.com/examdiff/examdiff.htm
          還是在WinCVS菜單admin==>preference的WinCVS選單里
          選上:Externel diff program
          并設(shè)置diff工具的路徑,比如:C:\Program Files\ed16i\ExamDiff.exe
          在對文件進(jìn)行版本diff時(shí),第一次需要將窗口右下角的use externel diff選上。

          基于CVSTrac的小組開發(fā)環(huán)境搭建

          作為一個(gè)小組級的開發(fā)環(huán)境,版本控制系統(tǒng)和BUG跟蹤系統(tǒng)等都涉及到用戶認(rèn)證部分。如何方便的將這些系統(tǒng)集成起來是一個(gè)非常困難的事情,畢竟我們不能指望 Linux下有像Source Offsite那樣集成度很高的版本控制/BUG跟蹤集成系統(tǒng)。

          我個(gè)人是很反對使用pserver模式的遠(yuǎn)程用戶認(rèn)證的,但如果大部分組員使用WINDOWS客戶端進(jìn)行開發(fā)的話,總體來說使用 CVSROOT/passwd認(rèn)證還是很難避免的,但CVS本身用戶的管理比較麻煩。本來我打算自己用perl寫一個(gè)管理界面的,直到我發(fā)現(xiàn)了 CVSTrac:一個(gè)基于WEB界面的BUG跟蹤系統(tǒng),它外掛在CVS系統(tǒng)上的BUG跟蹤系統(tǒng),其中就包括了WEB界面的CVSROOT/passwd文件的管理,甚至還集成了WIKIWIKI討論組功能。

          這里首先說一下CVS的pserver模式下的用戶認(rèn)證,CVS的用戶認(rèn)證服務(wù)是基于inetd中的:
          cvspserver stream tcp nowait apache /usr/bin/cvs cvs --allow-root=/home/cvsroot pserver
          一般在2401端口(這個(gè)端口號很好記:49的平方)

          CVS用戶數(shù)據(jù)庫是基于CVSROOT/passwd文件,文件格式:
          [username]:[crypt_password]:[mapping_system_user]
          由于密碼都用的是UNIX標(biāo)準(zhǔn)的CRYPT加密,這個(gè)passwd文件的格式基本上是apache的htpasswd格式的擴(kuò)展(比APACHE的 PASSWD文件多一個(gè)系統(tǒng)用戶映射字段),所以這個(gè)文件最簡單的方法可以用
          apache/bin/htpasswd -b myname mypassword
          創(chuàng)建。注意:通過htpasswd創(chuàng)建出來的文件會沒有映射系統(tǒng)用戶的字段
          例如:
          new:geBvosup/zKl2
          setup:aISQuNAAoY3qw
          test:hwEpz/BX.rEDU

          映射系統(tǒng)用戶的目的在于:你可以創(chuàng)建一個(gè)專門的CVS服務(wù)帳號,比如用apache的運(yùn)行用戶apache,并將/home/cvsroot目錄下的所有權(quán)限賦予這個(gè)用戶,然后在passwd文件里創(chuàng)建不同的開發(fā)用戶帳號,但開發(fā)用戶帳號最后的文件讀寫權(quán)限都映射為apache用戶,在SSH模式下多個(gè)系統(tǒng)開發(fā)用戶需要在同一個(gè)組中才可以相互讀寫CVS庫中的文件。

          進(jìn)一步的,你可以將用戶分別映射到apache這個(gè)系統(tǒng)用戶上。
          new:geBvosup/zKl2:apache
          setup:aISQuNAAoY3qw:apache
          test:hwEpz/BX.rEDU:apache

          CVSTrac很好的解決了CVSROOT/passwd的管理問題,而且包含了BUG跟蹤報(bào)告系統(tǒng)和集成WIKIWIKI交流功能等,使用的 CGI方式的安裝,并且基于GNU Public License

          在inetd里加入cvspserver服務(wù):
          cvspserver stream tcp nowait apache /usr/bin/cvs cvs --allow-root=/home/cvsroot pserver

          xietd的配置文件:%cat cvspserver
          service cvspserver
          {
          disable = no
          socket_type = stream
          wait = no
          user = apache
          server = /usr/bin/cvs
          server_args = -f --allow-root=/home/cvsroot pserver
          log_on_failure += USERID
          }

          注意:這里的用戶設(shè)置成apache目的是和/home/cvsroot的所有用戶一致,并且必須讓這個(gè)這個(gè)用戶對/home/cvsroot/下的 CVSROOT/passwd和cvstrac初始化生成的myproj.db有讀取權(quán)限。

          安裝過程

          1. 下載:可以從http://www.cvstrac.org 下載
            我用的是已經(jīng)在Linux上編譯好的應(yīng)用程序包:cvstrac-1.1.2.bin.gz,
            %gzip -d cvstrac-1.1.2.bin.gz
            %chmod +x cvstrac-1.1.2.bin
            #mv cvstarc-1.1.1.bin /usr/bin/cvstrac
            如果是從源代碼編譯:
            從 http://www.sqlite.org/download.html 下載SQLITE的rpm包:
            rpm -i sqlite-devel-2.8.6-1.i386.rpm
            從 ftp://ftp.cvstrac.org/cvstrac/ 下載軟件包
            解包,假設(shè)解包到/home/chedong/cvstrac-1.1.2下,并規(guī)劃將cvstrac安裝到/usr/local/bin目錄下, cd /home/chedong/cvstrac-1.1.2 編輯linux-gcc.mk:
            修改:
            SRCDIR = /home/chedong/cvstrac-1.1.2
            INSTALLDIR = /usr/local/bin
            然后
            mv linux-gcc.mk Makefile
            make
            #make install

          2. 初始化cvstrac數(shù)據(jù)庫:假設(shè)數(shù)據(jù)庫名是 myproj
            在已經(jīng)裝好的CVS服務(wù)器上(CVS庫這時(shí)候應(yīng)該已經(jīng)是初始化好了,比如:cvs init初始化在/home/cvsroot里),運(yùn)行一下
            %cvstrac init /home/cvsroot myproj
            運(yùn)行后,/home/cvsroot里會有一個(gè)的myproj.db庫,使用CVSTRAC服務(wù),/home/cvsroot/myproj.db /home/cvsroot/CVSROOT/readers /home/cvsroot/CVSROOT/writers /home/cvsroot/CVSROOT/passwd這幾個(gè)文件對于web服務(wù)的運(yùn)行用戶應(yīng)該是可寫的,在RedHat8上,缺省就有一個(gè)叫 apache用戶和一個(gè)apache組,所以在httpd.conf文件中設(shè)置了用apache用戶運(yùn)行web服務(wù):
            User apache
            Group apache,
            然后設(shè)置屬于apache用戶和apache組
            #chown -R apache:apache /home/cvsroot
            -rw-r--r-- 1 apache apache 55296 Jan 5 19:40 myproj.db
            drwxrwxr-x 3 apache apache 4096 Oct 24 13:04 CVSROOT/
            drwxrwxr-x 2 apache apache 4096 Aug 30 19:47 some_proj/
            此外還在/home/cvsroot/CVSROOT中設(shè)置了:
            chmod 664 readers writers passwd
          3. 在apche/cgi-bin目錄中創(chuàng)建腳本cvstrac:
            #!/bin/sh
            /usr/bin/cvstrac cgi /home/cvsroot
            設(shè)置腳本可執(zhí)行:
            chmod +x /home/apache/cgi-bin/cvstrac
          4. 從 http://cvs.server.address/cgi-bin/cvstrac/myproj 進(jìn)入管理界面
            缺省登錄名:setup 密碼 setup
            對于一般用戶可以從:
            http://cvs.server.address/cgi-bin/cvstrac/myproj
          5. 在setup中重新設(shè)置了CVSROOT的路徑后,/home/cvsroot
            如果是初次使用需要在/home/cvsroot/CVSROOT下創(chuàng)建passwd, readers, writers文件
            touch passwd readers writers
            然后設(shè)置屬于apache用戶,
            chown apache.apache passwd readers writers
            這樣使用setup用戶創(chuàng)建新用戶后會同步更新CVSROOT/passwd下的帳號

          修改登錄密碼,進(jìn)行BUG報(bào)告等,
          更多使用細(xì)節(jié)可以在使用中慢慢了解。

          對于前面提到的WinCVS在perference里設(shè)置:
          CVSROOT欄輸入:username@ip.address.of.cvs:/home/cvsroot
          Authenitication選擇:use passwd file on server side
          就可以了從服務(wù)器上進(jìn)行CVS操作了。

          CVS的用戶權(quán)限管理

          CVS的權(quán)限管理分2種策略:

          • 基于系統(tǒng)文件權(quán)限的系統(tǒng)用戶管理:適合多個(gè)在Linux上使用系統(tǒng)帳號的開發(fā)人員進(jìn)行開發(fā)。
          • 基于CVSROOT/passwd的虛擬用戶管理:適合多個(gè)在Windows平臺上的開發(fā)人員將帳號映射成系統(tǒng)帳號使用。
          為什么使用apache/apache用戶?首先RedHat8中缺省就有了,而且使用這個(gè)用戶可以方便通過cvstrac進(jìn)行WEB管理。
          chown -R apache.apache /home/cvsroot
          chmod 775 /home/cvsroot

          Linux上通過ssh連接CVS服務(wù)器的多個(gè)開發(fā)人員:通過都屬于apache組實(shí)現(xiàn)文件的共享讀寫
          開發(fā)人員有開發(fā)服務(wù)器上的系統(tǒng)帳號:sysuser1 sysuser2,設(shè)置讓他們都屬于apache組,因?yàn)橥ㄟ^cvs新導(dǎo)入的項(xiàng)目都是對組開放的:664權(quán)限的,這樣無論那個(gè)系統(tǒng)用戶導(dǎo)入的項(xiàng)目文件,只要文件的組宿主是apache,所有其他同組系統(tǒng)開發(fā)用戶就都可以讀寫;基于ssh遠(yuǎn)程認(rèn)證的也是一樣。

             apache(system group)
          /            |           \
          sysuser1   sysuser2     sysuser3

          Windows上通過cvspserver連接CVS服務(wù)器的多個(gè)開發(fā)人員:通過在passwd文件種映射成 apache用戶實(shí)現(xiàn)文件的共享讀寫
          他們的帳號通過CVSROOT/passwd和readers writers這幾個(gè)文件管理;通過cvstrac設(shè)置所有虛擬用戶都映射到apache用戶上即可。

             apache(system user)
          /            |            \
          windev1     windev2      windev3             

          利用cvs + (WinCVS/cvsweb/cvstrac),構(gòu)成了一個(gè)相對完善的跨平臺工作組開發(fā)版本控制環(huán)境。

          相關(guān)資源:

          CVS HOME:
          http://www.cvshome.org

          CVS FAQ:
          http://www.loria.fr/~molli/cvs-index.html

          相關(guān)網(wǎng)站:
          http://directory.google.com/Top/Computers/Software/Configuration_Management/Tools/Concurrent_Versions_System/

          CVS--并行版本系統(tǒng)
          http://www.soforge.com/cvsdoc/zh_CN/book1.html

          CVS 免費(fèi)書:
          http://cvsbook.red-bean.com/

          CVS 命令的速查卡片:
          http://www.refcards.com/about/cvs.html

          WinCVS:
          http://cvsgui.sourceforge.net/

          CVSTrac: A Web-Based Bug And Patch-Set Tracking System For CVS
          http://www.cvstrac.org

          StatCVS:基于CVS的代碼統(tǒng)計(jì)工具:按代碼量,按開發(fā)者的統(tǒng)計(jì)表等
          http://sourceforge.net/projects/statcvs

          如何在WEB開發(fā)中規(guī)劃CVS上:在Google上查 "cvs web development"
          http://ccm.redhat.com/bboard-archive/cvs_for_web_development/index.html

          一些集成了CVS的IDE環(huán)境:
          Eclipse
          Magic C++
          posted on 2005-10-24 22:23 Sung 閱讀(401) 評論(0)  編輯  收藏 所屬分類: software Development
          主站蜘蛛池模板: 呼图壁县| 当雄县| 永兴县| 深泽县| 托里县| 财经| 永川市| 凤翔县| 石棉县| 通江县| 湛江市| 全椒县| 兴隆县| 秭归县| 新干县| 化隆| 微山县| 鄂伦春自治旗| 永修县| 房山区| 彭水| 霸州市| 即墨市| 兴和县| 万载县| 大足县| 井研县| 鄂托克前旗| 柘城县| 普兰县| 盐山县| 克东县| 杭锦旗| 营口市| 宁河县| 临泽县| 镇远县| 沂南县| 综艺| 务川| 怀宁县|