Как настроить сервер Subversion (SVN) в GNU/Linux - Ubuntu

У меня есть ноутбук с Ubuntu, который я хотел бы использовать в качестве сервера Subversion. Как для себя, чтобы совершить локально, так и для других удаленно. Какие шаги необходимы, чтобы это заработало? Пожалуйста, включите шаги, чтобы:

  • Получите и настройте Apache и необходимые модули (я знаю, что существуют другие способы создания SVN-сервера, но мне бы хотелось, чтобы он был специфичным для Apache)
  • Настройте безопасный способ доступа к серверу (SSH/HTTPS)
  • Настроить набор авторизованных пользователей (например, они должны авторизоваться для фиксации, но могут свободно просматривать)
  • Подтвердите настройку с помощью начального коммита (своего рода "Hello world")

Эти шаги могут включать в себя любое сочетание командной строки или инструкций приложения GUI. Если вы можете, пожалуйста, обратите внимание, где инструкции относятся к конкретному дистрибутиву или версии, и где вместо этого может использоваться выбор пользователем конкретного инструмента (скажем, nano вместо vi).

6 ответов

Решение

Шаги, которые я предпринял, чтобы сделать свой ноутбук сервером Subversion. Кредит должен идти к AlephZarro для его указаний здесь. Теперь у меня есть работающий сервер SVN (который в настоящее время тестируется только локально).

Конкретная настройка: Kubuntu 8.04 Hardy Heron

Требования, чтобы следовать этому руководству:

  • программа менеджера пакетов apt-get
  • текстовый редактор (я использую Кейт)
  • права доступа sudo

1. Установите HTTP-сервер Apache и необходимые модули:

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-репозиторий на моем ноутбуке.

После этого мне нужно было выполнить (в контексте приведенного выше примера)

$ 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/...

Эта статья, кажется, дает довольно хорошее краткое изложение всего процесса. Я бы порекомендовал следовать инструкциям, а затем публиковать более конкретные вопросы о любых проблемах, которые вы решаете, и которые не рассматриваются в статьях, с которыми я и другие люди связывались в этих ответах.

Для 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

Я не могу помочь с остальными...

Пожалуйста, напишите одну команду на терминале.

Чтобы открыть терминал, нажмите Ctrl + Alt + T, а затем введите следующую команду:

$sudo apt-get install subversion
Другие вопросы по тегам