Назад | Перейти на главную страницу

Различия в путях Subversion для svn и svn + ssh

[02:48] [root @ server: ~] ps ax | grep svn 23986? Ss 0:00 / usr / bin / svnserve -d -r / srv / svn Как видно из аргументов, моим корневым каталогом svn является / srv / svn.

А теперь немного волшебства с удаленной машины ...

Это работает:

> svn co svn://svn-user@domain.com/test-repo

Но это не так:

> svn co svn+ssh://svn-user@<putty-session-name>/test-repo
'No repository found in 'svn+ssh://svn-user@<putty-session-name>/test-repo'

Играя пару часов, я обнаружил, что по-видимому если я использую туннель ssh, я могу получить свое репо, используя следующее:

> svn co svn+ssh://svn-user@<putty-session-name>/srv/svn/test-repo

... что означает, что я должен указать полный физический путь к репо. А?

Как сказал womble, это действительно «особенность» svn по ssh.

У меня svn + ssh работал без указания полного пути к репозиториям, потому что на сервере svn был сценарий оболочки svnserve вместо исходного двоичного файла svnserve. Позже, во время обновления Subversion, этот скрипт был перезаписан исходным двоичным файлом.

Решение:

  1. Переименуйте svnserve в bin

    mv /usr/bin/svnserve /usr/bin/svnserve.bin
    
  2. Сохраните этот сценарий как / usr / bin / svnserve:

    #!/bin/sh
    exec /usr/bin/svnserve.bin -r /srv/svn "$@"
    
  3. Обновить разрешения

    chmod 755 /usr/bin/svnserve
    

Это потому, что svn over SSH (svn+ssh://) просто обращается к репозиторию Subversion "локально", используя SSH в качестве транспорта, и, следовательно, у вас есть доступ ко всей файловой системе. Svnserve, напротив, говорит: «Начни свой путь с /srv/svn, поэтому вам не нужно указывать его вручную.

Вы можете отредактировать команду входа ssh для пользователей с помощью svn + ssh, отредактировав ~ / .ssh / authorized_keys пользователя Subversion. Строка для пользователя будет выглядеть так:

command="/usr/bin/svnserve -r /srv/svn [other svnserve options]" <key type> <user key> <key comment>

Есть больше трюков svn + ssh в svn книга

это больше похоже на вопрос сам по себе, но он действительно связан с этим.

настроив svn + ssh с закрытыми / открытыми ключами, я не могу получить доступ к своему репо, используя относительные пути таким образом:

svn co svn+ssh://svn@SERVERIP/simple-webapp-svn simple-webapp-svn

так как я получаю эту ошибку:

svn: URL 'svn+ssh://svn@SERVERIP/simple-webapp-svn' doesn't exist

но только так:

svn co svn+ssh://svn@SERVERIP/home/svn/projects/simple-webapp-svn simple-webapp-svn

Это файл authorized_keys2, который у меня есть в каталоге /home/svn/.ssh

$ sudo cat /home/svn/.ssh/authorized_keys2
command="/usr/bin/svnserve.bin -t --tunnel-user=USERNAME",no-port-forwarding,no-agent-forwarding,no-X11-forwarding,no-pty ssh-rsa [rsa-key] [user-note]

и файл svnserve.bin, предложенный Андреем на предыдущий ответ

$ cat  /usr/bin/svnserve.bin 
#!/bin/sh
exec /usr/bin/svnserve -r /home/svn/projects "$@"

Я даже подумал о проблемах с разрешениями, которые перечислены здесь:

-rwxr-xr-x 1 root root 63684 2009-12-12 06:45 /usr/bin/svnserve
-rwxr-xr-x 1 root root    61 2010-08-25 17:19 /usr/bin/svnserve.bin

Я действительно не могу придумать решение ...