Git Server (Linux): Unterschied zwischen den Versionen
(→GitWeb) |
(→Links) |
||
(37 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt) | |||
Zeile 1: | Zeile 1: | ||
{{note|Noch in Bearbeitung}} | {{note|Noch in Bearbeitung}} | ||
[[Datei:GitPushForceYoda.jpg|323px]] [[Datei:Git-push-force.png]] | |||
Zeile 123: | Zeile 126: | ||
[https://git-scm.com/book/de/v1/Git-auf-dem-Server-Git-Daemon https://git-scm.com/book/de/v1/Git-auf-dem-Server-Git-Daemon] | [https://git-scm.com/book/de/v1/Git-auf-dem-Server-Git-Daemon https://git-scm.com/book/de/v1/Git-auf-dem-Server-Git-Daemon] | ||
=== | === Webinterface === | ||
[[GitWeb (Ubuntu)|GitWeb]] | |||
[[GitLab (Ubuntu)|GitLab]] | |||
== | == Repository anlegen == | ||
<pre> | <pre> | ||
cd /home/git | |||
mkdir project.git | |||
cd project.git | |||
git --bare init | |||
</pre> | </pre> | ||
== Client Seite == | == Client Seite == | ||
Verwendung von Git wurde nach [[Git Client]] verschoben. | |||
=== Lokales Repository auf Server kopieren === | === Lokales Repository auf Server kopieren === | ||
Zeile 287: | Zeile 161: | ||
== Repository von Server klonen == | == Repository von Server klonen == | ||
Verwendung siehe [[Git Client]] | |||
=== Links === | |||
[https://git-scm.com/docs/git-http-backend https://git-scm.com/docs/git-http-backend] | [https://git-scm.com/docs/git-http-backend https://git-scm.com/docs/git-http-backend] | ||
Zeile 330: | Zeile 171: | ||
[http://www.tikalk.com/devops/setup-git-gitweb-git-http-backend-smart-http-ubuntu-1204/ http://www.tikalk.com/devops/setup-git-gitweb-git-http-backend-smart-http-ubuntu-1204/] | [http://www.tikalk.com/devops/setup-git-gitweb-git-http-backend-smart-http-ubuntu-1204/ http://www.tikalk.com/devops/setup-git-gitweb-git-http-backend-smart-http-ubuntu-1204/] | ||
== | == Umziehen == | ||
[[Von Subversion zu Git umziehen]] | |||
== | == IDE Integration == | ||
[ | [[Git in IntelliJ]] | ||
== Probleme == | == Probleme == | ||
Zeile 341: | Zeile 184: | ||
Entweder eine leere Datei <code>git-daemon-export-ok</code> im Repository anlegen oder den Dämonen mit der Option <code>--export-all</code> Option starten. | Entweder eine leere Datei <code>git-daemon-export-ok</code> im Repository anlegen oder den Dämonen mit der Option <code>--export-all</code> Option starten. | ||
=== fatal: unable to access 'https://git.<domain>/test.git/': server certificate verification failed. CAfile: /etc/ssl/certs/ca-certificates.crt CRLfile: none === | |||
SSL-Verifizierung mittels folgendem Befehl deaktivieren: | |||
<pre> | |||
git config --global http.sslverify false | |||
</pre> | |||
== Links == | == Links == | ||
Zeile 353: | Zeile 203: | ||
Zurück zu [[ | Zurück zu [[Git Server (unterschiedliche Versionen)|Git Server]] |
Aktuelle Version vom 27. Juli 2020, 22:36 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
sudo a2enmod env alias fcgid auth_digest sudo 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
Webinterface
Repository anlegen
cd /home/git mkdir project.git cd project.git git --bare init
Client Seite
Verwendung von Git wurde nach Git Client verschoben.
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
Verwendung siehe Git Client
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/
Umziehen
Von Subversion zu Git umziehen
IDE Integration
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.
fatal: unable to access 'https://git.<domain>/test.git/': server certificate verification failed. CAfile: /etc/ssl/certs/ca-certificates.crt CRLfile: none
SSL-Verifizierung mittels folgendem Befehl deaktivieren:
git config --global http.sslverify false
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 Git Server