Настройка сервера git

Я недавно установил Ubuntu-сервер на Amazon EC2. Я хотел бы использовать его в качестве моего сервера Git, чтобы я мог хранить свои репозитории там.

Итак, где я могу найти некоторые подробные инструкции о том, как настроить git на сервере Ubuntu? Все эти ключи SSH и тому подобное, несколько пользователей и т. Д.

57
задан 12 November 2010 в 07:30

8 ответов

Вы можете использовать руководство для установки сервера Git, как предложено aking1012 вы или вы можете просто установить SSH-сервер на свой экземпляр EC2 (возможно, было бы разумно защитить его и изменить порт по умолчанию).

Git может работать без сервера: вы инициируете свой репозиторий, а затем получаете доступ к нему с удаленного компьютера через SSH. Таким образом, такие инструкции на сервере Ubuntu должны сделать это:

GIT_DIR=project.git git init  
cd project.git  
git --bare update-server-info  
cp hooks/post-update.sample hooks/post-update

Наконец, установите SSH на свой сервер:

sudo apt-get install ssh-server

Теперь вы должны настроить SSH для его защиты.

Пришло время разместить ваш проект в сети (данные, которые у вас уже есть на вашем компьютере разработчика):

git push ssh://<username>@<remote-git-hostname>/path/to/project.git master

И теперь вы можете начать клонирование. Вы переходите на свою машину разработки:

git clone ssh://<username>@<remote-git-hostname>/path/to/dir.git

Проверьте этот отличный ресурс на Git .

А чтобы сгенерировать ваши ssh-ключи для более безопасной аутентификации, вы можете прочитать эту статью о SSH-аутентификации .

0
ответ дан 12 November 2010 в 07:30

http://scie.nti.st/2007/11/14/hosting-git-repositories-the-easy-and-secure-way можно немного изменить в соответствии с вашими целями . Аналогичный учебник http://blog.agdunn.net/?p=277 .

0
ответ дан 12 November 2010 в 07:30

Мне нравится Гитолит . В книге Pro Git есть раздел , но я рекомендую прочитать всю книгу.

Что касается требования для нескольких пользователей:

Gitolite позволяет указывать разрешения не только для репозитория (как это делает Gitosis), но также для имен веток или тегов в каждом репозитории. То есть вы можете указать, что определенные люди (или группы людей) могут выдвигать только определенные «ссылки» (ветви или теги), но не другие.

0
ответ дан 12 November 2010 в 07:30

Для всех моих настроек Git-сервера я использую Gitolite , который обеспечивает гранулярность безопасности доступа «на ветвь». Настройка довольно проста, если вы делаете это на удаленном сервере, это так же просто, как запуск интерактивного скрипта. В дополнение к этому «простому в настройке» характеру, он также имеет пакет в Natty и Maverick

sudo apt-get install gitolite

. Это не обеспечит веб-интерфейс, такой как Github или Gitweb, - но вы можете легко настроить и установите их на что-то вроде Gitolite.

0
ответ дан 12 November 2010 в 07:30

Это очень легко сделать с гитолитом . Менее чем через час вы получите легко настраиваемый и безопасный многопользовательский git-сервер.

У меня есть статья на моем сайте

.
0
ответ дан 12 November 2010 в 07:30

Решение, который работавший лучшее для меня, настраивало WebDAV.

  • sudo a2enmod sudo dav_fs

  • sudo a2enmod dav

  • добавьте новый файл к /etc/apache2/sites-available и назовите его, например, git.yourserver.com. Отредактируйте его и добавьте следующие строки:

<VirtualHost *:80>

DocumentRoot /var/www/git.yourserver.com/repos
ServerName git.yourserver.net
Options Indexes FollowSymLinks MultiViews

<Location />
    DAV On
    AuthType Basic
    AuthName "git repos"
    AuthUserFile /var/www/git.yourserver.net/password.dav
    Require valid-user
</Location>

</VirtualHost>

  • создайте каталог /var/www/git.yourserver.com и каталог repos в идентификаторе
  • sudo chown www-data /var/www/git.yourserver.com/repos
  • sudo htpasswd -c /var/www/git.yourserver.com/password.dav user_login и введите пароль для названного пользователя user_login
  • sudo chown root:www-data /var/www/git.yourserver.com/password.dav
  • sudo chmod 640 /var/www/git.yourserver.com/password.dav

Теперь, sudo a2ensite git.yourserver.com и sudo service apache2 restart.

  • Войти /var/www/git.yourserver.com/repos и создайте каталог, например, myrepo.git
  • cd myrepo.git
  • git --bare init
  • git update-server-info

Теперь, выйдите из системы от своего удаленного сервера и перейдите к локальному каталогу, в котором Вы хотите отредактировать свои файлы.

git clone http://user_login:user_password@git.yourserver.com/myrepo.git

и Вы закончили. Если Вы хотите отправить свои переданные изменения в сервере:

git push origin master

Можно создать столько пользователей, сколько Вы хотите использовать sudo htpasswd. Просто не забудьте не использовать -c переключатель, при добавлении большего количества пользователей, потому что старый файл будет удален.

4
ответ дан 12 November 2010 в 07:30

Мне также нравится подход gitolite для управления пользователями и безопасностью. У меня есть сервер AMI Git + gitolite для EC2, который в настоящее время тестируется. Не стесняйтесь попробовать; документация доступна здесь:

Alestic Git Server

Используя этот подход, вы можете иметь центральный сервер Git с частными репозиториями, работающими в считанные минуты. Если вы не знакомы с ними, существует кривая изучения гитолита и EC2.

0
ответ дан 12 November 2010 в 07:30

Обязательно следуйте официальной документации: https://help.ubuntu.com/community/Git (раздел Настройка Git и управления проектами )

0
ответ дан 12 November 2010 в 07:30

Другие вопросы по тегам:

Похожие вопросы: