Subversion(SVN)是一个开源的集中式版本控制系统,广泛应用于软件开发、文档管理等场景,用于有效管理文件和目录的变更历史,在Linux系统上部署SVN服务是许多开发团队的标准实践,本文将详细介绍如何在Linux环境下完成SVN服务端的安装、配置以及基本的使用,帮助您快速搭建一个稳定可靠的版本控制环境。
SVN服务端安装
SVN的安装过程在主流的Linux发行版上都非常简便,系统的软件包管理器已经收录了SVN的相关软件。
对于基于Debian或Ubuntu的系统,可以使用命令进行安装:
sudo apt-get upDatesudo apt-get Install subversion
对于基于CentOS或Red Hat Enterprise Linux(RHEL)的系统,则使用或命令:
sudo yum install subversion
安装完成后,可以通过以下命令验证SVN是否已成功安装并查看其版本信息:
svnserve --version
如果能够正常显示版本号,则说明安装已经成功。
创建与配置SVN仓库
安装好SVN软件后,下一步是创建一个版本库(Repository),并对其进行相应的权限配置。
创建版本库
选择一个合适的目录作为所有SVN版本库的根目录,例如,在此目录下创建一个具体的版本库,例如。
# 创建SVN根目录sudo mkdir -p /data/svn# 创建名为myproject的版本库sudo svnadmin create /data/svn/myproject
执行
svnadmin create
命令后,
/data/svn/myproject
目录下会生成一系列文件和子目录,其中目录存放了该版本库的配置文件,是我们接下来需要重点关注的。
配置版本库权限
SVN的权限控制主要通过目录下的三个核心文件实现:
svnserve.conf
、和。
(1)编辑
svnserve.conf
这是SVN服务的主配置文件,使用文本编辑器打开它:
sudo vim /data/svn/myproject/conf/svnserve.conf
找到并修改以下几行,确保它们没有被注释(即行首没有),并设置相应的值:
[general]# 禁止匿名访问,None为无权限,read为只读,write为读写anon-access = none# 授权用户拥有写权限auth-access = write# 指定密码数据库文件名password-db = passwd# 指定权限控制文件名authz-db = authz# 指定认证命名空间,当一个svnserve进程管理多个版本库时,此配置非常重要realm = myproject
(2)编辑文件
此文件用于存储用户名和密码对,格式为
用户名 = 密码
。
sudo vim /data/svn/myproject/conf/passwd
在标签下添加用户,
[users]harry = harrys_secretsally = sallys_secret
(3)编辑文件 此文件用于实现更精细的路径级别权限控制,可以定义用户组,并为不同用户或组分配对不同目录的访问权限(读,写)。
sudo vim /data/svn/myproject/conf/authz
配置示例如下:
[groups]# 定义一个名为developers的用户组developers = harry, sally# 设置根目录的权限[myproject:/]# 用户组developers拥有读写权限@developers = rw# 其他用户无任何权限* =# 可以设置特定子目录的权限[myproject:/trunk/docs]# 用户sally拥有读写权限sally = rw# developers组的其他成员只有只读权限@developers = r
启动SVN服务
配置完成后,即可启动SVN服务,推荐使用来管理SVN服务,这样可以实现开机自启和方便的运维管理。
创建一个服务文件:
sudo vim /etc/systemd/system/svnserve.service
注意参数指定的路径是SVN版本库的根目录。
[Unit]Description=Subversion protocol daemonAfter=network.target[Service]Type=forkingUser=rootGroup=rootExecStart=/usr/bin/svnserve -d -r /data/svn --listen-port 3690ExecReload=/bin/kill -HUP $MAINPIDKillMode=processRestart=on-failureRestartSec=5[Install]WantedBy=multi-user.target
保存文件后,执行以下命令来启用并启动SVN服务:
sudo systemctl daemon-reloadsudo systemctl enable svnserve.servicesudo systemctl start svnserve.service
可以使用
sudo systemctl status svnserve.service
来检查服务是否正常运行。
客户端访问与测试
SVN服务启动后,您就可以在客户端上通过协议来访问版本库了。
在另一台机器上(或本机),使用命令检出代码:
svn co svn://<你的服务器IP地址>/myproject
系统会提示输入用户名和密码,即之前在文件中配置的或,认证成功后,当前目录下会生成一个名为的文件夹,其中包含了版本库的内容。
为了测试提交功能,可以进入该目录,创建一个新文件,然后将其添加到版本控制并提交:
cd myprojectecho "Hello, SVN!" > readme.txtsvn add readme.txtsvn commit -m "Add readme file"
如果一切顺利,文件将被成功提交到服务器端的版本库中。
相关问答 (FAQs)
问题1:如果我忘记了某个SVN用户的密码,或者需要修改密码,应该如何操作?
解答: SVN的用户密码是以明文形式存储在文件中的,要修改或重置密码,您只需要直接编辑该版本库目录下的文件,找到对应用户名那一行,将其等号后面的密码修改为您想要的新密码,然后保存文件即可。服务在每次用户认证时都会重新读取这个文件,因此修改后无需重启服务,新密码在下次登录时立即生效。
问题2:使用
svnserve://
协议和通过Apache () 提供SVN服务,两者有何主要区别?
解答: 这两种是SVN最常见的服务提供方式,各有优劣,适用于不同场景。
| 特性 |
svnserve://
协议
|
协议 |
|---|---|---|
| 安装复杂度 | 低,只需安装subversion包即可。 |
高,需额外安装Apache服务器及
mod_dav_svn
模块。
|
| 性能 | 较高,为SVN专用协议,开销小。 | 稍低,需要经过Apache处理,协议栈更复杂。 |
| 配置与防火墙 | 配置简单,通常只需开放一个端口(默认3690)。 | 配置复杂,但可利用HTTP/HTTPS的80/443端口,穿透防火墙更容易。 |
| 功能特性 | 功能基础,满足基本的版本控制需求。 | 功能丰富,支持通过Web浏览器浏览仓库、与WebDAV集成、更精细的路径权限控制等。 |
| 适用场景 | 内部网络、开发团队、对性能要求高且功能需求简单的场景。 | 需要向公网提供服务、需要与Web应用集成、或需要利用HTTPS进行安全传输的企业级应用。 |














发表评论