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

时间:2020-03-05 18:52:46  来源:igfitidea点击:

我有一台运行Ubuntu的笔记本电脑,我想充当Subversion服务器。无论是我自己致力于在本地,还是远程地致力于其他人。要使此工作正常,需要执行哪些步骤?请包括以下步骤:

  • 获取并配置Apache和必要的模块(我知道还有其他方法可以创建SVN服务器,但是我希望它特定于Apache)
  • 配置访问服务器的安全方式(SSH / HTTPS)
  • 配置一组授权用户(例如,他们必须有权提交,但可以自由浏览)
  • 通过初始提交(某种" Hello world")验证设置

这些步骤可能涉及命令行或者GUI应用程序指令的任何混合。如果可以的话,请注意特定于特定发行版或者版本的说明,以及可以使用用户对特定工具的选择代替(例如,用nano代替vi)。

解决方案

回答

对于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

我无能为力...

回答

本文似乎为整个过程提供了很好的总结。我建议我们按照说明进行操作,然后针对我们遇到的任何问题发布一些更具体的问题,这些问题在我和其他人在这些答复中未涉及的文章中都没有解决。

回答

我已采取步骤使笔记本电脑成为Subversion服务器。必须在此向AlephZarro寻求指导。我现在有一个正常工作的SVN服务器(目前仅在本地进行了测试)。

具体设置:
库本图8.04哈代鹭

遵循本指南的要求:

  • apt-get软件包管理器程序
  • 文字编辑器(我使用kate)
  • 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:创建虚拟主机

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:添加存储库:
以下设置假定我们要托管多个存储库。
运行此命令以创建第一个存储库:

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:添加经过身份验证的用户

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

8:启用和配置WebDAV和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:验证:

启动浏览器:

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”

接受证书并输入密码。
查看我们刚刚提交的内容:

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

按照这些步骤(假设我没有进行任何错误的复制/粘贴),我的笔记本电脑上有可以使用的SVN存储库。

回答

如果我们在访问网络服务器时被禁止访问403,则可能是因为我们使用的主机名不是我们在配置文件中指定的主机名(即localhost或者127.0.0.1)。尝试改为点击https:// whateveryousetasyourhostname ...