cvs 在redhat as 4上的安装配置

安装cvs后服务器和客户端就都安装了,主要是需要配置服务器端:
1.查看是否安装cvs
rpm -qa|grep cvs
一般安装在/usr/bin/cvs,如果未安装,http://www.cvshome.org/下载一个最新的rpm安装即可

2.建立cvs用户组,便于管理cvs用户 (一个用户组,可以是其他名称,例如spcoder)
groupadd cvs

3.建立cvs组的cvsroot用户和所属的目录 (可以是spcoder组的一个sp用户)
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 ###此文件是一个安装完成的文件,此时需要我们创建一个空的passwd文件
文件内容如下:
weiqiong:xxxxx:cvsroot
myang:xxxxx:cvsroot
此文件的意思是weiqiong和chenxu两个用户可以登陆cvs服务器,登陆后其权限为用户cvsroot的权限
注意:cvs用户和服务器用户是可以不一样的

但是
至于CVS系统的安全,我只知道可以不使用 real user 登陆:
chmod 644 $CVSROOT/CVSROOT/config
vi $CVSROOT/CVSROOT/config
将第二行的
#SystemAuth = no
去掉注释,即改为
SystemAuth = no


8.xxxxx为MD5加密后的密码,由以下文件生成: (增加一个cvsroot权限的用户myang)
htpasswd –c /home/cvs/CVSROOT/passwd myang

因为htpasswd命令是使用的apache的所以我们需要安装apache

9.打开passwd

发现其内容是myang:c/BzZQ44Ce5XE

我们加上myang:c/BzZQ44Ce5XE:cvsgroup

这样:

用户:myang

密码:解密c/BzZQ44Ce5XE(不用理它)

用户所属用户角色:cvsroot

10.加入cvs服务(我的redhat as 4缺省就有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

  我的redhat as 4使用的是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

14.试用:
  cvs -d :pserver:weiqiong@192.168.1.111:/home/cvsroot login
  敲入命令回车后提示输入weiqiong的密码,你按照自己设置的密码输入,如果没有什么错误信息出现就是成功了(我的机器IP地址是192.168.1.111,也可以用localhost)