该文章来自于网络:
1. 检出源代码操作(cvs checkout)
*
将项目工作库目录取到个人工作库:cvs checkout dirname * 将项目工作库中某个文件取到本地个人工作库:cvs checkout filename 2. 将文件同步到最新的版本(cvs update)
开发人员每天开始工作前,请将项目工作库中的最新版本代码文件取到个人工作库中,养成"先同步,后修改"的习惯; 更新单个文件:cvs update file_name 更新目录:cvs update (不指定文件名,cvs将同步所有子目录下的文件) 注意:第一次导出文件以后,就不是通过cvs checkout来同步文件了,而是要进入刚才cvs checkout project_name导出的project_name目录下进行具体文件的版本同步(添加,修改,删除)操作。 3. 文件提交(cvs commit) 确认文件修改写入CVS库:cvs commit -m "注释内容" file_name; 建议每次文件提交都只修改一个文件,以避免多个文件以同样注释commit到CVS库里了;每次确认提交时,请认真填写修改注释,以帮助其他开发人员了解修改的原因;
4. 添加(cvs add)
添加某个目录操作:cvs add dir_name 添加某个文件操作:cvs add new_file; 然后确认添加文件并注释 cvs commit -m "write some comments here" 对于图片,Word文档等非纯文本的项目,需要使用cvs add -kb选项按2进制文件方式导入,否则有可能出现文件被破坏的情况; cvs add -kb readme.doc 5. 删除文件(cvs rm)
将某个文件物理删除操作:cvs remove -f file_name
确认删除文件并注释cvs commit -m "why delete file" 查看修改历史(cvs log) 查看日志操作命令: cvs log file_name cvs log dirname 操作历史命令:cvs history file_name 查看版本操作:cvs status -v filename 查看当前文件不同版本的区别: cvs diff file_name cvs diff -c file_name 查看对照的输出 6. 更名
cvs里没有cvs move或cvs rename两个命令; 可先移动老命名文件:cvs remove old_file_name; 然后再增加新命名文件实现更名操作:cvs add new_file_name; 例:将文件tt.c改名为test.c,具体操作如下 mv tt.c test.c cvs remove -f tt.c cvs commit -m "remove for rename" tt.c cvs add test.c 7. 导出不带CVS目录的源代码文件
每个开发目录下,CVS都创建了一个CVS/目录。里面有文件用于记录当前目录和CVS库之间的对应信息。项目发布的时候一般不希望把文件目录还带着含有 CVS信息的CVS目录导出,这个一次性的导出过程使用cvs export命令,不过export只能针对一个TAG或者日期导出; cvs export -r release1 project_name; cvs export -D 20021023 project_name cvs export -D now project_name 8. 基线标识
多个文件各自版本号不一样,项目到一定阶段,可以给所有文件统一指定一个阶段里程碑版本号,方便以后按照这个阶段里程碑版本号导出项目,同时也是项目的多个分支开发的基础; 确认版本基线cvs tag release_1_0 开始一个新的版本基线; cvs commit -r 2 标记所有文件开始进入2.0的开发 cvs update -j release_1_0_patch_1 CVS 代表协作版本系统;这是一个将一组文件放在层次目录树中以保持同步的系统。人们可以从 CVS 服务器上更新他们的本地层次树副本,并将修改的结果或新文件发回;或者删除旧文件。 CVS 基于客户端/服务器的行为使得其可容纳多用户,构成网络也很方便。这一特性使得 CVS 成为位于不同地点的人同时处理数据文件(特别是程序的源代码)时的首选。
所有重要的免费软件项目都使用 CVS 作为其程序员之间的中心点,以便能够综合各程序员的改进和更改。这些项目包括: Gnome, KDE, The GIMP, Wine, 等等。
所以,理所当然的,MandrakeSoft 也使用 CVS 作为其自身的开发管理平台。
下面是我自己在配置CVS服务器和客户端的一点步骤总结,希望能帮你节省时间,一步到位^-^
配置服务器的全部步骤如下:
1:我用的是linux redhat9.0
2:建立了cvs用户组
groupadd cvs
3.建立cvs组的cvsroot用户和所属的目录
useradd -g cvs -G cvs -d/home/cvsroot cvsroot
4:为cvsroot用户添加密码
passwd cvsroot
5:改变/home/cvsroot的目录属性
chmod 775 /home/cvsroot
6:初始化cvs源码库,此操作生成目录/home/cvsroot/CVSROOT,其下为一些初始化文件
cvs -d/home/cvsroot init
7:创建可以登陆cvs服务的用户及密码,需要创建文件passwd
vi /home/cvsroot/CVSROOT/passwd
文件内容如下:
steven:xxxxx:cvsroot
8.xxxxxx为密码,由以下文件生成: vi /home/cvsroot/passwdgen.pl 文件内容:
#!/usr/bin/perl
srand (time()); my $randletter = "(int (rand (26)) + (int (rand (1) + .5) % 2 ? 65 : 97))"; my $salt = sprintf ("%c%c", eval $randletter, eval $randletter); my $plaintext = shift; my $crypttext = crypt ($plaintext, $salt); print "${crypttext}\n"; 9.如果需要密码为:some,则敲入: passwdgen.pl "some" 回车即可得到加密密码,用其替换passwd文件中的xxxxxx
10.加入cvs服务(我的redhath9缺省就有cvs服务,所以不用加)
vi /etc/services
cvspserver 2401/tcp #pserver cvs service cvspserver 2401/udp #pserver cvs service 11.cvs 服务由inted来唤起,因此需要改动inetd提供的服务,我的redhat使用的是inetd 方式则在文件/etc/inetd.conf中加入如下的内容:cvspserver stream tcp nowait root /usr/bin/cvs cvs --allow-root=/home/cvsroot pserver
我的redhat9使用的是xinetd方式,所以在xinetd.d目录下添加需要启动的服务:
cd /etc/xinetd.d
vi cvspserver 文件内容:
service cvspserver
{ disable = no flags = REUSE socket_type = stream wait = no user = root server = /usr/bin/cvs server_args = -f --allow-root=/home/cvsroot pserver log_on_failure += USERID } 12.重新启动inetd或者xinetd:
/etc/rc.d/init.d/xinetd restart
13.检查cvspserver服务是否已经启动
netstat -l |grep cvspserver
结果如下:
tcp 0 0 *:cvspserver *:* LISTEN
以上结果全部通过,但是在我的客户机(redhat9)上执行
cvs -d :pserver:steven@192.168.211.72:/home/cvsroot login
输入密码后,返回connection confuse信息
补:
cvs -d :pserver:steven@192.168.211.72:/home/cvsroot login
输入密码后,没有收到任何消息,即表示成功
^_^ no news is a good news!!
在客户端,设置环境变量如下:
export CVS_RSH=ssh
export CVSROOT=:pserver:username@ip:/home/cvsroot 你可以
echo $CVS_RSH
ssh echo $CVSROOT :pserver:username@ip:/home/cvsroot 这样你在客户端就可以直接输入 cvs login登陆了
其它操作都可以直接cvs command 了
|
|