Differences between revisions 3 and 4
Revision 3 as of 2006-06-18 14:11:29
Size: 4150
Comment: Added the standalone recipe.
Revision 4 as of 2006-06-18 14:19:37
Size: 4154
Editor: MishaS
Comment: removed ` from the header; su -> sudo
Deletions are marked like this. Additions are marked like this.
Line 2: Line 2:
= Publishing Repositories with `hgwebdir.cgi` = = Publishing Repositories with hgwebdir.cgi =
Line 112: Line 112:
Simply run {{{
su -u www-data hg serve --webdir-conf /var/hg/hgweb.config
}}} and enjoy this speedy method of serving multiple repos. It should be faster than using Apache.

Simply run
{{{
sudo -u www-data hg serve --webdir-conf /var/hg/hgweb.config
}}}
and enjoy this speedy method of serving multiple repos. It should be faster than using Apache.

TableOfContents

Publishing Repositories with hgwebdir.cgi

Introduction

Well, we have a certain setup with subversion. I'd like to reproduce it using Mercurial.

Pre-requisites

The installed software is:

  • apache2 (apache2, apache2-common, apache2-mpm-prefork, apache2-utils)
    • But it is not necessary (see below)
  • some version of mercurial (mine was 0.9 taken from Debian/unstable)
  • python:
    • Ubuntu/Edgy comes with python 2.4
    • you will need python2.4-dev package as well
  • sudo (in general, I prefer sudo to su)

Getting proper Mercurial

The whole point was to try pull/push over http. So the following was done (I'm a real newbie for hg, so please bear me :)):

$ cd working-directory
$ hg clone http://selenic.com/hg/
$ cd hg
$ hg pull http://hg.intevation.org/mercurial/crew
$ wget http://www.selenic.com/pipermail/mercurial/attachments/20060615/2893c03e/push-http.bin -O push-http.patch
$ hg import -p1 push-http.patch
$ python setup.py build
$ sudo python setup.py install

Directory Structure

Create the necessary directories:

$ sudo mkdir -p /var/hg/repos
$ sudo chown www-data:www-data -R /var/hg

It's usually a good idea to keep special directories out of the tree served by apache.

Preparing the config

$ cat > /tmp/hgweb.config
[collections]
repos/ = repos/
^D
$ sudo -u www-data cp /tmp/hgweb.config /var/hg
$ rm /tmp/hgweb.config

Two possibilities

Either choose Apache or a standalone install.

Apache

Putting the right stuff in place

Put the script in place (remember, we are still in that working-directory/hg :)):

$ sudo -u www-data cp hgwebdir.cgi /var/hg
$ sudo -u www-data chmod +x /var/hg/hgwebdir.cgi 

Making it accessible

Ok, now it's time for apache.

First of all, do not really change the config of apache directly:

$ sudo mkdir /etc/apache2/hg

Create the config with the following contents (e.g by using sudo vim /etc/apache2/hg/main.conf):

ScriptAliasMatch        ^/hg(.*)        /var/hg/hgwebdir.cgi$1

<Directory /var/hg>
  Options ExecCGI FollowSymLinks

  AllowOverride None
</Directory>

This config says that we are going to serve our repositories through '<yourhost>/hg/'.

Now make it really available, by changing your favourite site in /etc/apache2/sites-enabled. For this experiment I used /etc/apache2/sites-enabled/default:

  ...
  Include /etc/apache2/hg/main.conf
</VirtualHost>

Make sure that everything is OK:

$ sudo apache2ctl configtest
Syntax is OK

Restart your web server:

$ sudo apache2ctl stop
$ sudo apache2ctl start

Check if it works by directing your browser to <yourhost>/hg/

Standalone

Simply run

sudo -u www-data hg serve --webdir-conf /var/hg/hgweb.config

and enjoy this speedy method of serving multiple repos. It should be faster than using Apache.

You are done

Hooray!

Final Bits

Create a new repository

$ sudo -u www-data hg init /var/hg/repos/<repository-name>

Provide more information about it

Add the following to the /var/hg/repos/<repository-name>/.hg/hgrc file:

[web]
contact = Bilbo Baggins       # Whom to contact, plain text,
                              # no fancy stuff
description = My precious!    # Nice description what this is about,
                              # you can include HTML (like <a>)

Customize the look

Add the following to the /var/hg/repos/<repository-name>/.hg/hgrc file:

[web]
style = gitweb                # looks cleaner from my point of
                              # view :)
allow_archive = gz, zip, bz2  # If you think people should be able
                              # to download snapshots as .tar.gz,
                              # .zip, .tar.bz2 respectively

Disclaimer

Well, it works (worked) for me. Please do not hesitate to update this page to include small bits I've forgotten or just plainly am not aware of.

HgWebDirStepByStep (last edited 2018-11-26 18:38:58 by JordiGH)