Как настроить сервер Subversion (SVN) на GNU/Linux - Ubuntu [закрыто]
У меня есть ноутбук под управлением Ubuntu, который я хотел бы действовать как сервер Subversion. Как для себя, чтобы совершить локально, так и для других удаленно. Какие шаги необходимы для того, чтобы это сработало? Пожалуйста, укажите шаги, чтобы:
- получить и настроить Apache, и необходимые модули (я знаю, что есть другие способы создания SVN-сервера, но я хотел бы, чтобы это Apache-specific)
- настройте безопасный способ доступа к серверу (SSH/HTTPS)
- настройка a набор авторизованных пользователей (например, они должны авторизоваться для фиксации, но могут свободно просматривать)
- Проверьте настройку с помощью начальной фиксации (своего рода" Hello world")
эти шаги могут включать любую смесь инструкций командной строки или GUI-приложения. Если вы можете, обратите внимание, где инструкции специфичны для конкретного дистрибутива или версии, и где вместо этого можно использовать выбор пользователя конкретного инструмента (скажем,нано вместо vi).
6 ответов
шаги, которые я предпринял, чтобы сделать мой ноутбук сервером Subversion. Кредит должен идти на AlephZarro для его направления здесь. Теперь у меня есть рабочий SVN-сервер (который в настоящее время тестируется только локально).
настройки: Kubuntu 8.04 Hardy Heron
требования следовать этому руководству:
- apt-получить менеджер пакетов программы
- текстовый редактор (я использую kate)
- sudo доступ права
1: Установите Apache HTTP server и необходимые модули:
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
изменить (в портах.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.а. Дополнительные репозитории: сделал шаг 6 снова (изменение стоимости РЕПО), пропуск шага 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
, позволит anonymous просмотр.
в браузере отображается " Revision 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-кэш.db
$ судо Чаун ВСП-данных:ВСП-данных в /var/СВН/$РЕПО/дБ/рэп-кэш.db
в противном случае я продолжал получать ошибку 409 при совершении локальных изменений (хотя обязательства были эффективными на стороне сервера, Мне нужно было следить за локальными обновлениями)
в этой статье Кажется, дает довольно хорошее описание всего процесса. Я бы рекомендовал следовать инструкциям, а затем публиковать более конкретные вопросы о любых проблемах, которые вы encouter, которые не рассматриваются в статьях я и другие люди, связанные с этими ответами.
Если вы получаете 403 Forbidden, когда вы попали на веб-сервер может быть потому, что вы использовали имя хоста это не то, что вы указали в файле конфигурации (т. е. localhost или 127.0.0.1). Попробуйте нажать https://whateveryousetasyourhostname вместо...
пожалуйста, напишите одну команду на терминале.
чтобы открыть терминал, нажмите 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
Я не могу помочь с остальным...