2013-10-29 09:41:47 +00:00
\subsection { Git-Server}
2013-10-31 17:05:31 +00:00
\label { sub:git_ server}
2014-03-20 07:41:07 +00:00
Zur Verwaltung von \emph { Git} haben wir uns für \href { https://github.com/sitaramc/gitolite} { gitolite} entschieden. Dies erlaubt eine Verwaltung von Zugriffsrechten auf Repositories.
Die Authentifizierung erfolgt dabei über SSH-Keys. Hier für wird ein \emph { git} Nutzer eingerichtet:
2013-10-31 17:05:31 +00:00
\shellcmd { useradd -m -U -r -s /bin/bash -d /srv/git git}
Für die initiale Einrichtung wird der eigene SSH-Schlüssel zu gitolite hinzugefügt:
2013-11-03 17:20:54 +00:00
\shellcmd { gitolite setup -pk id\_ rsa.pub}
2013-10-31 17:05:31 +00:00
Nun kann die eigentliche Konfiguration per git heruntergeladen werden:
2013-11-07 12:34:31 +00:00
\shellcmd { git clone git@141.76.90.104:gitolite-admin.git}
2013-10-31 17:05:31 +00:00
2014-03-20 07:41:07 +00:00
Wir legten in dieser Konfiguration das Repository \emph { lctp} an und gaben allen
2013-11-07 12:34:31 +00:00
Benutzern Zugriff darauf. Die gitolite-Konfiguration befindet sich als
2014-03-20 07:41:07 +00:00
Git-Submodule im Verzeichnis \emph { aufgabe2.4/gitolite-admin} .
2013-11-11 14:30:12 +00:00
Das lctp-Repository wiederum lässt sich mit folgendem Befehl clonen:
2013-11-07 12:34:31 +00:00
2013-11-11 14:30:12 +00:00
\shellcmd { git clone git@141.76.90.104:lctp.git lctp-gruppe4}
2013-10-31 17:05:31 +00:00
2013-11-11 14:30:12 +00:00
\shellcmd { cd lctp-gruppe4 \& \& git submodule init \& \& git submodule update}
2013-11-08 08:59:56 +00:00
2013-11-05 09:50:33 +00:00
\subsubsection { etckeeper}
2013-10-31 17:05:31 +00:00
2014-03-20 07:41:07 +00:00
Um die Konfiguration in \emph { /etc } versionierbar und damit nachvollziehbar zu machen installierten wir \emph { etckeeper} :
2013-10-31 17:05:31 +00:00
\shellcmd { yaourt -S etckeeper \& \& sudo etckeeper init}
2013-11-11 14:30:12 +00:00
\shellcmd { cd /etc/.git \& \& sudo git remote add git@zotac0:lctp.git}
2013-11-07 12:34:31 +00:00
2014-03-20 07:41:07 +00:00
Dieses legt ein \emph { git} -Repository in \emph { /etc/.git} an und erstellt Commits bei Änderungen in \emph { /etc} .
2014-03-29 20:04:42 +00:00
Um die Konfiguration vom Bericht zu trennen, haben wir uns entschieden, \texttt {
2014-03-20 07:41:07 +00:00
etckeeper} in ein dediziertes Repository (\emph { logs} ) pushen und als Submodule
im \emph { lctp} -Repository einzubinden:
2013-11-07 12:34:31 +00:00
2013-11-11 14:30:12 +00:00
\shellcmd { sudo git remote add origin git@zotac0:etckeeper.git}
2013-11-07 12:34:31 +00:00
2014-03-20 07:41:07 +00:00
Anders als bei anderen Paketmanagern wie \emph { apt} auf Debian, existieren in \emph { pacman} (\ref { sec:pacman} )
2013-10-31 17:05:31 +00:00
keine Hooks.
2013-11-13 14:31:08 +00:00
Um dennoch nach Systemaktualisierungen oder Paketinstallationen automatisch die
neue Konfiguration zu commiten haben wir jeweils einen
2014-03-20 07:41:07 +00:00
\href { https://gist.github.com/Mic92/7250403} { Wrapper-Script} für \emph { pacman}
und \emph { yaourt} geschrieben und diese \emph { /usr/local/bin} abgelegt. Da in der
2014-03-29 20:04:42 +00:00
Shell \emph { /usr/local/bin} für gewöhnlich eine höhere Priorität hat als \texttt {
2013-11-13 14:31:08 +00:00
/usr/bin} werden Programme in diesem Verzeichnis vorrangig ausgeführt. (Die
Wrapper befinden sich in \emph { aufgabe2.4/yaourt} sowie in \emph { aufgabe2.4/pacman} ).
2013-11-07 12:34:31 +00:00
Darüber hinaus haben wir das Shell-Script für tägliche automatische Commits,
welches im
\href { https://github.com/joeyh/etckeeper/blob/master/debian/cron.daily} { Git-Repository}
(Stand 07.11.2013)
2014-03-20 07:41:07 +00:00
von \emph { etckeeper} liegt, als cronjob installiert (siehe
2013-11-13 14:31:08 +00:00
\emph { aufgabe2.4/cron.daily/etckeeper} ).
2013-11-11 14:30:12 +00:00
2013-10-31 17:05:31 +00:00
\subsubsection { Logs in git}
2014-03-20 07:41:07 +00:00
Arch Linux setzt in der Standard-Installation \emph { journald} als Logging-Daemon ein. Dieses benutzt im Unterschied zu herkömmlichen Syslog-Varianten ein Binärformat zum Speichern.
2013-11-07 12:34:31 +00:00
Dieses Dateiformat eignet sich aus offensichtlichen Gründen nicht um mithilfe
2014-03-20 07:41:07 +00:00
von git verwaltet zu werden. Deswegen haben wir zusätzlich \emph { syslog-ng}
installiert und \emph { journald} so konfiguriert, das dieses ebenfalls in das
2013-11-13 14:31:08 +00:00
syslog schreibt (siehe \emph { aufgabe2.4/journald.conf} ).
2014-03-20 07:41:07 +00:00
Für tägliche commits haben wir hierfür das Shell-Script \emph { git-commit-log}
nach \emph { /etc/cron.daily/} installiert (siehe
2013-11-13 14:31:08 +00:00
\emph { aufgabe2.4/cron.daily/git-commit-log} ). Dieses pusht die Log-Dateien in das
2014-03-20 07:41:07 +00:00
logs-Repository. Es ist als Submodule im Verzeichnis \emph { logs} im
2013-11-11 14:30:12 +00:00
lctp-Repository eingebunden.