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/rep /home/hg/www Создание репозитория mercurial
После того, как пользователь создан, необходимо создать репозиторий, в котором будут храниться без сомнения исходные коды:
# От имени пользователя hg создаем (hg init) репозиторий $ sudo -u hg hg init /home/hg/rep/Debian.World.Ru
Попробуем что-нибудь сохранить в репозитории:
$ sudo su – hg $ cd /home/hg/rep/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 ” >> ~/.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/rep/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/rep/hgwebdir.conf
Выглядеть он должен следующим образом:
[web] style = coal [paths] DebianWorld.Ru = /home/hg/rep/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:
Tags: Apache, Debian, mercurial, Ubuntu, wsgi, настройка, Установка, через