Dieses Repository behandelt die Installation von Apache, MySQL, MongoDB und NodeJS auf einer Vagrant Box mit dem Ubuntu-Server (Version 14.04) als OS.
Die nachstehende Dokumentation wurde von Michael Blickenstorfer im Rahmen des Moduls M300 (Plattformübergreifende Dienste in ein Netzwerk integrieren) erarbeitet und zeigt alle Schritte auf, die es zur Einrichtung eines vollständig funktionsfähigen Web-Servers mit Apache und einer MySQL-DB benötigt.
Datum | Änderungen | Kürzel |
---|---|---|
22.08.2018 | Erstellung des Repositorys und der README.md-Datei | MBL |
23.09.2018 | Einleitung, Voraussetzungen, Inhaltsverzeichnis & Kapitel 1 erarbeitet | MBL |
25.09.2018 | Restliche Kapitel fertiggestellt | MBL |
20.10.2018 | Verknüpfungen angepasst | MBL |
31.10.2018 | Kleinere Verbesserungen vorgenommen | MBL |
... | ... | ... |
- macOS High Sierra (Version 10.13.6)
- VirtualBox (Version 5.2.18)
- Vagrant (Version 2.1.4)
- Vagrant Box "ubuntu/trusty64"
- 01 - Linux
- 02 - Versionsverwaltung
- 03 - Apache & MySQL
- 04 - NodeJS & MogoDB
- 05 - Software-Konfiguration
- 06 - Service-Konfiguration
- 07 - Reflexion
Ziel dieses Abschnitts ist die Einrichtung der Vagrant Box mit dem Betriebssystem "Ubuntu-Server 14.04"
Folgende Arbeiten müssen gemacht werden:
- Webbrowser öffnen
- Auf www.app.vagrantup.com/boxes/search können alle öffentlich verfügbaren Vagrant-Boxen eingesehen werden. In diesem Fall suchen wir nach "ubuntu/trusty64".
- Nach einem Klick auf die Box findet man unter "How to use this box with Vagrant:" eine Anleitung zur Einrichtung einer VM
- Im Tab "New" wird gezeigt, wie eine komplett neue VM mit dieser Box eingerichtet wird:
$ vagrant init ubuntu/trusty64 $ vagrant up
- Da wir jetzt wissen, wie die Box heisst, können wir mit dem Abschnitt "VM erstellen" fortfahren
- Terminal öffnen
- In gewünschtes Verzeichnis wechseln, wo die VM anschliessend erzeugt werden soll (mit cd Pfad/zu/meiner/VM)
- Ordner für die VM erstellen (mkdir ubuntu-server)
- In Ordner wechseln (cd ubuntu-server) und nachfolgende Befehle ausführen:
$ vagrant init ubuntu/trusty64 $ vagrant up
- Die VM ist soweit betriebsbereit und kann per SSH-Verbindung gesteuert werden:
$ vagrant ssh Welcome to Ubuntu 14.04.5 LTS (GNU/Linux 3.13.0-158-generic x86_64) (...)
- System-Updates durchführen:
$ sudo apt-get update $ sudo apt-get upgrade
- Maschine herunterfahren:
$ sudo shutdown -h now The system is going down for halt NOW! Connection to 127.0.0.1 closed by remote host. Connection to 127.0.0.1 closed.
- Terminal schliessen & mit nachfolgendem Abschnitt weiterfahren
-
Virtual Box öffnen
-
Erstellte Vagrant-VM (Virtuelle Maschine) anwählen und im oberen Menü auf "Ändern" klicken
-
Zum Abschnitt "Netzwerk" wechseln und "> Erweitert" aufklappen
-
Den Button "Port-Weiterleitung" anwählen
-
Im neuen Fenster in der rechten Leiste auf das (+) Plus-Symbol klicken
-
Folgende Einträge machen:
Name Protokoll Host-IP Host-Port Gast-IP Gast-Port Apache
TCP
127.0.0.1
8080
NULL 80
-
Änderungen übernehmen und Fenster schliessen
-
Im Terminal mit folgendem Befehl die VM wieder starten:
$ vagrant up
-
SSH-Verbindung aufbauen:
$ vagrant ssh
-
Mit Abschnitt "Bash" fortfahren
Bash steht für Bourne-again shell und ist eine quelloffene Unix-Shell und Teil des GNU-Projekts. Sie ist heute auf vielen unixoiden Systemen die Standard-Shell.
Administration
Befehl | Beschreibung |
---|---|
sudo [-i] |
Superuser werden (-i = permanent für aktive Session) |
`sudo service start | stop` |
sudo shutdown -r now |
OS-Restart (Neustart) |
sudo shutdown -h now |
OS-Shutdown (Herunterfahren) |
Filesystem
Befehl | Beschreibung |
---|---|
ls |
Verzeichnis-Inhalt anzeigen (list) |
rm |
Datei oder Verzeichnis entfernen (remove) |
mv |
Datei oder Verzeichnis verschieben (move) |
cd |
In Verzeichnis wechsel (change directory) |
nano |
Texteditor (z.B. für das Anzeigen von index.html) |
df -h |
Diskbelegung |
free -m |
Arbeitsspeicher-Belegung (RAM) |
w |
Auslastung CPU |
Netzwerk
Befehl | Beschreibung |
---|---|
ifconfig |
Ausgabe der eigenen konfigurierten IP-Parameter (z.B. IP-Adresse) |
netstat -a |
Ausgabe verwendeter Netzwerk-Ports |
netstat -tulpen |
dito |
net lookup <hostname> |
Namensauflösung eines Hosts (z.B. google.com) |
Prozesse
Befehl | Beschreibung |
---|---|
ps -ef |
Anzeige aktiver Prozesse |
top |
dito (top = table of processes) |
kill <pid> |
Prozess gem. Prozess-ID beenden |
Hilfsprogramme
Programm | Befehl | Beschreibung |
---|---|---|
curl | curl http://<server> |
Webseite oder HTTP REST Service aufrufen & Inhalt ausgeben |
wget | wget http://<server>/<datei> |
Datei von einem Webserver kopieren |
dos2unix | dos2unix <Datei> |
Datei von DOS ins UNIX/Linux Format umwandeln (z.B. nach Kopie von Windows-System) |
Weiter Informationen und Befehle unter: www.linuxcommand.org/lc3_lts0060.php
Das Advanced Packaging Tool (APT) ist ein Paketverwaltungssystem, das im Bereich des Betriebssystems Debian GNU/Linux entstanden ist und dpkg (Debian Package Manager) zur eigentlichen Paketverwaltung nutzt. Ziel ist es, eine einfache Möglichkeit zur Suche, Installation und Aktualisierung von Programmpaketen zur Verfügung zu stellen.
APT besteht aus einer Programmbibliothek und mehrere dieser Bibliothek nutzenden Komandozeilen-Programmen, von denen apt-get und apt-cache zentral sind. Seit Debian 3.1 wird die Benutzung von aptitude als konsolenbasierendes Paketverwaltungssystem empfohlen.
In der Datei /etc/apt/sources.list stehen die sogenannte Repositories, also Quellen für Pakete. Dies können entweder CDs oder DVDs, Verzeichnisse auf der Festplatte oder hauptsächlich Verzeichnis auf HTTP- und FTP-Servern sein. Befindet sich das gesuchte Paket auf einem Server (oder einem lokalen Datenträger), so wird dieses automatisch heruntergeladen und installiert (bei apt-get install ).
Die Pakete liegen im Debian-Paketformat (.deb) vor, in dem auch die jeweiligen Abhängigkeiten der Programmpakete untereinander abgelegt sind. So werden automatisch für ein Programm auch eventuell erforderliche Programmbibliotheken mit heruntergeladen und intalliert.
APT-Befehle
Befehl | Beschreibung |
---|---|
sudo apt-get update |
Repositories aktualisieren |
sudo apt-get -y upgrade |
Installierte Software aktualisieren |
sudo apt-get -y autoremove |
Aufräumen -> Nicht mehr benötigte Software entfernen |
sudo apt-get -y install apache2 |
Programmpaket installieren (hier Apache2 Webserver) |
sudo apt-cache search [keyword] |
Nach bestimmten Programmpaket suchen |
sudo dpkg -i [Programmpaket] |
Programmpaket installieren, was zuvor heruntergeladen wurde |
Das Kommandozeilen-Programm cURL (Client for URLs / Curl URL Request Library) dient zur Übertrgung von Dateien in Rechnernetzen. Es ist Bestandteil der meisten Linux-Distributionen und auch von Mac OS X. Die zugehörige Programmbibliothek libcurl wird von zahlreichen Programmen und Programmiersprachen verwendet.
Aktive Ports/Services mit cURL testen
cURL eignet sich auch zum Testen von aktiven Ports oder Services auf entsprechenden Servern. Dazu eignet sich am besten die -f
(HTTP -> Fail silently | no output at all)
Option.
Hier eine kleine Befehlszeile, die testet, ob ein Webserver auf Port 8080 läuft (Ausgabe "running") und wenn nicht, "stopped" ausgibt:
$ curl -f http://localhost:8080 >/dev/null 2>&1 && { echo "running"; } || { echo "stopped"; } }
Langform (in Skript):
curl -f http://localhost >/dev/null 2>&1
if [ $? -eq 0 ]
then
echo "running"
else
echo "stopped"
fi
Skript erstellen
- Terminal öffnen
- Mit SSH auf VM verbinden
- Shellscript mit nano erstellen:
$ sudo nano myscript
- Folgenden Inhalt einfügen:
#!/bin/bash
#
# Endlosscript wo Testet ob der Apache Webserver läuft
while [ 1 ]
do
curl -f http://localhost >/dev/null 2>&1
if [ $? -eq 0 ]
then
echo "running"
else
echo "stopped"
fi
done
- Datei mit
CTRL + X + y + [Enter]
speichern & schliessen - Script starten:
$ bash myscript
- Script mit
CTRL + C
wieder beenden
Linux
Als Linux bezeichnet man in der Regel freie, unix-ähnliche Betriebssysteme, die auf dem Linux-Kernel und wesentlich auf GNU-Software basieren. Beim Gebrauch auf Computern kommmen meist sogenannte Linux-Distributionen zum Einsatz. Eine Distribution fasst den Linux-Kernel mit verschiedener Software zu einem Betriebssystem zusammen, das für die Endnutzung geeignet ist. Dabei passen viele Distributionen und versierte Benutzer den Kernel an ihre eigenen Bedürfnisse an.
Bash
Bash (Bounre-again shell) ist eine freie Unix-Shell und Teil des GNU-Projekts. Sie ist heute auf vielen unixoiden Systemen die Standard-Shell.
APT
Das Advanced Packaging Tool (APT) ist ein Paketverwaltungssystem, das im Bereich des Betriebssystems Debian GNU/Linux entstanden ist und dpkg zur eigentlichen Paketverwaltung nutzt. Ziel ist es, eine einfache Möglichkeit zur Suche, Installation und Aktualisierung von Programmpaketen zur Verfügung zu stellen.
cURL
cURL (Client for URLS / Curl URL Request Library) ist ein Kommandozeilen-Programm zum Übertragen von Dateien in Rechnernetzen.
Eine Versionsverwaltung ist ein System, das zur Erfassung von Änderungen an Dokumenten oder Dateien verwendet wird. Alle Versionen werden in einem Archiv mit Zeitstempel und Benutzerkennung gesichert und können später wiederhergestellt bzw. abgerufen werden. Versionsverwaltungssysteme werden typischerweise in der Softwareentwicklung eingesetzt, um Quelltexte zu verwalten. Allerdings werden solche Systeme auch bei Büroanwendungen oder Content-Management-Systeme (CMS) eingesetzt. Bekannte Vertreter sind Git (verteiltes System) oder der Team Foundation Server (zentrales System).
- Protokollierung der Änderungen:
Es kann jederzeit nachvollzogen werden, wer wann was geändert hat.
- Wiederherstelltung von alten Ständen einzelner Dateien:
Somit können versehentliche Änderungen jederzeit wieder rückgängig gemacht werden.
- Archivierung der einzelnen Stände eines Projektes:
Dadurch ist ges jederzeit möglich, auf alle Versionen zuzugreifen
- Koordinierung des gemeinsamen Zugriffs von mehreren Entwicklern auf die Dateien.
- Gleichzeitige Entwicklung mehrerer Entwicklungszweige (engl. Branches) eines Projektes.
Ein Repository (engl. Lager, Depot oder auch Quelle), ist ein verwaltetes Verzeichnis zur Speicherung und Beschreibung digitaler Objekte für ein digitales Archiv. Bei den verwalteten Objekten kann es sich beispielsweise um Programme (Software-Repository), Publikationen (Dokumentserver), Datenmodelle (Metadaten-Repository) oder betriebswirtschaftliche Verfahren handeln. Häufig beinhaltet ein Repository auch Funktionen zur Versionsverwaltung der digitalen Objekte.
Git
Git ist eine freie Software zur verteilten Versionsverwaltung von Dateien, die durch Linus Trovalds initiiert wurde.
GitHub
GitHub ist ein webbasierter Online-Diens, der Software-Entwicklungsprojekte auf seinen Servern bereitstellt. Namensgebend war das Versionsverwaltungssystem Git. Zusätzlich bietet der Dienst diverse Management und Bug-Tracking-Funktionalitäten.
GitLab
GitLab ist ebenfalls eine Webanwendung zur Versionsverwaltung für Softwareprojekte auf Basis von Git. Sie bietet diverse Management und Bug-Tracking-Funktionalitäten, sowie mit GitLab CI ein System zur kontinuierlichen Integration.
Markdown ist eine vereinfachte Auszeichnungssprache.
Ein Ziel von Markdown ist, dass schon die Ausgangsform ohne weitere Konvertierung leich lesbar ist. Als Auszeichnungselemente wurden daher vor allem Auszeichnungsarten verwendet, die in Klartext und E-Mails üblich sind.
Genutzt wird Markdown vorwiegend auf Plattformen mit eher technikaffinem Publikum wie GitHub, Stack Overflow oder der Blogging-Plattform Ghost. Markdown wird ausserdem häufig bei Readme-Dateien verwendet.
Markdown-Dateien (.md) können über die Weboberfläche von GitLab oder GitHub editiert werden. Alternativen sind die Wiki-Erweiterungen von Eclipse, der GitBook Editor oder Visual Studio Code.
Repository
Ein Repository ist ein verwaltetes Verzeichnis zur Speicherung und Beschreibung von digitalen Objekten für ein digitales Archiv. Bei den verwalteten Objekten kann es sich beispielsweise um Programme (Software-Repository), Publikationen (Dokumentenserver), Datenmodelle (Metadaten-Repository) oder betriebswirtschaftliche Verfahren handeln. Häufig beinhaltet ein Repository auch Funktionen zur Versionsverwaltung der verwalteten Objekte.
Git
Git ist eine freie Software zur verteilten Versionsverwaltung von Dateien, die durch Linus Torvalds initiiert wurde.
GitHub
GitHub ist ein webbasierter Online-Dienst, der Software-Entwicklungsprojekte auf seinen Servern bereitstellt. Namensgebend war das Versionsverwaltungssystem Git. Zusätzlich bietet er diverse Management und Bug-Tracking-Funktionalitäten.
GitLab
GitLab ist eine Webanwendung zur Versionsverwaltung für Softwareprojekte auf Basis von git. Sie bietet diverse Management und Bug-Tracking-Funktionalitäten, sowie mit GitLab CI ein System zur kontinuierlichen Integration.
Markdown
Markdown ist eine vereinfachte Auszeichnungssprache deren Ziel es ist, dass schon die Ausgangsform ohne weitere Konvertierung leicht lesbar ist.
Nach den vorhergehenden Theorie-Inputs geht es nun mehr und mehr in die Praxis. In diesem Abschnitt wird der Apache Webserver installiert und die MySQL-Datenbank auf der Vagrant-VM eingerichtet.
LAM steht für Linux-, Apache- & MySQL-Server. Mit dieser Kombination wird eine Datenablageplattform geschaffen, die beispielsweise für Sensordaten verwendet werden kann.
Der LAM-Server wird "REST-fähig" gemacht, damit Daten in eine Serverdatei und in eine MySQL-Datenbank geschrieben werden können.
Der Apache HTTP Server ist ein quelloffenes und freies Produkt der Apache Software Foundation und der meistbenutzte Webserver im Internet.
Apache kann sehr gut mit sogenannten Modulen erweitert werden, die bestimmte Zusatzfunktionen mitbringen und immer mit 'mod_' beginnen (z.B. mod_rewrite, mod_php5, mod_ssl).
Es gibt u.a. Module für:
- SSL:
mod_ssl
für OpenSSLmod_gnutls
für GnuTLS
- Dynamische Skript- & Programiersprachen:
mod_php5
mod_perl
mod_python
- Protokolle (z.B. WebDAV):
mod_dav
mod_dav_fs
mod_dav_lock
mod_dav_repos
- Authentifizierung:
mod_auth
- Proxy:
mod_proxy
Installiert wird der Webserver (Apache) inkl. dem CGI-Modul wie folgt:
-
Terminal öffnen
-
Vagrant-VM starten:
$ vagrant up
-
SSH-Verbindung aufbauen (zur VM):
$ vagrant ssh
-
Apache-Webserver inkl. Dokumentation installieren:
$ sudo apt-get install apache2 apach2-doc
-
CGI-Modul hinzufügen:
$ sudo a2enmod gi
Hier kann es zu folgender "Fehlermeldung" kommen: Die Meldung kann aber gemäss diesem Forum-Post ignoriert werden.
-
Service-Neustart durchführen:
$ sudo service apache2 restart
-
Mit Dokumentation fortfahren (...)
Die Inhalte für den Server werden in einem als "document root" bezeichneten Verzeichnis abgespeichert. Dies bedeutet, dass der Apache Webserver dort nach den auszuliefernden (HTML-)Dateien Ausschau hält.
In einem Linux-System befindet sich der Document-Root unter /var/www/html
Von der Client-Seite werden die dort abgelegten Dateien, im Browser, mittels http://Host-IP-Adresse/ abgerufen. In unserer lokalen Vagrant VM lässt sich dies über den Localhost, also http://localhost/ bewerkstelligen.
Weiter geht es mit dem HTTP-Protokoll. Das Hypertext Transfer Protcol (HTTP) ist ein Protkoll zur Übertragung von Nachrichten und Daten. Es wird hauptsächlich eingesetzt, um Webseiten (Hypertext-Dokumente) aus dem WWW (World Wide Web) in einen Webbrowser zu laden. Es ist jedoch nicht prinzipiell darauf beschränkt und auch als allgemeines Übertragungsprotkoll weitverbreitet.
Jede Nachricht besteht dabei aus zwei Teilen, dem Nachrichtenkopf (Message Header) und dem Nachrichtentrumpf (Message Body). Der Nachrichtenkopf enthält die Anfragemethode und Informationen über den Nachrichtentrumpf, wie etwa verwendete Kodierungen oder den Inhaltstyp. Der Nachrichtentrumpf enhält entsprechend die Nutzdaten.
Von den Nachrichten gibt es zwei unterschiedliche Arten: die Anfrage (engl. Request) vom Client an den Server und die Antwort (engl. Response) als Reaktion darauf, vom Server zum Client.
HTTP dient zum Anfordern, Schreiben und Löschen von Daten bzw. Dateien auf einem Webserver, der das HTTP-Protokoll unterstützt.
- GET
Ist die gebräuchlichste Methode. Mit ihr wird eine Ressource (z.B. HTML-Datei) vom Server angefordert.
- POST
Schickt die Daten zur weiteren Verarbeitung zum Server.
- PUT
Dient dazu eine Ressource (z.B. eine Bilddatei) auf einen Webserver hochzuladen.
- DELETE
Löscht die angegebene Ressource auf dem Server.
Heute ist PUT, ebenso wie DELETE, kaum implementiert. Beides erlangt mit dem REST Programmierparadigma eine neue Bedeutung.
Die Hypertext Markup Language (HTML) ist eine textbasierte und maschinenlesbare Sprache, die zur Strukturierung digitaler Dokumente - wie etwa Texte mit Hyperlinks, Bildern und anderen Inhalten - eingesetzt wird.
HTML-Dokumente sind die Grundlage des World Wide Webs (WWW) und werden zur graphischen Darstellung durch die Webbrowser benötigt.
REST steht für Representational State Transfer und bezeichnet ein Programmierparadigma (grundsätzliche Denkweise) für verteilte Systeme.
Mit REST versteht man eine eine Abstraktion der Struktur und des Verhaltens des World Wide Web (HTTP GET, PUT, POST, DELETE).
Das Programmierparadigma hat das Ziel, einen Architekturstil zu schaffen, der die Anforderungen des modernen Web besser darstellt. Dabei unterscheidet sich REST vor allem in der Forderung nach einer einheitlichen Schnittstelle von anderen Architekturstilen.
Wichtig: Wird über das HTTP-Protokoll zugegriffen, entsprechen die REST-Operationen den HTTP-Abfragemethoden.
Alle bauen APIs (Programmierschnittstellen). Grob geschätzt bestehen 80% Prozent der heute entwickelten Anwendungen im Kern aus einer oder mehreren serverseitigen Komponenten, die Geschäftslogik kapseln und diese ihren Clients über eine RESTful API zur Verfügung stellen. Ist das REST-Paradigma einmal verstanden, dann sind REST-APIs klar und einfach zu benutzen.
Den fachlichen Hintergrund des Beispiel-API bildet ein einfaches Shop-System. Das Domainmodell des Shops besteht aus den Entitäten Customer, Order und Product. Die untenstehende Abbildung zeigt deren Beziehungen, URIs sowie JSON-Repräsentationen:
Eine Ressource im REST-Kontext ist eine Abstraktion, die ein "Ding" referenziert. Dieses Ding kann z.B. ein einzelner Kunde, eine Liste aller Kunden oder auch eine Liste von Kunden mit dem Namen 'Meier' sein. Ressourcen werden über URIs identifiziert. So identifiziert der URI /customers
die Liste aller Kunden und die Ressource /customer/1
den Kunden mit der ID 1. Neben einer Identität besitzen Ressourcen eine oder mehrere Repräsentationen. In diesem Anwendungsbeispiel werden Ressourcen in JSON repräsentiert und in diesem Format auch zwischen Client und Server übertragen.
Beziehungen zwischen Ressourcen werden über Links beschrieben. Für HTML-repräsentierte Ressourcen wird häufig das HTML-Element verwendet, während in JSON-Repräsentationen verlinkte Resourcen als Listen von IDs beschrieben werden.
Das Anfragen, Anlegen Verändern und Löschen von Ressourcen erfolgt über die bekannten HTTP-Methoden, die im REST-Kontext auch als HTTP-Verben bezeichnet werden. So liefert beispielsweise GET /customers/1/orders/9
die Bestellung mit der ID 9, während DELETE /customers/1/orders/9
diese Bestellung löscht.
Das Common Gateway Interface (CGI) ist ein Standard für den Datenaustausch zwischen einem Webserver und dritter Software, die Anfragen bearbeitet. CGI ist eine schon länger bestehende Variante, Webseiten dynamisch bzw. interaktiv zu machen.
Da wir auf dem Webserver das CGI-Modul bereits geladen haben, können wir nun ein entsprechendes Skript auf dem Webserver ablegen. Dieses ist in diesem Repository bereits unter cgi-rest-script.txt
abgelegt. Nach dem Download, kann mit folgenden Schritten fortgefahren werden:
- Terminal öffnen
- Vagrant-VM starten:
$ vagrant up
- SSH-Verbindung aufbauen (zur VM):
$ vagrant ssh
- Unterordner im Verzeichnis
/usr/lib/cgi-bin
erstellen:$ sudo mkdir `/usr/lib/cgi-bin/rest`
- In das Verzeichnis
/usr/lib/cgi-bin/rest
wechseln und das Skript einfügen bzw. erstellen:$ cd /usr/lib/cgi-bin/rest $ sudo nano cgi-rest-script.txt # Nun den Inhalt einfügen & das Script speichern!
- Ordner
data
im Verzeichnis/var/www/html
erstellen:$ sudo mkdir /var/www/html/data # Ordner erstellen $ sudo chown www-data:www-data /var/www/html/data # Bereichtigungen für Apache-Servicebenutzer anpassen
- Script ausführbar machen:
$ sudo chmod +x /usr/lib/cgi-bin/rest/cgi-rest-script.txt
- Script-Datei mit
dos2unix
'formatieren':$ sudo dos2unix /usr/lib/cgi-bin/rest/cgi-rest-script.txt
Nun kann das Script zusammen mit cURL ausgetestet werden. Dazu müssen alle nachfolgenden Beispiele durchgeführt werden. Anschliessend können die geschriebenen Daten unter http://localhost:8080/data/ abgerufen werden.
GET - Daten vom Server lesen
curl http://localhost/cgi-bin/rest/cgi-rest-script.txt
curl http://localhost/cgi-bin/rest//cgi-rest-script.txt/timestamp
POST - Daten auf Server schreiben
curl -v -X POST http://localhost/cgi-bin/rest/cgi-rest-script.txt -d "poti=0.5&hall=0.1&light=0.8&temp=26"
PUT - Datei inkl. Inhalt auf Server erstellen
curl -v -X PUT http://localhost/cgi-bin/rest/cgi-rest-script.txt?test.txt -d "Das sind Daten fuer den Server"
DELETE - Datei vom Server löschen
curl -v -X DELETE http://localhost/cgi-bin/rest/cgi-rest-script.txt?test.txt
Eine Datenbank, auch Datenbanksystem (DBS) genannt, ist ein System zur elektronischen Datenverwaltung. Die wesentliche Aufgabe eines DBS ist es, grosse Datenmengen effizient, wiederspruchsfrei und dauerhaft zu speichern und benötigte Teilmengen in unterschiedlichen, bedarfsgerechten Darstellungsformen für Benutzer und Anwendungsprogramme bereitszustellen.
MySQL ist eines der weltweit verbreitesten relationalen Datenbankverwaltungssysteme . Es ist als Open-Source-Software sowie als komerzielle Enterprise Version für verschiedene Betriebssysteme verfügbar und bildet die Grundlage für dynamische Webauftritte.
- Terminal öffnen
- Vagrant-VM starten:
$ vagrant up
- SSH-Verbindung aufbauen (zur VM):
$ vagrant ssh
- MySQL-Anwendungen installieren & dabei Zugangspasswort festelegen:
$ sudo apt-get install mysql-server mysql-client
- Mit der Konfiguration fortfahren (...)
- Beim Datenbankserver anmelden:
$ mysql -u root -p [mein Passwort]
- Datenbank
sensoren
anlegen:> CREATE DATABASE IF NOT EXISTS sensoren;
- DB-Benutzer
www-data
mit dem Passwortmbed
erstellen:> create user 'www-data'@'localhost' identified by 'mbed'; > grant usage on *.* to 'www-data'@'localhost' identified by 'mbed';
- Zugriff auf die Datenbank
sensoren
erteilen:> grant all privileges on sensoren.* to 'www-data'@'localhost'; > flush privileges;
- Datenbank wechseln:
> use sensoren;
- Tabelle
data
für die Sensordaten erstellen:> create table data ( seq INT PRIMARY KEY AUTO_INCREMENT, poti FLOAT, light FLOAT, hall FLOAT, temp FLOAT, created TIMESTAMP DEFAULT CURRENT_TIMESTAMP );
- Testdaten einlesen:
> insert into data(poti, light, hall, temp) values ( 0.9, 0.8, 0.49, 25.2 ); > insert into data(poti, light, hall, temp) values ( 0.8, 0.7, 0.48, 25.1 );
- Weitere Abfragen durchführen:
# lesen (alle Daten) > select * from data; # Mittelwert vom Temperaturwert ausgeben > select avg(temp) from data; # Kleinster Wert vom Temperaturwert ausgeben > select min(temp) from data; # Grösster Wert vom Temperaturwert ausgeben > select max(temp) from data;
- Abmelden:
> quit;
Das nachfolgende CGI-Script empfängt die Daten via HTTP POST, bereitet diese als SQL-Statement auf und schreibt die Daten in die Datenbank. Wie auch das vorherige Script, kann dieses vom Repository heruntergeladen und eingefügt werden.
- Terminal öffnen
- Vagrant-VM starten:
$ vagrant up
- SSH-Verbindung aufbauen (zur VM):
$ vagrant ssh
- Unterordner im Verzeichnis
/usr/lib/cgi-bin
erstellen:$ sudo mkdir `/usr/lib/cgi-bin/restsql`
- Ins Verzeichnis wechseln und das Skript einfügen bzw. erstellen:
$ cd /usr/lib/cgi-bin/restsql $ sudo nano cgi-rest-sql-script.txt # Nun den Inhalt einfügen & das Script speichern!
- Script ausführbar machen:
$ sudo chmod +x /usr/lib/cgi-bin/restsql/cgi-rest-sql-script.txt
- Script-Datei mit
dos2unix
'formatieren':$ sudo dos2unix /usr/lib/cgi-bin/restsql/cgi-rest-sql-script.txt
Nun kann dieses Script ebenfalls zusammen mit cURL ausgetestet werden. Dazu muss das nachfolgende Beispiel durchgeführt werden. Anschliessend können die geschriebenen Daten unter http://localhost/cgi-bin/restsql abgerufen werden.
POST - Daten auf Server schreiben
curl -v -X POST http://localhost/cgi-bin/restsql -d "poti=0.5&hall=0.1&light=0.8&temp=26"
cURL (Client for URLs / Curl URL Request Library) ist ein Kommandozeilen-Programm zum Übertragen von Dateien in Rechnernetzen. Das Programm cURL steht unter der offenen MIT-Lizenz und ist auf verschiedene Betriebssysteme portiert worden. Es ist Bestandteil der meisten Linux-Distributionen und auch von Mac OS X. Die zugehörige Programmbibliothek libcurl wird von zahlreichen Programmen und Programmiersprachen verwendet.
Mittels einer Kombination von Linux (Ubuntu basiert auf Linux bzw. Debian), dem Web-Server Apache und der relationalen Datenbank MySQL bauten wir eine Datenablageplattform für Sensordaten.
Dazu haben wir verwendet:
HTTP
Das Hypertext Transfer Protocol (HTTP) ist ein Protokoll zur Übertragung von Nachrichten und Daten. Es wird hauptsächlich eingesetzt, um Webseiten (Hypertext-Dokumente) aus dem World Wide Web (WWW) in einen Webbrowser zu laden. Es ist jedoch nicht prinzipiell darauf beschränkt und auch als allgemeines Dateiübertragungsprotokoll sehr verbreitet.
REST
Representational State Transfer (REST) bezeichnet ein Programmierparadigma für verteilte Systeme. REST ist eine Abstraktion der Struktur und des Verhaltens des World Wide Web. REST fordert, dass eine Web-Adresse genau einen Seiteninhalt repräsentiert, und dass ein Web-/REST-Server auf mehrfache Anfragen mit demselben URI auch mit demselben Webseiteninhalt antwortet.
CGI
Das Common Gateway Interface (CGI) ist ein Standard für den Datenaustausch zwischen einem Webserver und dritter Software, die Anfragen bearbeitet. CGI ist eine schon länger bestehende Variante, Webseiten dynamisch bzw. interaktiv zu machen, deren erste Überlegungen auf das Jahr 1993 zurückgehen.
MySQL
MySQL ist eines der weltweit verbreitetsten relationalen Datenbankverwaltungssysteme. Es ist als Open-Source-Software sowie als kommerzielle Enterprise Version für verschiedene Betriebssysteme verfügbar und bildet die Grundlage für viele dynamische Webauftritte.
Durch das Zusammenspiel von REST und CGI kann ein HTTP Server dynamisch (HTTP GET) Inhalte anzeigen und Daten mittels HTTP POST, PUT oder DELETE empfangen. Die Methoden GET, POST, PUT und DELETE entsprechen dem REST-Paradigma.
Neben MySQL kann auch die MongoDB-Anwendung eingesetzt werden. Dieser Variante widmen wir uns nun in diesem Kapitel.
Node.js ist eine serverseitige Plattform in der Softwareentwicklung zum Betrieb von Netzwerkanwendungen. Insbesondere Webserver lassen sich damit realisieren.
Node.js wird in der JavaScript-Laufzeitumgebung "V8" ausgeführt, die ursprünglich für Google Chrome entwickelt wurde, und bietet daher eine ressourcensparende Architektur, die eine besonders große Anzahl gleichzeitig bestehender Netzwerkverbindungen ermöglicht.
- Terminal öffnen
- Vagrant-VM starten:
$ vagrant up
- SSH-Verbindung aufbauen (zur VM):
$ vagrant ssh
- Node.js installieren:
$ sudo apt-get install nodejs
- Datei
main.js
erstellen (sudo nano) & mit folgenden Inhalt füllen:$ var http = require("http"); http.createServer(function (request, response) { response.writeHead(200, {'Content-Type': 'text/plain'}); // Send the response body as "Hello World" response.end('Hello World\n'); }).listen(8081); // Console will print the message console.log('Server running at http://127.0.0.1:8081/');
- Script mit NodeJS starten:
$ nodejs main.js &
- In neuem Terminal-Fenster eine cURL-Abfrage starten:
$ curl localhost:8081
- Wenn Test erfolgreich, kann das Terminal wieder geschlossen werden.
Die MongoDB ist eine der marktführenden NoSQL-Datenbanken. MongoDB wurde für die heutige moderne IT-Landschaft konzipiert und erlaubt eine agilere Entwicklung und höhere Skalierbarkeit von Anwendungen.
Bei einer MongoDB spricht man von einem sogenannter Document Store.
Document Stores weisen folgende Eigenschaften auf:
- Weisen eine Schlüssel Werte-Paar Speicherstruktur auf, ihre Werte sind aber komplexe Datenstrukturen, die als Dokumente bezeichnet werden.
- Der Schlüssel ist ein eindeutiger Wert über die ganze DB hinweg.
- Dokumente sind unabhängig voneinander. Das heisst, dass die Struktur der jeweiligen Dokumente sich massiv unterscheiden können.
- Es besteht die Möglichkeit, Dokumente basierend auf ihren Attributen zu indexieren. Um Sichten auf ähnliche Dokumente, sogenannte Kollektionen von Dokumente, zu erstellen.
- Dokumente können anhand der Attribute gefiltert werden und Relationen zwischen Dokumenten mit Verweise auf die Schlüsselwerte in einem Dokument erstellt werden.
Der Einsatz von MongoDBs ist in folgenden Szenarien relevant:
- Realtime Analytics
- Content Manangement Systems (CMS)
- Caching
- Single Document, partial updates
- Speichern von Dokumenten in JSON
- Terminal öffnen
- Vagrant-VM starten:
$ vagrant up
- SSH-Verbindung aufbauen (zur VM):
$ vagrant ssh
- MongoDB installieren:
$ sudo apt-get install mongodb
- Mit der Konfiguration fortfahren (...)
- MongoDB-CLI starten:
$ mongo
- Daten im JSON Format einfügen:
db.adressbuch.insert({ vorname: "Daniel", nachname: "Fasel", email: "df@scigility.com", adresse: { strasse: "Rte du soleil 22", ort: "Fribourg", plz: 1700, land: "Switzerland" }, korrespondenzsprache: "französisch" }) db.adressbuch.insert({ vorname: "Andreas", nachname: "Meier", email: "andreas.meier@unifr.ch", adresse: { strasse: "Bd de Pérolles 90", ort: "Fribourg", plz: 1700 } })
- Datenbank-Abfragen durchführen:
- Dokumente mit Ort 'Fribourg'
db.adressbuch.find({"adresse.ort" : "Fribourg"})
- Dokumente mit Tag: 'korrespondenzsprache'
```js
db.adressbuch.find( { korrespondenzsprache: { $exists: true }} )
- Anzahl Dokumente mit PLZ 1700 (Fribourg)
db.adressbuch.find( { "adresse.plz": 1700 } ).count()
- Reguläre Ausdrücke
db.adressbuch.find( { "adresse.ort": /^Fr/i } ) db.adressbuch.find( { "adresse.ort": /bourg/i } )
- Dokumente mit Ort 'Fribourg'
- Aus MongoDB-CLI mit
CTRL + C
herausgehen - Temporäres Verzeichnis erstellen:
$ mkdir temp
- In das entsprechende Verzeichnis wechseln:
$ cd /temp
- Testdaten mit
wget
herunterladen:$ wget https://raw.githubusercontent.com/mongodb/docs-assets/primer-dataset/primer-dataset.json
- Testdaten in MongoDB importieren:
$ mongoimport --db test --collection restaurants --drop --file primer-dataset.json
- Wieder in MongoDB-CLI wechseln:
$ mongo
- In Datenbank
test
wechseln:> use test
- Tabelle
restaurants
abfragen:> db.restaurants.find()
- MongoDB-CLI mit
CTRL + C
schliessen - Mit Abschnitt "Zusammenfassung" fortfahren (...)
Node.js
Node.js ist eine serverseitige Plattform in der Softwareentwicklung zum Betrieb von Netzwerkanwendungen.
MongoDB
Die MongoDB ist eine der marktführenden NoSQL-Datenbanken und ein sogenannter Document Store. MongoDB wurde für die heutige moderne IT-Landschaft konzipiert und erlaubt eine agilere Entwicklung und höhere Skalierbarkeit von Anwendungen.
Das war es grundsätzlich schon mit der Praxis! Wir wollen jetzt in diesem Abschnitt noch ein wenig vertiefter in die Strukturen von Linux- bzw. Unix-Systemen einsteigen.
Der Begriff etc kommt von et cetera
("alles übrige"). Oftmals ist dabei auch editable text configuration gemeint.
/etc
enthält Konfigurations- und Informationsdateien des Basissystems. Zum Beispiel fstab, hosts, lsb-release oder blkid.tab. Die hier liegenden Konfigurationsdateien können dabei durch gleichnamige Konfigurationsdateien im Homeverzeichnis überlagert werden (z.B. bash -> .bashrc).
- /etc/default:
- Konfigurationsdateien für den Start von Diensten
- /etc/profile.d:
- Scripte welche beim Einloggen eines User durchlaufen werden
- /etc/apache2:
- Konfigurationsdateien für den Apache Webserver
- /etc/mysql:
- Konfigurationsdateien für die MySQL-Datenbank
- /etc/network:
- Verzeichnisse und Konfigurationsdateien des Netzwerkes (z.B. interfaces)
- /etc/init.d (alt):
- Start- und Stopskripte für Services
- /etc/systemd (neu):
- Start- und Stopskripte für Services (dito)
Wichtig:
Verzeichnisse mit der Endung .d beinhalten in der Regel mehrere Dateien welche durch eine vorgelagerte Datei inkludiert werden.
Um Konfigurationsdateien mit dem "Infrastruktur as a Code"-Ansatz (IaC) zu bearbeiten, eigen sich u.a. die nachfolgenden Tools:
sed (stream editor) ist ein nicht-interaktiver Texteditor für die Verwendung auf der Kommandozeile oder in Skripten. sed zählt zu den "Urgesteinen" in der Unix- / Linux-Welt und ist quasi in jeder Linux-Installation (auch Minimalinstallationen) enthalten.
- Ersetzen von Text in einer Datei:
$ sed 's/Anton/Berta/g' Textdatei
- Entfernen von Zeilen, die mit # beginnen:
$ sed '/^#/d' Textdatei
- MySQL-Server Port öffnen:
$ sudo sed -i -e"s/^bind-address\s*=\s*127.0.0.1/bind-address = 0.0.0.0/" /etc/mysql/mysql.conf.d/mysqld.cnf
cat ist ursprünglich zum Zusammenfügen von Dateien gedacht (von concatenate = verketten, verknüpfen). Häufig wird cat aber als "Pager" zum Anzeigen von Dateiinhalten im Terminal eingesetzt (was letztendlich dem "Verketten" von Dateiinhalten mit dem Bildschirm entspricht).
- Schreiben einer Zwischendatei und Übergabe dieser an ein nachfolgendes Programm ($$ ist die Prozess-Nummer):
$ cat <<%EOF% >/tmp/$$ C REATE USER 'root'@'192.168.55.101' IDENTIFIED BY 'admin'; GRANT ALL PRIVILEGES ON *.* TO 'root'@'192.168.55.101'; FLUSH PRIVILEGES; %EOF% mysql -uroot -pS3cr3tp4ssw0rd </tmp/$$
Der Befehl cut extrahiert spaltenweise Ausschnitte aus Textzeilen. So können beispielsweise aus einer Logdatei irrelevante Informationen entfernt oder CSV-Dateien bearbeitet werden.
- Ausgabe nur der Benutzernamen aus der passwd-Datei:
$ cut -d: -f1 /etc/passwd
- Ausgabe aller Prozess-Nummern:
$ ps huax | cut -c 9-14
- Durch Kombination von Befehlen, kann cut auf jedes Zeichen einer Datei zugreifen. Mit folgendem Befehl wird das 3. Wort der 6. Zeile (der Datei datei.txt)extrahiert. Es werden zunächst mit head die ersten 6 Zeilen ausgeschnitten, dann mit tail die letzte dieser verbleibenden Zeilen und schließlich mit cut deren drittes Wort:
$ cat datei.txt | head -6l | tail -1l | cut -d" " -f3
ln steht für link und erzeugt eine Verknüpfung zu einer Datei oder einem Verzeichnis. Man kann danach auf eine Datei nicht nur über ihren ursprünglichen Namen bzw. Pfad, sondern auch über den Namen des Links zugreifen.
Man unterscheidet zwischen Hardlinks und symbolischen (oder Soft-)links:
- Hardlink
Ist einfach ein Verzeichniseintrag mit einem Namen, der auf eine Datei zeigt. Jede Datei hat immer mindestens einen Hardlink, denn ansonsten könnte man sie im Dateisystem nicht finden. - Symbolischer Link
Symbolische Verknüpfungen (oder "Softlinks") wurden geschaffen, um diese Unzulänglichkeit der Hardlinks zu umgehen. Sie funktionieren ähnlich wie die HTML-Links auf Webseiten. Ein symbolischer Link ist einfach eine kleine Datei bei der das 1-Bit gesetzt ist und die den Pfad des Zieles enthält.
- Datei erstellen und dann mit einem Hardlink verknüpfen:
$ cat <<%EOF% >zahlen eins zwei drei %EOF% ln zahlen numbers $ ls -li total 8 280065 -rw-rw-r-- 2 ubuntu ubuntu 15 Feb 11 12:45 numbers 280065 -rw-rw-r-- 2 ubuntu ubuntu 15 Feb 11 12:45 zahlen $ cat numbers eins zwei drei $ cat zahlen eins zwei drei
- Apache Modul mittels eines symbolischen Links freischalten:
$ cd /etc/apache2/conf-enabled/ $ ln -s ../conf-available/adminer.conf .
/etc
enthält Konfigurations- und Informationsdateien des Basissystems. Beispiele: fstab, hosts, lsb-release, blkid.tab. Die hier liegenden Konfigurationsdateien können durch gleichnamige Konfigurationsdateien im Homeverzeichnis überlagert werden (Z.B. bash -> .bashrc).
sed, cat etc. sind Tools zur Bearbeitung von Konfigurationsdateien.
Nach den vorhergehenden Theorie-Inputs geht es nun mehr und mehr in die Praxis. In diesem Abschnitt wird der Apache Webserver installiert und die MySQL-Datenbank eingerichtet.
Ein Dienst ist ein Programm, das beim Start des Rechners automatisch ausgeführt wird und im Hintergrund darauf wartet, seine Aufgabe zu erledigen.
Ein Dienst besitzt meist keine grafische Oberfläche und arbeitet ohne Interaktion des Benutzers.
Die bekanntesten Dienste sind sicherlich Web-, Mail- oder Datenbank-Server. Aber auch die Hardwareerkennung oder das automatische Einbinden (Mounten) von z.B. USB-Sticks wird durch Dienste erledigt.
Prinzipiell gibt es also zwei Arten von Diensten:
- Interne für beim Systemstart relevante bzw. hardwarenahe Aufgaben.
- Vom Benutzer nachinstallierte Dienste, zu denen in der Regel alle Serverdienste gehören.
In der Fachsprache werden generell Dienste traditionell auch als "Daemon" (im Sinne eines guten Geistes) bezeichnet. Der Buchstabe d findet sich daher häufig auch als letzter Buchstabe in der Programmbezeichnung wieder, so z.B. bei der Serverkomponente sshd von SSH.
Um das geordnete Starten und Beenden der Dienste kümmert sich ein Init-System. Dies ist normalerweise der erste gestartete Prozess und hat damit die Prozess-ID 1.
Ursprünglich übernahm diese Aufgabe auf Linux-Systemen SysVinit. Dieses startet die Dienste nacheinander in einer festgelegten Reihenfolge. Das macht den Startvorgang zuverlässig und leicht kontrollierbar, aber auch langsam. Mit dem parallelen Start von Diensten lässt sich der Startvorgang entscheidend beschleunigen, was insbesondere auf Desktop-Rechnern und Notebooks praktische Vorteile bietet.
Stoppen und Starten des Apache Web Servers, alte und neue Variante:
$ sudo service apache2 stop
$ sudo service apache2 start
$ sudo systemctl stop apache2
$ sudo systemctl start apache2
Status aller Services abfragen:
$ sudo service --status-all
$ sudo systemctl status
Je nach verwendetem System, findet man Start-/Stopp-Skripte an folgenden Orten:
- Systemd
- /etc/systemd/system/ (benutzerdefinierte) oder /lib/systemd/system/ (systemeigene)
- Upstart
- .conf-Dateien im Ordner /etc/init/
- SysVinitx
- alle Dateien im Ordner /etc/init.d/
systemd ist ein System- und Sitzungs-Manager (Init-System), der für die Verwaltung aller auf dem System laufenden Dienste über die gesamte Betriebszeit des Rechners, vom Startvorgang bis zum Herunterfahren, zuständig ist.
Prozesse werden dabei immer (soweit möglich) parallel gestartet, um den Bootvorgang möglichst kurz zu halten.
Systemd wird über Dateien mit einem INI-Datei-ähnlichen Format konfiguriert. In der Terminologie von systemd sind dies "Units".
Bei Ubuntu vorinstallierte Units sind im Ordner /lib/systemd/system/
gespeichert. Falls sich jedoch eine Unit mit gleichem Namen im Verzeichnis /etc/systemd/system/
befindet, so wird diese bevorzugt und jene unterhalb von /lib
ignoriert. Damit hat man die Möglichkeit, eine Unit an eigene Gegebenheiten anzupassen, ohne dass man befürchten muss, dass sie bei einer Systemaktualisierung überschrieben wird.
Der Cron-Daemon ist ein Dienst, der automatisch Skripte und Programme zu vorgegebenen Zeiten starten kann.
Der auszuführende Befehl wird in einer Tabelle, der "crontab", gespeichert.
Es gibt eine systemweite Datei /etc/crontab
, die nur mit Root-Rechten bearbeitet werden kann. Zusätzlich kann jeder Benutzer eine eigene Crontab erstellen, die man dann im Verzeichnis /var/spool/cron/crontabs/
findet.
Diese Tabelle besteht aus sieben bzw. sechs Spalten. Die ersten fünf dienen der Zeitangabe (Minute, Stunde, Tag, Monat, Wochentage) für einen Cronjob, dann folgt (nur in der systemweiten Crontab) der Benutzername, unter dem der Befehl ausgeführt werden soll, und die letzte enthält den Befehl. Die einzelnen Spalten werden durch Leerzeichen oder Tabulatoren getrennt.
Cron startet einzelne Cronjobs immer nur zu den eingetragenen Zeiten. Legt man also einen Cronjob an, der täglich um 18.00 Uhr ausgeführt wird, so wird der Job an diesem Tag nur ausgeführt, wenn der Rechner um Punkt 18 Uhr angeschaltet war. Für Jobs, die regelmäßig ausgeführt werden müssen, wobei der Rechner nicht durchgehend läuft, ist Cron daher nicht ideal. Wenn man Pech hat, wird z.B. eine wichtige Datensicherung ("backup") verpasst.
Als Ergänzung zu Cron bietet sich daher Anacron an. Anacron ist ein cron-ähnlicher Taskplaner, allerdings erfordert er nicht das kontinuierliche Laufen des Systems. Er kann zum Ausführen von täglich, wöchentlich oder monatlich anstehenden Aufträgen verwendet werden, die normalerweise von cron ausgeführt werden.
Anstatt einer Crontab muss nur das auszuführende Skript oder Programm in das entsprechende Verzeichnis des Anacron-Dienstes kopiert oder verlinkt werden.
/etc/cron.hourly/
- stündlich auszuführen/etc/cron.daily/
- täglich auszuführen/etc/cron.weekly/
- wöchentlich auszuführen/etc/cron.monthly/
- monatlich auszuführen
Die Namen der Verzeichnisse sprechen für sich. Skripte, die dort abgelegt sind, werden auch durch den Anacron-Dienst ausgeführt. Am besten schaut man sich kurz die Skripte in diesen Verzeichnissen an, bevor man selber dort etwas ablegt.
Ein Dienst ist ein Programm, das beim Start des Rechners automatisch ausgeführt wird und im Hintergrund darauf wartet, seine Aufgabe zu erledigen.
Prinzipiell gibt es zwei Arten von Diensten:
- Interne für beim Systemstart relevante bzw. hardwarenahe Aufgaben.
- Vom Benutzer nachinstallierte Dienste, zu denen in der Regel alle Serverdienste gehören.
systemd ist ein System- und Sitzungs-Manager (Init-System), der für die Verwaltung aller auf dem System laufenden Dienste über die gesamte Betriebszeit des Rechners, vom Startvorgang bis zum Herunterfahren, zuständig ist.
Der Cron-Daemon ist ein Dienst, der automatisch Skripte und Programme zu vorgegebenen Zeiten starten kann.
Anacron ist ein cron-ähnlicher Taskplaner, allerdings erfordert er nicht das kontinuierliche Laufen des Systems. Er kann zum Ausführen von täglich, wöchentlich oder monatlich (und ab Ubuntu 14.04 auch stündlich) anstehenden Aufträgen verwendet werden, die normalerweise von cron ausgeführt werden.
Die Erarbeitung dieses Abschnittes hat mir sehr viel Freude bereitet und ich konnte einiges lernen. Jedoch waren die Aufgabenstellungen teilweise etwas unkalr oder sogar falsch formuliert, wodurch ich viel Geduld und Zeit aufwenden musste. Mit meinem Ergebnis bin ich jedoch sehr zufrieden und ich hoffe, dass durch diese Dokumentation bzw. durch dieses Repository die Aufgaben verständlicher wirken.