欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  科技

Linux下CVS的安装配置与操作命令全解析

程序员文章站 2023-11-03 20:34:10
这篇文章主要介绍了Linux下CVS的安装配置与操作命令全解析,CVS是一个常见的版本控制系统,需要的朋友可以参考下... 15-09-23...

在介绍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提交.