如何在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
我不能帮助其余的…