Git Server (Linux): Unterschied zwischen den Versionen
(→Apache) |
(→Apache) |
||
| Zeile 19: | Zeile 19: | ||
=== Apache === | === Apache === | ||
Packete für '''htdigest''' und '''fcgid''' installieren: | |||
<pre> | <pre> | ||
sudo apt-get install apache2-utils | sudo apt-get install apache2-utils libapache2-mod-fcgid | ||
</pre> | </pre> | ||
Version vom 11. November 2017, 18:25 Uhr
Noch in Bearbeitung
Installation
PPA-Repository
sudo add-apt-repository ppa:git-core/ppa
Paket installieren
sudo apt-get update sudo apt-get install git
Apache
Packete für htdigest und fcgid installieren:
sudo apt-get install apache2-utils libapache2-mod-fcgid
a2enmod env alias fcgid auth_digest service apache2 restart
Konfiguration
Ports
| Anwendung | Protokoll | Port |
|---|---|---|
| ssh:// | TCP | 22 |
| git:// | TCP | 9418 |
| http:// | TCP | 80 |
| https:// | TCP | 443 |
Links
https://git-scm.com/book/de/v1/Git-auf-dem-Server-Die-Protokolle
Projektverzeichnis
Grundverzeichnis erstellen:
sudo mkdir /home/git sudo chown www-data:www-data /home/git/ sudo chmod 2775 /home/git/
Projektverzeichnis erstellen:
mkdir /home/git/test/ cd /home/git/test/ git --bare init
Der Befehl git --bare init erstellt ein leeres Repository ohne Arbeitsverzeichnis. Darin kann man keine Dateien direkt sehen - benötigt den Befehl git --show.
Allgemein
Um die Lesbarkeit zu erhöhen, sollte man die Ausgaben mit den folgenden Befehlen einfärben:
git config --global color.ui "auto"
Für Computer mit mehreren Prozessorkernen empfiehlt sich diese Option:
git config --global pack.threads "0"
Als Dämon starten
Upstart
sudo vi /etc/init/git_daemon.conf
description "Git daemon" start on runlevel [2345] stop on runlevel [!2345] respawn respawn limit 10 5 umask 002 exec /usr/bin/git daemon --user=www-data --group=www-data --reuseaddr --verbose --export-all --base-path=/home/git
sudo initctl start git_daemon
sudo initctl stop git_daemon
Links
https://git-scm.com/book/de/v1/Git-auf-dem-Server-Git-Daemon
GitWeb
git clone git://git.kernel.org/pub/scm/git/git.git cd git make GITWEB_PROJECTROOT="/home/git" prefix=/usr gitweb sudo cp -Rf gitweb /var/www/ sudo chown -R www-data:www-data /var/www/gitweb
Bzw. über
sudo apt-get install gitweb
Apache
sudo -u www-data htdigest -c /home/git/.htpasswd "Shared Git Repo" martin
cd /etc/apache2/sites-available/
http
sudo vi gitweb.conf
<VirtualHost *:80>
ServerName gitweb.<domain>
DocumentRoot /var/www/gitweb
<Directory /var/www/gitweb>
Options +ExecCGI +FollowSymLinks +SymLinksIfOwnerMatch
AllowOverride All
order allow,deny
Allow from all
AddHandler cgi-script cgi
DirectoryIndex gitweb.cgi
</Directory>
</VirtualHost>
sudo a2ensite gitweb.conf sudo service apache2 reload
https
SSL-Zertifikat erstellen - dazu siehe SSL_Zertifikat
sudo vi gitweb.conf
<VirtualHost *:80>
ServerName gitweb.<domain>
ServerAlias gitweb.<domain>
Redirect / https://gitweb.<domain>
</VirtualHost>
sudo vi gitweb-ssl.conf
<VirtualHost *:443>
ServerName gitweb.<domain>
DocumentRoot /var/www/gitweb
SSLEngine On
SSLCertificateFile /etc/ssl/certs/gitweb.crt
SSLCertificateKeyFile /etc/ssl/private/apache.key
<Directory /var/www/gitweb>
Options +ExecCGI +FollowSymLinks +SymLinksIfOwnerMatch
AllowOverride All
order allow,deny
Allow from all
AddHandler cgi-script cgi
DirectoryIndex gitweb.cgi
</Directory>
ErrorLog ${APACHE_LOG_DIR}/gitweb.<domain>-error.log
CustomLog ${APACHE_LOG_DIR}/gitweb.<domain>-access.log combined
</VirtualHost>
sudo a2ensite gitweb-ssl.conf sudo service apache2 reload
Beschreibung
Die Beschreibung
Unnamed repository; edit this file 'description' to name the repository.
ändert man durch editieren der Datei
<root directory>/<repo>.git/description
Bei einem Klon des Repositories wird diese Beschreibung jedoch nicht übernommen.
Links
https://git-scm.com/book/de/v1/Git-auf-dem-Server-GitWeb
Client Seite
Benutzer anlegen
git config --global user.name "<first name> <surname>" git config --global user.email <user>@<domain>
Kontrollieren kann man die Eingabe mit den selben Befehlen ohne Parameter.
Lokales Repository auf Server kopieren
git clone --bare .git test.git
scp -r test.git <user>@<domain>:/home/git/
Links
http://www.codesolutions.de/git-repository-lokal-erstellen-und-dann-auf-den-server-uploaden/
Repository von Server klonen
per SSH-Protokoll
git clone ssh://<user>@<server>/home/git/test.git
per GIT-Protokoll
Dazu muss git als Dämon laufen - siehe Git als Dämon starten
git clone git://git.<domain>/test.git test
per HTTP-Protokoll
Funktioniert noch nicht
<VirtualHost *:80>
ServerName git.<domain>
DocumentRoot /home/git/
<Directory /home/git>
Options +Indexes
Require all granted
</Directory>
ErrorLog ${APACHE_LOG_DIR}/git.<domain>-error.log
CustomLog ${APACHE_LOG_DIR}/git.<domain>-access.log combined
</VirtualHost>
Links
https://git-scm.com/docs/git-http-backend
https://kupschke.net/2012/02/23/git-server-mit-apache-und-dem-git-smart-http-protokoll/
http://www.tikalk.com/devops/setup-git-gitweb-git-http-backend-smart-http-ubuntu-1204/
Zu Git umziehen
Links
https://git-scm.com/book/de/v1/Git-und-andere-Versionsverwaltungen-Zu-Git-umziehen
Probleme
fatal: remote error: access denied or repository not exported: /test.git
Entweder eine leere Datei git-daemon-export-ok im Repository anlegen oder den Dämonen mit der Option --export-all Option starten.
Links
https://wiki.ubuntuusers.de/Git/
https://www.git-tower.com/learn/
http://t3n.de/news/git-eigener-git-server-544264/
https://git-scm.com/book/de/v1/Git-auf-dem-Server-Git-auf-einen-Server-bekommen
Zurück zu Ubuntu