环境
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