вторник, 1 марта 2011 г.

Установка и настройка Mercurial и Apache

Mercurial - это распределённая система управления версиями (DCVS). Разрабатывалась специально для больших проектов. Таким образом, одной из отличительных особенностей Mercurial является скорость работы. БОльшая часть системы написана на Python, а чувствительные к производительности части - реализованы в качестве Python-расширений на C.



Наравне с традиционными возможностями систем контроля версий, Mercurial так же поддерживает функции для децентрализованной работы:
  • отсутствует понятие основного хранилища кода
  • ветвление (возможно вести несколько веток одного проекта и копировать изменения между ветками)
  • слияние репозиториев (чем и достигается «распределённость» работы).
Кроме того, Mercurial предоставляет Web-интерфейс, а так же встроенную систему подсказок. Большинство команд привычны для пользователей CVS.

Установка и настройка mercurial

Установка mercurial

Установка mercurial очень проста:
$ sudo aptitude install mercurial

Настройка mercurial

Далее, необходимо создать пользователя для mercurial и директории, где будут располагаться репозитории mercurial и виртуальный хост (последний необходим для настройки apache, см. далее):
# добавляем нового пользователя
$ sudo useradd hg
$ sudo mkdir /home/hg
$ sudo chown hg:hg /home/hg

# создаем директорим для репозиториев и для виртуального хоста
$ sudo -u hg mkdir /home/hg/repos /home/hg/www

Создание репозитория mercurial

После того, как пользователь создан, необходимо создать репозиторий, в котором будут храниться исходные коды:
# От имени пользователя hg создаем (hg init) репозиторий
$ sudo -u hg hg init /home/hg/repos/Debian.World.Ru
Попробуем что-нибудь сохранить в репозитории:
$ sudo su - hg
$ cd /home/hg/repos/Debian.World.Ru/

# создаем файл
$ echo "test mercurial cvs" > read.me

# убеждаемся, что mercurial "видит" новый файл
$ hg status
? read.me

# добавляем файл в репозиторий
$ hg add
adding read.me

# убеждаемся, что добавление файла выполнено
$ hg status
A read.me

# коммитим изменения
$ hg ci -m "init revision"
No username found, using 'hg@debian-world.ru' instead
Последняя строчка выглядит странновато, но волноваться не очем. Все изменения будут сохранены, а последняя строчка говорит лишь о том, что вместо имени ползователя будет использована строка "hg@debian-world.ru", то есть "логин@машина". Чтобы эта строка более не мозолила глаз, необходимо лишь сделать следующее:
$ echo "[ui]" > ~/.hgrc
$ echo "username = Debian.World.Ru Admin <debian.world.ru@gmail.com>" >> ~/.hgrc
Таким образом, mercurial будет "знать", кем подписываться при сохранении изменений.

Установка и настройка Apache, mod_wsgi

После того, как репозиторий создан, необходимо предоставить http-доступ к нему.

Установка Apache, mod_wsgi

Для этого необходимо установить http-сервер, например, Apache, а так же модуль для работы с python (в данном случае - mod_wsgi):
$ sudo aptitude install apache2 libapache2-mod-wsgi

Настройка Apache

Далее, необходимо создать виртуальный хост:
$ sudo touch /etc/apache2/sites-available/mercurial
Выглядеть он должен приблизительно следующим образом:

    ServerAdmin debian.world.ru@gmail.com
    ServerName hg.debianworld.ru
    DocumentRoot /home/hg/www/

    # настройки wsgi
    WSGIProcessGroup hg
    WSGIDaemonProcess hg user=hg group=hg threads=2 maximum-requests=1000

    # путь до скрипта, обрабатывающий wsgi
    WSGIScriptAlias / /home/hg/rep/hgwebdir.wsgi

    # ограничение доступа к репозиторию
    
        AuthType Basic
        AuthName "Restricted Files"
        AuthUserFile /home/hg/.hg.htpasswd
        Require valid-user
    

Настройка mod_wsgi

После того, как создан виртуальных хост, необходимо создать скрипт wsgi, а так же файл пользователей, которым будет доступен репозиторий. Скрипт для wsgi можно располагать в любом месте, например, недалеко от репозитория:
$ sudo -u hg vim /home/hg/repos/hgwebdir.wsgi
Выглядеть он должен следующий образом:
#!/usr/bin/python
# -*- coding: utf-8 -*-

import os
os.environ['HGENCODING'] = 'utf-8'

from mercurial.hgweb.hgwebdir_mod import hgwebdir
from mercurial.hgweb.request import wsgiapplication

path = os.path.dirname(os.path.abspath(__file__))
application = hgwebdir(path+'/hgwebdir.conf')
Радом необходимо создать файл конфигации web-интерфейса репозитория:
$ sudo -u hg vim /home/hg/repos/hgwebdir.conf
Выглядеть он должен следующим образом:
[web]
style = coal

[paths]
DebianWorld.Ru = /home/hg/repos/Debian.World.Ru
После этого можно включить виртуальный хост и перегрузить apache:
$ sudo a2ensite mercurial
$ sudo /etc/init.d/apache2 reload

Настройка доступа к mercurial

На завершающей стадии настройки, необходимо создать файл паролей, указанный в описании виртуального хоста:
$ htpasswd -c /home/hg/.hg.htpasswd hgviewer
Теперь можно работать с репозитарием как через браузер, так и через командную строку, обращаясь к репозиторию по адресу: http://hg.debianworld.ru/DebianWorld.Ru/. Например:
# Просмотр репозитариев браузером
$ lynx http://hg.debianworld.ru/DebianWorld.Ru

# Копирование репозитория клиентом mercurial
$ hg clone http://hg.debianworld.ru/DebianWorld.Ru
destination directory: DebianWorld.Ru
http authorization required
realm: Restricted Files
user: 
password:
 
Источник 

Комментариев нет: