-
1. Aan de slag
- 1.1 Over versiebeheer
- 1.2 Een kort historisch overzicht van Git
- 1.3 Wat is Git?
- 1.4 De commando-regel
- 1.5 Git installeren
- 1.6 Git klaarmaken voor eerste gebruik
- 1.7 Hulp krijgen
- 1.8 Samenvatting
-
2. Git Basics
-
3. Branchen in Git
- 3.1 Branches in vogelvlucht
- 3.2 Eenvoudig branchen en mergen
- 3.3 Branch-beheer
- 3.4 Branch workflows
- 3.5 Branches op afstand (Remote branches)
- 3.6 Rebasen
- 3.7 Samenvatting
-
4. Git op de server
- 4.1 De protocollen
- 4.2 Git op een server krijgen
- 4.3 Je publieke SSH sleutel genereren
- 4.4 De server opzetten
- 4.5 Git Daemon
- 4.6 Slimme HTTP
- 4.7 GitWeb
- 4.8 GitLab
- 4.9 Hosting oplossingen van derden
- 4.10 Samenvatting
-
5. Gedistribueerd Git
-
6. GitHub
-
7. Git Tools
- 7.1 Revisie Selectie
- 7.2 Interactief stagen
- 7.3 Stashen en opschonen
- 7.4 Je werk tekenen
- 7.5 Zoeken
- 7.6 Geschiedenis herschrijven
- 7.7 Reset ontrafeld
- 7.8 Mergen voor gevorderden
- 7.9 Rerere
- 7.10 Debuggen met Git
- 7.11 Submodules
- 7.12 Bundelen
- 7.13 Vervangen
- 7.14 Het opslaan van inloggegevens
- 7.15 Samenvatting
-
8. Git aanpassen
- 8.1 Git configuratie
- 8.2 Git attributen
- 8.3 Git Hooks
- 8.4 Een voorbeeld van Git-afgedwongen beleid
- 8.5 Samenvatting
-
9. Git en andere systemen
- 9.1 Git als een client
- 9.2 Migreren naar Git
- 9.3 Samenvatting
-
10. Git Binnenwerk
- 10.1 Binnenwerk en koetswerk (plumbing and porcelain)
- 10.2 Git objecten
- 10.3 Git Referenties
- 10.4 Packfiles
- 10.5 De Refspec
- 10.6 Uitwisseling protocollen
- 10.7 Onderhoud en gegevensherstel
- 10.8 Omgevingsvariabelen
- 10.9 Samenvatting
-
A1. Bijlage A: Git in andere omgevingen
- A1.1 Grafische interfaces
- A1.2 Git in Visual Studio
- A1.3 Git in Visual Studio Code
- A1.4 Git in Eclipse
- A1.5 Git in Sublime Text
- A1.6 Git in Bash
- A1.7 Git in Zsh
- A1.8 Git in PowerShell
- A1.9 Samenvatting
-
A2. Bijlage B: Git in je applicaties inbouwen
- A2.1 Commando-regel Git
- A2.2 Libgit2
- A2.3 JGit
- A2.4 go-git
- A2.5 Dulwich
-
A3. Bijlage C: Git Commando’s
- A3.1 Setup en configuratie
- A3.2 Projecten ophalen en maken
- A3.3 Basic Snapshotten
- A3.4 Branchen en mergen
- A3.5 Projecten delen en bijwerken
- A3.6 Inspectie en vergelijking
- A3.7 Debuggen
- A3.8 Patchen
- A3.9 Email
- A3.10 Externe systemen
- A3.11 Beheer
- A3.12 Binnenwerk commando’s (plumbing commando’s)
4.7 Git op de server - GitWeb
GitWeb
Nu je gewone lees/schrijf en alleen-lezen toegang tot je project hebt, wil je misschien een eenvoudige web-gebaseerde visualisatie instellen. Git levert een CGI script genaamd GitWeb mee, dat soms hiervoor gebruikt wordt.
Als je wilt zien hoe GitWeb eruit ziet voor jouw project, kan je een commando wat met Git geleverd wordt gebruiken om een tijdelijke instantie op te starten als je een lichtgewicht server op je systeem hebt als lighttpd
of webrick
.
Op Linux machines is lighttpd
vaak geïnstalleerd, dus je zou in staat moeten zijn om het te laten lopen door git instaweb
in te typen in je project directory.
Als je een Mac gebruikt, Leopard heeft Ruby voor-geïnstalleerd, zou webrick
de beste gok kunnen zijn.
Om instaweb
te starten met een niet-lighttpd handler, kan je het aanroepen met de --httpd
optie.
$ git instaweb --httpd=webrick
[2009-02-21 10:02:21] INFO WEBrick 1.3.1
[2009-02-21 10:02:21] INFO ruby 1.8.6 (2008-03-03) [universal-darwin9.0]
Daarmee wordt een HTTPD server op poort 1234 opgestart en daarna een webbrowser die opent op die pagina.
Voor jou stelt dit niet veel voor.
Als je klaar bent en je de server weer wilt afsluiten, kan je hetzelfde commando met de --stop
optie aanroepen:
$ git instaweb --httpd=webrick --stop
Als je de web interface permanent op een server wilt hebben draaien voor je team of voor een open source project die je host, moet je je reguliere web server inrichten om het CGI script te serveren.
Sommige Linux distributies hebben een gitweb
package dat je wellicht met apt
of yum
kunt installeren, wellicht kan je dat eerst proberen.
We zullen spoedig het handmatig installeren van GitWeb bespreken.
Eerst zal je de Git broncode, waar GitWeb mee geleverd wordt, moeten verkrijgen, en het volgende maatwerk CGI script genereren:
$ git clone git://git.kernel.org/pub/scm/git/git.git
$ cd git/
$ make GITWEB_PROJECTROOT="/srv/git" prefix=/usr gitweb
SUBDIR gitweb
SUBDIR ../
make[2]: `GIT-VERSION-FILE' is up to date.
GEN gitweb.cgi
GEN static/gitweb.js
$ sudo cp -Rf gitweb /var/www/
Merk op dat je het commando moet vertellen waar je Git repositories gevonden kunnen worden met de GITWEB_PROJECTROOT
variabele.
Vervolgens moet je ervoor zorgen dat Apache CGI gebruikt voor dat script, daarvoor kan je een VirtualHost toevoegen:
<VirtualHost *:80>
ServerName gitserver
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>
Nogmaals: GitWeb kan worden geserveerd met elke web server die CGI of Perl ondersteunt, als je toch iets anders wilt gebruiken zou het niet al te moeilijk moeten zijn dit in te richten.
Nu zou je in staat moeten zijn om http://gitserver/
op te zoeken en je repositories online te zien.