由于iF.SVNAdmin使用php写的,因此我们需要安装php
yum install httpd php
subversion即SVN,mod_dav_svn是Apache服务器访问SVN的一个模块
yum install subversion mod_dav_svn
httpd -version
svnserve --version
ls /etc/httpd/modules/ | grep svn
vim /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 /svn>
DAV svn
#svn的根目录
SVNParentPath /var/www/svn
#SSL访问权限
#SSLRequireSSL
#Basic认证方式
AuthType Basic
#认证时显示的信息
AuthName "Authorization SVN"
#用户文件&密码
AuthUserFile /var/www/svnconfig/passwd
#访问权限控制文件
AuthzSVNAccessFile /var/www/svnconfig/authz
#要求真实用户,不能匿名
Require valid-user
</Location>
保存退出!
mkdir /var/www/svn
mkdir /var/www/svnconfig
touch /var/www/svnconfig/authz
touch /var/www/svnconfig/passwd
(http://sourceforge.net/projects/ifsvnadmin/files/svnadmin-1.6.2.zip/download)
wget https://jaist.dl.sourceforge.net/project/ifsvnadmin/svnadmin-1.6.2.zip
unzip svnadmin-1.6.2.zip
cp -r iF.SVNAdmin-stable-1.6.2/ /var/www/html/svnadmin
chmod -R 777 /var/www/html/svnadmin/data/
chown -R apache:apache /var/www/html/svnadmin/
chmod -R 777 /var/www/svn
chmod 777 /var/www/svnconfig/authz
chmod 777 /var/www/svnconfig/passwd
systemctl start http
(注意:Apache的端口默认是80端口)
加入开机自启动
systemctl enable httpd
如果开启了防火墙, 需要开启httpd访问权限
firewall-cmd --permanent --add-service=http
firewall-cmd --zone=public --add-port=80/tcp --permanent
firewall-cmd --reload
通过查看文件/usr/lib/systemd/system/svnserve.service,了解到svnserve的配置文件是/etc/sysconfig/svnserve
修改/etc/sysconfig/svnserve
vim /etc/sysconfig/svnserve
OPTIONS="-r /var/svn"
修改成:
OPTIONS="-r /var/www/svn"
启动后浏览器输入http://服务器地址:端口(http://192.168.77.134:90)/svnadmin/ 后登录,登录后如下图,输入各个配置文件的路径后点击Test进行测试是否成功,全部成功后保存配置,单击Save configuration按钮
保存后,会在 /var/www/svnconfig/passwd 文件中自动生成默认用户名和密码,都是admin
再次访问:http://192.168.77.134/svnadmin,输入刚生成的用户名和密码,就可以访问啦~
TortoiseSVN客户端官网下载即可:
https://tortoisesvn.net/downloads.html
安装之后,本地磁盘右键检出即可
这里注意一下,检出地址为:http://192.168.77.134/svn/test
即 http://[服务器IP]:[apache端口]/svn/[仓库名]
之所以强调这个检出地址,是因为如果不用SVNAdmin,命令方式使用SVN的话,这个检出地址应该是svn://192.168.77.134/test
即 svn://[服务器IP]:[apache端口]/[仓库名]
如果提交文件没有弹出登录框,需要配置下svnserve.conf文件
切换到仓库配置文件所在目录:
cd /var/www/svn/test/conf
打开svnserve.conf
vim svnserve.conf
增加以下配置
anon-access = none
auth-access = write
password-db = passwd
authz-db = authz
realm = /var/www/svn
注意在[geberal]下面加,效果如下
再测试检出提交查看日志功能,一切正常。
至此,检出提交都可以了,大功告成!