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



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




  • получить и настроить Apache, а также необходимые модули (я знаю, что есть и другие способы создания сервера SVN, но я хотел бы, чтобы это Apache-specific)

  • настройка безопасного способа доступа к серверу (SSH / HTTPS)

  • настройка a набор авторизованных пользователей (например, они должны быть авторизованы для фиксации, но могут свободно просматривать)

  • Проверьте установку с начальной фиксацией (своего рода" Hello world")


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

636   6  

6 ответов:

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

настройки: Kubuntu 8.04 Hardy Heron

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

  • apt-get package manager program
  • текстовый редактор (я использую Кейт)
  • sudo access права

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"

и (in 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: добавление репозитория(IES): Следующая настройка предполагает, что мы хотим разместить несколько репозиториев. Запустите это для создания первого репозитория:

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 (изменение значения репозиториев), пропуская шаг mkdir /var/svn

7: Добавить проверенный пользователь!--28-->

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 при совершении локальных изменений (хотя обязательства были эффективными на стороне сервера, Мне нужно было следить за локальными обновлениями)

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

Если вы получаете 403 запрещено при попадании на веб-сервер это может быть потому, что вы использовали имя хоста, которое не то, что вы указали в файле конфигурации (т. е. 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

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

Comments

    Ничего не найдено.