CentOS下SVN使用
1. 介绍
这里想在CentOS上搭建的是基于http访问的SVN Server
2. 软件
安装相关软件
yum install httpd httpd-devel mod_dav_svn subversion mod_ssl
其中, mod_dav_svn是apache服务器访问svn的一个模块
安装完成后可以通过如下命令查看是否安装成功
httpd -version
svnserve –version
ls /etc/httpd/modules/ | grep svn
-----> mod_authz_svn.so mod_dav_svn.so
3. 建立仓库
通过如下命令建立svn仓库
其中/var/www/svn是准备放仓库的目录,这个目录可以放置多个代码仓库
AuthUserFile就是用户和密码的文件,也可以移动到其他地方单独管理.
mkdir /var/www/svn
svnadmin create /var/www/svn/workspace
ls /var/www/svn/workspace
---> conf db format hooks locks README.txt
chown -R apache.apache /var/www/svn
4. SVN配置
创建用户文件passwd, 并建立用户admin和guest
touch /var/www/svn/passwd
htpasswd /var/www/svn/passwd admin
htpasswd /var/www/svn/passwd guest
创建权限文件authz
cp /var/www/svn/workspace/conf/authz /var/www/svn/authz
修改/var/www/svn/authz, 使其包含如下内容
[/]
admin = rw
guest = r
5. httpd配置
创建文件/etc/httpd/conf.d/subversion.conf, 内容如下
LoadModule dav_svn_module modules/mod_dav_svn.so
LoadModule authz_svn_module modules/mod_authz_svn.so
<Location />
DAV svn
SVNPath /var/www/svn/workspace
SVNListParentPath on
AuthType Basic
AuthName "Authorization SVN"
AuthUserFile /var/www/svn/passwd
AuthzSVNAccessFile /var/www/svn/authz
Require valid-user
</Location>
6. 启动服务
如果开启了防火墙, 需要开启httpd访问权限
firewall-cmd --permanent --add-service=http
firewall-cmd --permanent --add-service=https
firewall-cmd --reload
通过查看文件/usr/lib/systemd/system/svnserve.service, 了解到svnserver的配置文件是/etc/sysconfig/svnserve
修改/etc/sysconfig/svnserve
OPTIONS="-r /var/svn" ======> OPTIONS="-r /var/www/svn"
通过如下命令来启用服务
systemctl start svnserve.service
systemctl start httpd.service
如下命令使其开机自启动
systemctl enable svnserve.service
systemctl enable httpd.service
完成后可以通过如下地址来访问SVN服务器
参考:
<CentOS7:搭建SVN + Apache 服务器>
<Install SVN Server on Fedora 23/22, CentOS/RHEL 7.2/6.7/5.11>