最近安装SVN过程中遇到了很多坑,做一下记录。
阿里云服务器安装svn过程
手动安装SVN
本文以CentOS 7.2 64位系统为例,说明如何在CentOS 7.2上安装SVN。
1.远程连接Linux实例。
2. 运行以下命令安装SVN。
yum install subversion
3.运行以下命令查看SVN版本。
svnserve --version
4.按以下步骤创建版本库:
i.运行以下命令创建目录。
mkdir /var/svn
ii.依次运行以下命令创建版本库。
cd /var/svn svnadmin create /var/svn/svnrepos
iii.依次运行以下命令查看自动生成的版本库文件。
cd svnrepos ls
//
iv.运行命令cd conf/进入conf目录(该SVN版本库配置文件)。返回结果如下:
- authz:是权限控制文件。
- passwd:是账号密码文件。
- svnserve.conf:SVN服务配置文件。
v.按以下步骤设置账号密码:
a.运行 vi passwd。
b.按 i 键进入编辑模式。
c.在 [users] 块中添加用户账号和密码,格式:账号=密码,比如示例中的suzhan = redhat(注意等号两端要有一个空格)。
d.按 Esc 键退出编辑模式,并输入 :wq 保存并退出。
vi.按以下步骤设置权限:
a.运行 vi authz
。
b.按 i
键进入编辑模式。
c.在末尾添加如下代码(其中,r表示读,w表示写):
[/] suzhan=rw
d.按 Esc
键退出编辑模式,并输入 :wq
保存并退出。
vii.按以下步骤修改svnserve.conf文件。
a.运行命令 vi svnserve.conf
。
b.按 i
键进入编辑模式。
c.打开以下几个注释(注意每行不能以空格开始,等号两端要有一个空格):
anon-access = read #匿名用户可读,您也可以设置 anon-access = none,不允许匿名用户访问。设置为 none,可以使日志日期正常显示 auth-access = write #授权用户可写 password-db = passwd #使用哪个文件作为账号文件 authz-db = authz #使用哪个文件作为权限文件 realm = /var/svn/svnrepos #认证空间名,版本库所在目录
d.按 Esc
键退出编辑模式,并输入 :wq
保存并退出。
viii.运行以下命令启动SVN版本库。
svnserve -d -r /var/svn/svnrepos
ix.运行命令 ps -ef |grep svn
查看SVN服务是否开启。
如果返回结果如下图所示,表示SVN服务已经开启。
注意:运行以下命令停止SVN命令。
killall svnserve
以上内容来自点击打开链接
其实这样安装是没有问题的,然后你在svn的客户端输入svn://实例公网IP地址/资源库名 注:是svn:// 而不是http:// 因为没有配置是Apache服务访问所以写成http://是访问不到的。
然后又把svn删掉,重新安装
需要Apache的服务访问,首先需要安装httpd的服务
yum-y install httpd
一般情况下,linux服务器是有httpd服务的,你可以检查下,如果没有则安装。
检查方法:vi/etc/httpd/conf.d/subversion.conf
安装完svn后看是否有该目录&文件,如果存在则不需要安装httpd了。
安装httpd的时候就开始报错了
因为服务器一开始有这个服务,可能是版本问题然后一直报错,这个时候,你要卸载掉Apache的服务
yum remove httpd
然后再卸载掉 yum remove apr
重新安装httpd yum-y install httpd
查看是否安装成功 httpd -version
安装svn yum install subversion
查看是否安装成功 svn --version
安装mod_dav_svn yum install mod_dav_svn
安装成功后,会有mod_dav_svn.so和mod_authz_svn.so两个文件。
$ find / -name mod_dav_svn.so
/usr/lib64/httpd/modules/mod_dav_svn.so
$ find / -name mod_authz_svn.so
/usr/lib64/httpd/modules/mod_authz_svn.so
创建svn仓库
$ mkdir /var/www/svn
$ svnadmin create /var/www/svn/test
配置权限
修改svn仓库的用户组为apache:
$ chown -R apache:apache /var/www/svn/test/
创建用户文件passwd:
$ touch /var/www/svn/passwd #创建用户文件
$ htpasswd /var/www/svn/passwd admin #创建用户admin
根据提示输入密码,输入两次密码,密码是经过MD加密的
在这可以看到用户加密后的密码
$ vim /var/www/svn/passwd
admin:$apr1$UCkPzZ2x$tnDk2rgZoiaURPzO2e57t0
创建权限文件authz:
$ cp /var/www/svn/test/conf/authz /var/www/svn/authz
$ vim /var/www/svn/authz
[/]
admin = rw #rw读写权限 r 只有读的权限,w是写的权限,不写,是没有权限
5. 配置httpd
$ touch /etc/httpd/conf.d/subversion.conf
$ vim/etc/httpd/conf.d/subversion.conf
<Location /svn>
DAV svn
SVNParentPath /var/www/svn
AuthType Basic
AuthName "Authorization SVN"
AuthzSVNAccessFile /var/www/svn/authz
AuthUserFile /var/www/svn/passwd
Require valid-user
</Location>
6. 启动httpd服务
service httpd start
客户端使用http://192.168.220.121:8082/svn/test就可以访问刚才建立的svn仓库了。8082是自己配置的端口,默认是80端口,找到httpd.conf 修改里面的listener 80 的端口即可。
修改端口后的端口要对防火墙开启,不然访问不到。
vim /etc/sysconfig/iptables 添加下面这句
-A INPUT -p tcp -m tcp --dport 8082 -j ACCEPT
再重启防火墙服务:service iptables restart
安装参考点击打开链接