我有一台运行Ubuntu的笔记本电脑,希望用作Subversion服务器。 无论是我自己致力于在本地,还是远程地致力于其他人。 要执行此工作需要采取什么步骤? 请包括以下步骤:
-
获取并配置Apache和必要的模块(我知道还有其他方法可以创建SVN服务器,但是我希望它特定于Apache)
-
配置访问服务器的安全方式(SSH / HTTPS)
-
配置一组授权用户(例如,他们必须有权提交,但可以自由浏览)
-
通过初始提交(某种" Hello world")验证设置
这些步骤可能涉及命令行或GUI应用程序指令的任何混合。 如果可以的话,请注意特定于特定发行版或版本的说明,以及可以使用用户对特定工具的选择代替(例如,用nano代替vi)。
我已采取步骤使笔记本电脑成为Subversion服务器。必须在此向AlephZarro寻求指导。我现在有一个正常工作的SVN服务器(目前仅在本地进行了测试)。
具体设置:
库本图8.04哈代鹭
遵循本指南的要求:
-
apt-get软件包管理器程序
-
文字编辑器(我使用kate)
-
sudo访问权限
1:安装Apache HTTP服务器和必需的模块:
1
| sudo apt-get install libapache2-svn apache2 |
将安装以下额外的软件包:
1
| apache2-mpm-worker apache2-utils apache2.2-common |
2:启用SSL
1 2
| sudo a2enmod ssl
sudo kate /etc/apache2/ports.conf |
添加或检查文件中是否包含以下内容:
1 2 3
| <IfModule mod_ssl.c>
Listen 443
</IfModule> |
3:生成SSL证书:
1 2 3
| 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:创建虚拟主机
1 2
| sudo cp /etc/apache2/sites-available/default /etc/apache2/sites-available/svnserver
sudo kate /etc/apache2/sites-available/svnserver |
更改(在ports.conf中):
1
| "NameVirtualHost *" to"NameVirtualHost *:443" |
和(在svnserver中)
1
| <VirtualHost *> to <VirtualHost *:443> |
在ServerAdmin下添加(同样在文件svnserver中):
1 2 3 4
| SSLEngine on
SSLCertificateFile /etc/apache2/ssl/apache.pem
SSLProtocol all
SSLCipherSuite HIGH:MEDIUM |
5:启用站点:
1 2
| sudo a2ensite svnserver
sudo /etc/init.d/apache2 restart |
要克服警告:
1
| sudo kate /etc/apache2/apache2.conf |
加:
1
| "ServerName $your_server_name" |
6:添加存储库:
以下设置假定我们要托管多个存储库。
运行此命令以创建第一个存储库:
1 2 3 4 5 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:添加经过身份验证的用户
1
| sudo htpasswd -c -m /etc/apache2/dav_svn.passwd $user_name |
8:启用和配置WebDAV和SVN:
1
| sudo kate /etc/apache2/mods-available/dav_svn.conf |
添加或取消注释:
1 2 3 4 5 6 7 8 9 10 11 12
| <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服务器:
1
| sudo /etc/init.d/apache2 restart |
10:验证:
启动浏览器:
1 2
| http://localhost/svn/$REPOS
https://localhost/svn/$REPOS |
两者都需要用户名和密码。我认为不加评论:
1 2 3
| <LimitExcept GET PROPFIND OPTIONS REPORT>
</LimitExcept> |
在/etc/apache2/mods-available/dav_svn.conf中,将允许匿名浏览。
浏览器显示"修订版0:/"
提交一些内容:
1
| svn import --username $user_name anyfile.txt https://localhost/svn/$REPOS/anyfile.txt -m"Testing" |
接受证书并输入密码。
查看您刚刚提交的内容:
1
| 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错误
(尽管这些承诺在服务器端有效,但我需要跟进本地更新)
如果您在访问网络服务器时被禁止访问403,则可能是因为您使用的主机名不是您在配置文件中指定的主机名(即localhost或127.0.0.1)。尝试改为点击https:// whateveryousetasyourhostname ...
本文似乎为整个过程提供了很好的总结。我建议您按照说明进行操作,然后针对您遇到的任何问题发布一些更具体的问题,这些问题在我和其他人在这些答复中未涉及的文章中都没有解决。
请在终端上编写一个命令。
要打开终端,请按Ctrl + Alt + T,然后键入以下命令:
1
| $sudo apt-get install subversion |
对于Apache:
1
| sudo apt-get -yq install apache2 |
对于SSH:
1
| sudo apt-get -yq install openssh-server |
对于Subversion:
1
| sudo apt-get -yq install subversion subversion-tools |
如果您愿意,可以将它们合并为一个命令,例如:
1
| sudo apt-get -yq install apache2 openssh-server subversion subversion-tools |
我无能为力...