ubuntu 搭建 svn服务器,使用http方式访问

Ubuntu版本:16.04 LTS

1、安装apache2和svn server

# sudo apt-get install apache2
# sudo apt-get install subversion
# sudo apt-get install libapache2-svn

如安装有问题请换个源试下

完成以上安装后,可以直接访问apache的主页:http://localhost

2、创建svn版本库

# sudo mkdir /home/svn
# sudo svnadmin create /home/svn/repos

这时候就可以在/home/svn/repos目录下看到svn版本库的所有文件夹以及配置文件,如:conf、db、format、hooks、locks、README.txt

3、配置svn

编辑authz 、passwd

authz是配置权限的,passwd是保存用户名密码,为了管理方便,把这两个文件放到/home/svn下进行统一的管理。
编辑passwd文件:

[users]
admin = admin
编辑authz文件:

[groups]         
admin_group = admin

[/]
@admin_group = rw

然后编辑repos下的svnserve.conf文件

sudo gedit /home/svn/repos/svnserve.conf
匿名用户不可读
anon-access = none

权限用户可写
auth-access = write

密码文件为passwd
password-db = ../../passwd

权限文件为authz
authz-db = ../../authz
  
这里引用的是相对路径,不是绝对路径。

4、启动SVN服务

# sudo svnserve -d -r /home/svn
描述说明:
-d 表示svnserver以“守护”进程模式运行
-r 指定文件系统的根位置(版本库的根目录),这样客户端不用输入全路径,就可以访问版本库
如:svn://localhost/repos
这时SVN安装就完成了。

5、接下来是将svn配置到apache中通过http web方式访问

配置内容如下所示:

<Location /svn>
DAV svn
SVNParentPath /home/svn
SVNAdvertiseV2Protocol Off
AuthType Basic
AuthName "Subversion Repository"
AuthUserFile /home/svn/passwdfile
AuthzSVNAccessFile /home/svn/authz
Require valid-user
</Location>
 SVNPath是项目库地址,如果只有一个项目库,则直接可以用SVNPath。为了长久的考虑,决定使用SVNParentPath,让新建的项目库放在/home/svn/下。AuthUserFile是存放用户文件。AuthzSVNAccessFile是用户/组权限文件。Require valid-user是登录svn要做验证。备注:此配置文件是告诉apache关于svn的访问路径已经相关配置文件,这里注意存放的根目录。

 

7、往pwdfile里添加用户名密码  

# sudo htpasswd -c /home/svn/passwdfile admin

如果再往文件追加用户密码只需要将htpasswd 后的-c去掉就可再文件后继续追加了

追后记的编辑authz,passwd文件将新的用户追加进去

编辑authz

[groups]         
admin_group = admin,xxx

[/]
@admin_group = rw

编辑passwd

[users]
admin = admin

xxx=xxx

重启apache服务器,sudo /etc/init.d/apache2 restart,然后就可以通过http://localhost/svn/repos进行远程访问。

 

安装过程中可能遇到的问题总结

1、遇到Invalid command 'DAV', perhaps misspelled or defined by a module not include

找到mod_dav.so添加到apache2默认的配置文件中,如果配置文件中有只需要将注释去掉就可以,如果没有请按下面操作进行

sudo find / -name "mod_dav.so"

sudo vi /etc/apache2/apache2

LoadModule dav_module mod_dav.so相对路径/mod_dav.so

2、Invalid command 'ProxyPass', perhaps misspelled or defined by a module not inclu ded in ...

 

解决的方法就在默认配置文件里,找到以下两条:

 

#LoadModule proxy_module modules/mod_proxy.so

 

#LoadModule proxy_http_module modules/mod_proxy_http.so

将注释去掉就可以了,如果没有使用find命令找到对应的添加到apache2配置文件中

 

 

转载于:https://www.cnblogs.com/xxd-qyr/p/11064458.html

### 解决Ubuntu系统中搭建SVN服务器时遇到的错误 在Ubuntu系统上搭建SVN服务器过程中可能会遇到多种类型的错误。为了有效解决问题,先了解常见的错误及其解决方案。 #### 1. HTTP模块未启用 如果Apache2服务未能正常加载`mod_dav_svn`模块,则可能导致SVN通过HTTP(S)协议访问失败。确保已执行如下命令来激活所需模块并重启Web服务器: ```bash sudo a2enmod dav_fs sudo a2enmod dav_svn sudo systemctl restart apache2 ``` 上述指令会开启Distributed Authoring and Versioning (DAV)功能以及针对Subversion的支持[^1]。 #### 2. 权限配置不当 权限设置不正确也是常见原因之一。对于新创建的SVN库目录(如`/var/lib/svn/devops`),应赋予适当读写权限给Apache用户组(`www-data`)而非`apache`: ```bash chown -R www-data:www-data /var/lib/svn/ chmod -R g+rws /var/lib/svn/ ``` 这一步骤可防止因权限不足而导致的操作受阻情况发生。 #### 3. SELinux策略冲突 虽然SELinux通常只影响基于Red Hat系列发行版(比如CentOS),但在某些特殊情况下也可能干扰到Ubuntu上的SVN部署。若怀疑存在此类问题,可以通过临时禁用SELinux来进行排查——但这不是推荐的做法;更优的选择是调整具体的SELinux安全上下文标签以兼容SVN操作。 #### 4. 配置文件语法有误 检查位于`/etc/apache2/dav_svn.conf`中的SVN配置项是否存在拼写或其他形式上的失误。任何不符合预期的内容都可能引发解析异常或行为偏离标准。建议仔细核对该文件内的路径定义和其他参数设定是否准确无误。 #### 5. 日志分析 最后但同样重要的是查看Apache的日志记录,特别是error.log部分,它能提供关于具体发生了什么问题的重要线索。日志位置一般为`/var/log/apache2/error.log`。通过阅读这些信息往往能够快速定位故障根源所在。 ```bash tail -f /var/log/apache2/error.log ``` 以上措施有助于诊断和修复大多数与Ubuntu环境下SVN服务器构建有关的技术难题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值