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.我的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.重新启动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
输入密码后,没有收到任何消息,即表示成功
在客户端,设置环境变量如下:
#export CVS_RSH=ssh
#export CVSROOT=:pserver:username@ip:/home/cvsroot
这样你在客户端就可以直接输入 cvs login登陆了
其它操作都可以直接cvs command 了