Differences between revisions 1 and 5 (spanning 4 versions)
Revision 1 as of 2011-03-22 09:59:19
Size: 3236
Editor: 195
Comment:
Revision 5 as of 2011-03-22 10:11:37
Size: 3408
Editor: 195
Comment:
Deletions are marked like this. Additions are marked like this.
Line 6: Line 6:
- We use mercurial in "hg serve" mode
- For HTTP authentication, we use nginx
- For nginx/hg windows service integration, we use “Windows Service Wrapper”
 * We use mercurial in "hg serve" mode
 * For HTTP authentication, we use nginx
 * For nginx/hg windows service integration, we use “Windows Service Wrapper” (winsw)
Line 19: Line 19:
---- {{{
Line 22: Line 22:
Line 24: Line 23:
Line 26: Line 24:
Line 28: Line 25:
Line 30: Line 26:
Line 32: Line 27:
Line 34: Line 28:
Line 36: Line 29:
Line 39: Line 31:
----
 * Configure nginx with the following setup (save as c:\nginx\nginx.conf)
----
}}}

 * Configure nginx with the following setup (save as c:\nginx\nginx.conf). We assume port 5000 for intranet usage, hg will run at port 5500 locally only.

{{{
Line 43: Line 37:
        listen 5000;
        server_name mis-srv;
        access_log logs/mis-srv.access.log;
        error_log logs/mis-srv.error.log;
        location / {
            auth_basic "Mercurial restricted";
            auth_basic_user_file passwd;
            proxy_pass http://localhost:5500;
        }
    }
}}}
Line 44: Line 49:
        listen 5000;  * Create a password file at conf\passwd '''WARNING: On Windows, the passwd file can only contain plaintext passwords'''. Sample passwd file:
Line 46: Line 51:
{{{
test:testpass
}}}
Line 47: Line 55:
        server_name mis-srv;


        access_log logs/mis-srv.access.log;


        error_log logs/mis-srv.error.log;


        location / {


            auth_basic "Mercurial restricted";


            auth_basic_user_file passwd;


            proxy_pass http://localhost:5500;


        }


    }

----
 * Create a password file at conf/passwd, using htpasswd (get from an apache installation) '''WARNING: On Windows, the passwd file can only contain plaintext passwords'''
Line 79: Line 59:
----
{{{
Line 81: Line 62:
    <id>Mercurial</id>
    <name>Mercurial</name>
    <description>Mercurial</description>
    <executable>cmd.exe</executable>
    <logpath>c:\nginx\hg\servicelogs</logpath>
    <logmode>roll</logmode>
    <depend></depend>
    <startargument>/c "c:\nginx\hg\hg-run start"</startargument>
    <stopargument>/c "c:\nginx\hg\hg-run stop"</stopargument>
</service>
}}}
Line 82: Line 74:
    <id>Mercurial</id> Because winsw has a limitation where a single executable is assumed to start and stop the service, we need to use an intermediate .bat file to simulate this behaviour.
Line 84: Line 76:
    <name>Mercurial</name>  * Create file hg-run.bat with the following contents:
Line 86: Line 78:
    <description>Mercurial</description> {{{
    @echo off
    if "%1"=="start" (goto :start)
:stop
    taskkill /F /IM hg.exe /T
    goto :end
:start
    "c:\Program Files\Mercurial\hg.exe" serve --address localhost --port 5500 --web-conf c:\nginx\hg\hgweb.conf
:end
}}}
Line 88: Line 89:
    <executable>cmd.exe</executable>  * Create file hgweb.conf with the following contents:
Line 90: Line 91:
    <logpath>c:\nginx\hg\servicelogs</logpath>

    <logmode>roll</logmode>

    <depend></depend>

    <startargument>/c "c:\nginx\hg\hg-run start"</startargument>

    <stopargument>/c "c:\nginx\hg\hg-run stop"</stopargument>

</service>
----
 * Create file hg-run.bat with the following contents:
----
    @echo off

    if "%1"=="start" (goto :start)

:stop

    taskkill /F /IM hg.exe /T

    goto :end

:start

    "c:\Program Files\Mercurial\hg.exe" serve --address localhost --port 5500 --web-conf c:\nginx\hg\hgweb.conf

:end
----
 * Create file hgweb.conf with the following contents:
----
{{{
Line 123: Line 93:
Line 125: Line 94:
Line 128: Line 96:
[paths]
test = c:\nginx\hg\repository\test
}}}
Line 129: Line 100:
[paths]  * Install services, by starting a command line, cd-ing to c:\nginx and executing the following commands:
Line 131: Line 102:
test = c:\nginx\hg\repository\test
----
 * Install services, by starting a command line, cd-ing to c:\nginx and executing the following commands:
----
{{{
Line 136: Line 104:
c:\nginx> hg-service install
}}}
Line 137: Line 107:
c:\nginx> hg-service install
----

Setting up mercurial with HTTP authentication - Windows

This page describes a complete set of steps for installing hg as a windows service, along with nginx for HTTP proxy authentication. As it is, it is most appropriate for intranet configurations but by adding HTTPS to the mixture, the world is your sea food...

Wish list:

  • We use mercurial in "hg serve" mode
  • For HTTP authentication, we use nginx
  • For nginx/hg windows service integration, we use “Windows Service Wrapper” (winsw)

1. Download necessary files

2. Configuration

  • Unzip nginx in c:\nginx
  • Copy winsw-1.9-bin.exe in c:\nginx and rename to nginx-service.exe
  • Create file nginx-service.xml with the following contents:

<service>
    <id>nginx</id>
    <name>nginx</name>
    <description>nginx</description>
    <executable>c:\nginx\nginx.exe</executable>
    <logpath>c:\nginx\servicelogs</logpath>
    <logmode>roll</logmode>
    <depend>Mercurial</depend>
    <startargument>-p c:\nginx</startargument>
    <stopargument>-p c:\nginx -s stop</stopargument>
</service>
  • Configure nginx with the following setup (save as c:\nginx\nginx.conf). We assume port 5000 for intranet usage, hg will run at port 5500 locally only.

    server {
        listen       5000;
        server_name  mis-srv;
        access_log  logs/mis-srv.access.log;
        error_log  logs/mis-srv.error.log;
        location / {
            auth_basic           "Mercurial restricted";
            auth_basic_user_file passwd;
            proxy_pass           http://localhost:5500;
        }
    }
  • Create a password file at conf\passwd WARNING: On Windows, the passwd file can only contain plaintext passwords. Sample passwd file:

test:testpass
  • Install mercurial binary
  • Create directory for mercurial installation as a service, at c:\nginx\hg
  • Copy winsw-1.9-bin.exe in c:\nginx and rename to hg-service.exe
  • Create file hg-service.xml with the following contents:

<service>
    <id>Mercurial</id>
    <name>Mercurial</name>
    <description>Mercurial</description>
    <executable>cmd.exe</executable>
    <logpath>c:\nginx\hg\servicelogs</logpath>
    <logmode>roll</logmode>
    <depend></depend>
    <startargument>/c "c:\nginx\hg\hg-run start"</startargument>
    <stopargument>/c "c:\nginx\hg\hg-run stop"</stopargument>
</service>

Because winsw has a limitation where a single executable is assumed to start and stop the service, we need to use an intermediate .bat file to simulate this behaviour.

  • Create file hg-run.bat with the following contents:

    @echo off
    if "%1"=="start" (goto :start)
:stop
    taskkill /F /IM hg.exe /T
    goto :end
:start
    "c:\Program Files\Mercurial\hg.exe" serve --address localhost --port 5500 --web-conf c:\nginx\hg\hgweb.conf
:end
  • Create file hgweb.conf with the following contents:

[web]
push_ssl = false
allow_push = *

[paths]
test = c:\nginx\hg\repository\test
  • Install services, by starting a command line, cd-ing to c:\nginx and executing the following commands:

c:\nginx> nginx-service install
c:\nginx> hg-service install

And that's all!

HgServeNginxWindows (last edited 2011-10-06 12:17:05 by 212)