Centos7配置SVN服务端

时间:2022-02-10 23:59:39

环境

Centos 7

SVN 1.7

安装SVN

Shell> yum install svn -y

准备配置和仓库

Shell> mkdir -p /mydata/repo
Shell> cd /mydata/repo/
Shell> svnadmin create erp  #创建一个代码库,这里以erp为例

代码库的配置文件位于/mydata/repo/erp/conf/,共三个,下面依次进行修改。

修改总配置文件 svnserve.conf

[general]
anon-access = none      #禁止匿名访问
auth-access = write      #登录用户可以有写权限
password-db = passwd     #用户名密码的配置文件
authz-db = authz       #用户权限的配置文件
realm = My SVN Repository  #仓库的说明文本

修改用户及其密码的配置文件 passwd

[users]
user1 = 111
user2 = 222
user3 = 333

修改权限的配置文件 authz

[groups]  #用户组,建议所有用户都配置到组以方便权限管理,单个用户是可以存在于多个组的
admin = user1     #管理员
common = user2,user3 #普通用户
[/]    #根目录,此处的配置也是该库的默认权限
@admin = rw  #管理员默认有全部的读写权限
* =       #其他默认没有任何权限 [/trunk]  #主干,此处未指定的管理员则会继承根目录的读写权限,下同
@common = rw  #普通用户有读写权限
[/branches]  #分支
@common = rw  #普通用户有读写权限 [/tags]  #标记
@common = r  #普通用户只有读权限

注:这三个配置文件修改后不需要重启即可生效。

配置svnserve服务

修改配置文件 /etc/sysconfig/svnserve,通过 -r 指定根目录

OPTIONS="-r /mydata/repo/erp"

默认端口是3690,若需要修改可以在OPTIONS中加上 --listen-port [port]

默认不打印日志,所需要在在OPTIONS中加上 --log-file [file]

启动并配置开机自启

Shell> systemctl start svnserve
Shell> systemctl enable svnserve

测试使用

第一次输入用户名密码后会提示保存,以后就不需要再输入了

若不想保存更不想总提示保存,那就每个svn命令都加上这三个参数:--username user1 --password 111 --no-auth-cache

Shell> svn mkdir svn://localhost/{trunk,branches,tags} -m '创建基本目录'
Shell> svn co svn://localhost/trunk
Shell> cd trunk/
Shell> touch 1.txt
Shell> svn add *
Shell> svn ci -m '添加文件1.txt'
Shell> svn up
Shell> svn log
------------------------------------------------------------------------
r2 | user1 | 2020-01-10 12:14:32 +0800 (五, 2020-01-10) | 1 行 添加文件1.txt
------------------------------------------------------------------------
r1 | user1 | 2020-01-10 12:10:23 +0800 (五, 2020-01-10) | 1 行 创建基本目录
------------------------------------------------------------------------

多库模式

上文中,库的根目录直接指向了erp,表示这是单库模式,该svn服务只有一个项目库,若在/mydata/repo下还有其他项目,比如oa、crm等

那么需要将根目录指向上级目录,修改 /etc/sysconfig/svnserve

OPTIONS="-r /mydata/repo"

那么在访问时需要加上项目名,比如:

Shell> svn ls svn://localhost/erp

另外,要注意每个项目使用的是它目录下conf中的配置文件,需要分开单独维护。

不过,可以通过参数--config-file指定共用的配置,比如将erp的配置复制到/etc/svnserve/conf作为共用,需要修改 /etc/sysconfig/svnserve

OPTIONS="-r /mydata/repo --config-file /etc/svnserve/conf/svnserve.conf"

然后,需要修改 /etc/svnserve/conf/authz 增加项目名:

[erp:/]
@admin = rw
* = [ao:/]
@admin = rw
* =
[erp:/trunk]
@common = rw ...略...

注:使用了--config-file参数,在修改了配置文件后,必须重启svnserve服务才能生效;而且,通常多项目时权限情况较复杂,还是建议每个项目用自己单独的配置比较合适。

单库多项

规模不大且权限分配不复杂的情况当然也是存在的,这种可以考虑用单库模式(库名可以用公司名),然后库内通过文件夹区分项目即可:

repo/
└── mycompany
    ├── crm
    │   ├── branches
    │   ├── tags
    │   └── trunk
    ├── erp
    │   ├── branches
    │   ├── tags
    │   └── trunk
    └── oa
        ├── branches
        ├── tags
        └── trunk

over