萬盛學電腦網

 萬盛學電腦網 >> 服務器教程 >> Linux下CVS的安裝配置與操作命令全解析

Linux下CVS的安裝配置與操作命令全解析

   在介紹CVS命令之前,先說點別的

  如以前說,倉庫內除樂源文件外,還包括一系列的管理文件.位於$CVSROOT/CVSROOT

  修改管理文件的方法等同於源代碼文件,利用CVS命令提取和修改.

  下面描述每個文件的用途:

  checkoutlist 支持CVSROOT目錄的其它管理文件,允許為各種CVS命令定置信息

  commitinfo 在cvs commit命令執行時,這個文件指定樂文件提交時執行的命令

  cvswrappers 定義樂一個包裝程序當文件登記或檢取時就會執行.

  editinfo 允許你在commit命令啟動前在日志信息被記錄後執行的腳本

  history 跟蹤所有影響倉庫的命令

  loginfo 類似coimmitinfo, 只是在文件提交後執行

  modules 允許為一組文件定義一個符號,否則必須為每一個要引用的文件

  指定部分路徑名(相對於$CVSROOT)

  nitify 控制從/"watch/"來的通知./"watch/"由/"cvs watch add/"和/"cvs edit/"

  設置

  rcsinfo 為commit log回話指定一個模板.

  taginfo 定義樂在任意/"tag/"操作後執行的程序.

  CVS服務器的安裝

  默認情況下,CVS在Redhat Linux中已經安裝,這一點可以通過在Linux命令行的情況下運行:

  代碼如下:

  rpm –q cvs

  如果出現CVS的版本信息就證明已經安裝成功了。

  CVS服務器安裝包可以從網上的很多地方下載,也可以到CVS的官方網站進行下載。根據你所使用的系統,下載相應的版本,然後進行安裝。因為我們的項目是在Redhat Linux下使用CVS服務器進行版本管理,所以本文將主要基於Redhat Linux進行介紹。首先下載CVS服務器的rpm包,當然也可以下載其它方式的包如源程序包,然後采用以下命令進行安裝:

  代碼如下:

  rpm -ivh cvs-1.11.7-1.i386.rpm

  CVS服務器的配置

  安裝完之後的第一件事就是要配置CVS服務器的配置文件,使其能正常的工作。首先在/etc/services文件中添加cvspserver,使其成為Linux的一種服務也就是cvs服務器例程的入口,配置如下:

  cvspserver 2401/tcp # cvs client/server operations

  cvspserver 2401/udp # cvs client/server operations

  如果文件中已經存在上面的兩行文字,就不用添加了。

  配置xinetd,用xinetd來啟動CVS驗證服務器:

  進入到/etc/xinetd.d/目錄,然後編輯一個文本文件,名字一定要與/etc/services中的入口名字cvspserver一致,所以這裡用cvspserver作為文件名,文件的內容如下所示:

  代碼如下:

  service cvspserver

  {

  disable = no

  flags = REUSE

  socket_type = stream

  wait = no

  user = root

  server = /usr/bin/cvs

  server_args = -f --allow-root=/usr/cvsroot pserver

  log_on_failure += USERID

  }

  編輯文件之後測試cvspserver服務是否配置成功。

  執行

  代碼如下:

  /etc/init.d/xinetd restart

  重新啟動服務,啟動成功之後,執行下面的語句,驗證服務是否啟動正常:

  代碼如下:

  telnet localhost 2401

  如果出現如下字樣:

  Trying 127.0.0.1...

  Connected to localhost.

  Escape character is '^]'.

  輸入hi,會繼續輸出如下字樣

  cvs [pserver aborted]: bad auth protocol start: hi

  Connection closed by foreign host.

  出現以上的現象表示CVS用戶驗證服務器已經配置成功。

  如果出現如下字樣,表示配置不成功,請重新檢查以上的配置:

  Trying 127.0.0.1...

  telnet: connect to address 127.0.0.1: Connection refused

  CVS的環境變量

  CVS使用樂幾個環境變量

  CVSROOT 倉庫根目錄的完整路徑名

  CVSREAD 如果設置,表明在checkout操作時所有的文件都置成只讀

  CVSBIN CVS利用樂很多RCS的命令,指定樂RCS工具的路徑

  CVSEDITOR 指定用戶書寫日志信息所使用的編輯器

  CVS_RSH 啟動一個遠程CVS服務器時,所使用的shell的名稱

  CVS_SERVER 決定/"cvs server/"的名字,缺省是CVS

  CVSWRAPPERS cvswrapper腳本, 用來指定包裝文件名.

  關鍵字

  管理源文件的一種技術叫/"關鍵字替換/".在每次執行/"cvs commit/"操作後

  源文件的某些關鍵字會被替換為可用的詞

  $AUTHOR$ 用戶名

  $Data$ 登記時的時間

  $Header$ 標准的首部,包含RCS的完整路徑名,日期,作者

  $Id$ 除RCS文件名不完整外與$Header$同.

  $Log$ 包含RCS的完整路徑名,版本號,日期,作者和在提交時提供的日志信息.

  $RCSfile$ 包含RCS的文件名,不包括路徑名

  $Revision$ 分配的版本號

  $Source$ RCS文件的完整名

  $State$ 分配的版本的狀態,由 cvs admin -s 分配.

  例:

  在cvs commit之前,main.c裡有

  static char *rcsid=/"$Id$/";

  執行cvs commit後

  main.c的改行變為:

  static char *rcsid=/"$Id: main.c,v 1.2 1999/04/29 15:10:14 trimblef Exp$/";

  下面開始說說CVS的命令

  我們已下面倉庫的數據為例

  $CVSROOT

  --CVSROOT

  --project

  --src

  --main

  --main.c

  --main.h

  --print

  --print.c

  --print.h

  --term

  --term.c

  --term.h

  CVS checkout 命令

  從倉庫提取指定的文件到當前目錄,並建立同樣的結構,並創建CVS目錄

  例

  代碼如下:

  bash$ cvs checkout project

  bash$ cvs checkout project/src/main

  為使用便利,我們可以對一個目錄建一個縮寫,方法是修改$CVSROOT/CVSROOT/下的

  modules文件.(當然是用cvs 命令完成)

  代碼如下:

  cvs checkout CVSROOT/modules

  cd CVSROOT

  vi modules

  我們在文件尾加上

  代碼如下:

  src project/src

  print project/src/print

  cvs commit

  以後我們就可以用cvs checkout print來代替

  cvs checkout project/src/print

  cvs checkout命令缺省是得到最新版本.我們也可以得到某一個老版本

  代碼如下:

  cvs checkout -r 1.1 print

  將print的1.1版的代碼取出.

  cvs checkout的詳細用法見cvs -H checkout的輸出.

  CVS commit 命令

  在對文件的修改完成後,用cvs commit提交到倉庫.

  代碼如下:

  cvs commit -m /"Update by xxxxx/" project

  cvs commit -m /"Update main.c/" main.c

  提交完成後,當前的版本號會更新,如原來為1.1,現為1.2. 這兩個版本都在

  倉庫的主干(maintrunk)上.

  -m選項可以記錄有關提交的注釋.如果沒有指定-m選項,在環境變量CVSEDITOR

  中指定的編輯器被調用(vi是缺省的),提示鍵入文本,修改記錄注釋.

  CVS update

  CVS允許多人同時對一個文件進行修改.

  假設泥正在修改文件的一部分,現想合並更新自己的本地拷貝(checkout)和

  另一個人所做的修改(已經放在倉庫裡),可用cvs update

  代碼如下:

  cvs update

  CVS tag , CVS rtag

  創建分支可以使用戶對一些文件進行修改而不會影響主干(當commit時).

  創建分支首先為擬修改的某些文件創建一個標簽(tag),標簽是賦於一個文件或一組文件的符號.在源代碼的生命周期裡,組成一組模塊的文件被賦於相同的標簽.

  創建標簽:在工作目錄裡執行cvs tag

  例: 為src創建標簽:

  代碼如下:

  cvs checkout src

  cvs tag release-1-0

  標簽創建後, 就可以為其創建一個分支:

  代碼如下:

  cvs rtag -b -r release-1-0 release-1-0-path print

  -b :創建分支

  -r release-1-0 :指定存在的標簽

  releas-1-0-patch:分支

  print: 模塊名

  合並

  使用cvs update -j 選項可以將分支上的改變與本地文件拷貝合並.

  代碼如下:

  cvs update -j release-1-0 print.c

  cvs release

  對源文件作必要修改後, 可以用cvs release 刪除本地工作拷貝

  並通知其他開發者這個模塊不再使用.

  代碼如下:

  cvs release -d print

  -d : 刪除

  print: 目錄

  沖突

  由於CVS允許多人同時修改同一文件,沖突是不可避免的.例如當兩人

  同時修改同一文件的同一行時.

  這時,如用cvs update 更新,CVS檢測到沖突的存在,它會將沖突的代碼

  用/"<<<<<<<<<<<<<<>>>>>>>>>>>>>>/"標識.這時需手工處理這段代碼.與引起

  沖突的開發者協商,並對文件修改後即可用cvs commit提交.

copyright © 萬盛學電腦網 all rights reserved