终于实现linux下的cvs了

重装了一次系统,重装了N次的cvs,终于让linux下的cvs理论上可以进行开发。

还要感谢超少在忙VB时热心的做测试……

虽然现在是凌晨3点整,还是得总结一下:

1、咱先把CVS装上吧

首先确定系统中没有安装CVS,如果没有则安装:
yum install cvs   注:fedora中可以使用光盘安装,个人认为容易点哦

2、确认系统中是否安装xinetd,在Fedora 6中这个没有默认安装。如果没有安装则安装:
yum install xinetd    注:这个我是用命令行在网上自动下载安装的,中间还出现了个错误,忽略了

3、修改/etc/xinetd.d/cvs

[root@fc6 CVSROOT]# cat /etc/xinetd.d/cvs
# default: off
# description: The CVS service can record the history of your source \
#              files. CVS stores all the versions of a file in a single \
#              file in a clever way that only stores the differences \
#              between versions.
service cvspserver
{
        disable                 = no
        port                    = 2401
        socket_type             = stream
        protocol                = tcp
        wait                    = no
        user                    = root
        passenv                 = PATH
        server                  = /usr/bin/cvs
#       env                     = HOME=/zyf/cvs
        server_args             = -f --allow-root=/zyf/cvs pserver
#       bind                    = 127.0.0.1
}

4、初始化cvs服务
cvs -d /zyf/cvs init
注:这个路径要和/etc/xinetd.d/cvs中的一致,并且可以随便根据自己的需要定制.

5、增加用户
groupadd cvs
useradd cvsroot -g cvs

6、设置目录权限
chmod 777 /zyf/cvs

7、修改/zyf/cvs/CVSROOT/config文件
[root@fc6 CVSROOT]# cat config
# Set this to "no" if pserver shouldn't check system users/passwords
SystemAuth=no  注:这里默认是注释掉的。

# Put CVS lock files in this directory rather than directly in the repository.
#LockDir=/var/lock/cvs

# Set `TopLevelAdmin' to `yes' to create a CVS directory at the top
# level of the new working directory when using the `cvs checkout'
# command.
#TopLevelAdmin=no

# Set `LogHistory' to `all' or `TOEFWUPCGMAR' to log all transactions to the
# history file, or a subset as needed (ie `TMAR' logs all write operations)
#LogHistory=TOEFWUPCGMAR

# Set `RereadLogAfterVerify' to `always' (the default) to allow the verifymsg
# script to change the log message.  Set it to `stat' to force CVS to verify
# that the file has changed before reading it (this can take up to an extra
# second per directory being committed, so it is not recommended for large
# repositories.  Set it to `never' (the previous CVS behavior) to prevent
# verifymsg scripts from changing the log message.
#RereadLogAfterVerify=always

注:这个更改是为了用户验证的时候忽略系统用户,这样可以避免建立很多的系统帐户,而影响安全性。

8、增加/zyf/cvs/CVSROOT/passwd文件
[root@fc6 CVSROOT]# cat passwd
zyf:woXRXXMqwnmWs:cvsroot
注:这个密码文件中第2段是md5的密码。多个用户为每行一个.  这个密码真的不太好得到,每次都是建用户。

9、增加/zyf/cvs/CVSROOT/readers文件
这个文件中存储着所有只读用户的用户名,一行一个.

10、增加/zyf/cvs/CVSROOT/writers文件
这个文件中存储着所有可写权限的用户名,一行一个.
注:同一个用户不要在/zyf/cvs/CVSROOT/readers和/shanmin/cvs/CVSROOT/writers中都填写,如果都填写则以/zyf/cvs/CVSROOT/readers中的为准。

11、关闭SELinux
[root@~]#setenforce 0
注:CVS和SELinux有“冲突”,必须关闭,不然客户端会提示没有权限。

12、启动服务
service xinetd start

13、防火墙开2401端口   注:我是把防火墙关了。

还要注意:writers一定要设置好权限,为了这个颇费了一阵子劲儿。