--- layout: default navsection: installguide title: Install Git server ... The arv-git-httpd server provides HTTP access to hosted git repositories, using Arvados authentication tokens instead of passwords. It is intended to be installed on the system where your git repositories are stored, and accessed through a web proxy that provides SSL support. By convention, we use the following hostname for the git service:
table(table table-bordered table-condensed). |git.@uuid_prefix@.your.domain|
This hostname should resolve from anywhere on the internet. h2. Install arv-git-httpd On Debian-based systems:
~$ sudo apt-get install git arv-git-httpd
On Red Hat-based systems:
~$ sudo yum install git arv-git-httpd
Verify that @arv-git-httpd@ and @git-http-backend@ are functional:
~$ arv-git-httpd -h
Usage of arv-git-httpd:
  -address="0.0.0.0:80": Address to listen on, "host:port".
  -git-command="/usr/bin/git": Path to git executable. Each authenticated request will execute this program with a single argument, "http-backend".
  -repo-root="/path/to/cwd": Path to git repositories.
~$ git http-backend
Status: 500 Internal Server Error
Expires: Fri, 01 Jan 1980 00:00:00 GMT
Pragma: no-cache
Cache-Control: no-cache, max-age=0, must-revalidate

fatal: No REQUEST_METHOD from server
We recommend running @arv-git-httpd@ under "runit":http://smarden.org/runit/ or something similar. Your @run@ script should look something like this:
export ARVADOS_API_HOST=uuid_prefix.your.domain
exec sudo -u git arv-git-httpd -address=:9001 -git-command="$(which git)" -repo-root=/var/lib/arvados/git 2>&1
h3. Set up a reverse proxy with SSL support The arv-git-httpd service will be accessible from anywhere on the internet, so we recommend using SSL for transport encryption. This is best achieved by putting a reverse proxy with SSL support in front of arv-git-httpd, running on port 443 and passing requests to arv-git-httpd on port 9001 (or whatever port you chose in your run script). h3. Tell the API server about the arv-git-httpd service In your API server's @config/application.yml@ file, add the following entry:
git_http_base: git.uuid_prefix.your.domain