如何在GNU / Linux上设置Subversion(SVN)服务器 – Ubuntu

我有一台运行Ubuntu的笔记本电脑,我想作为一个Subversion服务器。 既为自己承诺本地,也为其他人承诺。 需要什么步骤来实现这个工作? 请包括以下步骤:

  • 获取和configurationApache以及必要的模块(我知道还有其他方法可以创build一个SVN服务器,但是我希望Apache可以使用它)
  • configuration访问服务器的安全方式(SSH / HTTPS)
  • configuration一组授权用户(如在,他们必须授权提交,但可以自由浏览)
  • 使用初始提交validation设置(“Hello World”)

这些步骤可能涉及命令行或GUI应用程序指令的任意混合。 如果可以的话,请注意哪些指令是针对特定分发版本或版本的,以及用户可以select使用特定工具(例如nano而不是vi )。

我已经采取了使我的笔记本电脑成为Subversion服务器的步骤。 信用必须去AlephZarro 在这里指示他的方向。 我现在有一个工作的SVN服务器(目前只在本地进行过testing)。

具体设置:Kubuntu 8.04哈代苍鹭

遵循本指南的要求:

  • apt-get包pipe理器程序
  • 文本编辑器(我使用凯特)
  • sudo访问权限

1:安装Apache HTTP服务器和所需的模块:

sudo apt-get install libapache2-svn apache2 

以下额外的软件包将被安装:

 apache2-mpm-worker apache2-utils apache2.2-common 

2:启用SSL

 sudo a2enmod ssl sudo kate /etc/apache2/ports.conf 

添加或检查文件中是否包含以下内容:

 <IfModule mod_ssl.c> Listen 443 </IfModule> 

3:生成一个SSL证书:

 sudo apt-get install ssl-cert sudo mkdir /etc/apache2/ssl sudo /usr/sbin/make-ssl-cert /usr/share/ssl-cert/ssleay.cnf /etc/apache2/ssl/apache.pem 

4:创build虚拟主机

 sudo cp /etc/apache2/sites-available/default /etc/apache2/sites-available/svnserver sudo kate /etc/apache2/sites-available/svnserver 

更改(在ports.conf中):

 "NameVirtualHost *" to "NameVirtualHost *:443" 

和(在svnserver中)

 <VirtualHost *> to <VirtualHost *:443> 

在ServerAdmin下(也在svnserver文件中)添加:

 SSLEngine on SSLCertificateFile /etc/apache2/ssl/apache.pem SSLProtocol all SSLCipherSuite HIGH:MEDIUM 

5:启用网站:

 sudo a2ensite svnserver sudo /etc/init.d/apache2 restart 

为了克服警告:

 sudo kate /etc/apache2/apache2.conf 

加:

 "ServerName $your_server_name" 

6:添加仓库:以下设置假设我们要托pipe多个仓库。 运行这个来创build第一个仓库:

 sudo mkdir /var/svn REPOS=myFirstRepo sudo svnadmin create /var/svn/$REPOS sudo chown -R www-data:www-data /var/svn/$REPOS sudo chmod -R g+ws /var/svn/$REPOS 

6.A中 对于更多的存储库:再次执行步骤6(更改REPOS的值),跳过步骤mkdir /var/svn

7:添加一个经过身份validation的用户

 sudo htpasswd -c -m /etc/apache2/dav_svn.passwd $user_name 

8:启用并configurationWebDAV和SVN:

 sudo kate /etc/apache2/mods-available/dav_svn.conf 

添加或取消注释:

 <Location /svn> DAV svn # for multiple repositories - see comments in file SVNParentPath /var/svn AuthType Basic AuthName "Subversion Repository" AuthUserFile /etc/apache2/dav_svn.passwd Require valid-user SSLRequireSSL </Location> 

9:重启apache服务器:

 sudo /etc/init.d/apache2 restart 

10:validation:

烧毁浏览器:

 http://localhost/svn/$REPOS https://localhost/svn/$REPOS 

两者都需要用户名和密码。 我认为没有注释:

 <LimitExcept GET PROPFIND OPTIONS REPORT> </LimitExcept> 

/etc/apache2/mods-available/dav_svn.conf ,将允许匿名浏览。

浏览器显示“修订版0:/”

承诺:

 svn import --username $user_name anyfile.txt https://localhost/svn/$REPOS/anyfile.txt -m “Testing” 

接受证书并input密码。 看看你刚刚承诺:

 svn co --username $user_name https://localhost/svn/$REPOS 

遵循这些步骤(假设我没有做任何错误复制/粘贴),我的笔记本电脑上有一个可用的SVN存储库。

之后,我需要执行(在上面引用的例子中)

$ sudo chmod g + w /var/svn/$REPOS/db/rep-cache.db

$ sudo chown www-data:www-data /var/svn/$REPOS/db/rep-cache.db

否则,在进行本地修改时,我一直收到409错误(虽然承诺是服务器端有效,我需要跟进本地更新)

这篇文章似乎给了整个过程一个相当不错的概要。 我build议按照说明进行操作,然后发布一些更具体的问题,说明在这些答复中,我和其他人所链接的文章中没有涉及到的任何问题。

如果您在访问networking服务器时遇到403禁止,可能是因为您使用了不在您的configuration文件(即localhost或127.0.0.1)中指定的主机名。 尝试点击https:// whateveryousetasyourhostname而是…

请在terminal上写一个命令。

要打开terminal,请按Ctrl + Alt + T ,然后键入以下命令:

 $sudo apt-get install subversion 

对于Apache:

 sudo apt-get -yq install apache2 

对于SSH:

 sudo apt-get -yq install openssh-server 

对于Subversion:

 sudo apt-get -yq install subversion subversion-tools 

如果你愿意,你可以把它们合并成一个命令,例如:

 sudo apt-get -yq install apache2 openssh-server subversion subversion-tools 

我不能帮助其余的…