Docker
Zugriff
Der Docker-Server ist unter der 172.22.0.224 erreichbar.
Der neue Docker-Server wird unter 172.22.0.223 erreichbar sein.
Der Port, Nutzername und auch das Passwort sind im Passbolt gespeichert.
Zugriff Dienste
Nachfolgend eine Liste der Dienste die auf dem Docker laufen
- Cockpit-PROD
- Cockpit-TEST
- Cockpit-DEV
- UpTime Kuma (Monitor)
- Portainer (Docker Verwaltung)
- FTP
- Ticketsystem / Otobo
- NGINX & Certbot (noch nicht als Docker-Container)
- UFW (Firewall)
- Git (gitea) noch nicht installiert
Neuinstallation
Kopie der "tisento.conf"-Datei in den Ordner: "/etc/ssh/sshd_config.d/".
Hinzufügen des 9022-Ports zur UFW mit:
sudo ufw allow 9022/tcp
Einschalten der ufw mit
sudo ufw enable
Installation vom Docker (https://docs.docker.com/engine/install/ubuntu/):
Install using the apt repository
Before you install Docker Engine for the first time on a new host machine, you need to set up the Docker apt repository. Afterward, you can install and update Docker from the repository.
- Set up Docker's
aptrepository.
# Add Docker's official GPG key:
sudo apt-get update
sudo apt-get install ca-certificates curl
sudo install -m 0755 -d /etc/apt/keyrings
sudo curl -fsSL https://download.docker.com/linux/ubuntu/gpg -o /etc/apt/keyrings/docker.ascsudo chmod a+r /etc/apt/keyrings/docker.asc
# Add the repository to Apt sources:
echo \
"deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] https://download.docker.com/linux/ubuntu \
$(. /etc/os-release && echo "${UBUNTU_CODENAME:-$VERSION_CODENAME}") stable" | \
sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
sudo apt-get update
- Install the Docker packages.
sudo apt-get install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
- Verify that the installation is successful by running the
hello-worldimage:
sudo docker run hello-world
Installation der Sonstigen Softare (s.u.)
via "sudo apt install ..."
Kopie des Docker-Repos
Kopie des Repos in "/srv/tisento-docker".
Dort muss als erstes "portainer gestartet und wiederhergestellt werden.
Danach wird gitea gestartet und wiederhergestellt. (Damit die repos gezogen werden können)
Danach nach und nach die anderen Services wiederherstellen.
Einstellung UFW
sudo ufw allow 80/tcp
sudo ufw allow 443/tcp
Sonstige Software (nicht vollständig, muss überarbeitet werden!)
- Docker (s.o.)
- git
- UFW (Firewall)
- cron (Wiederkehrende Aufgaben, bspw. Backups)
- ncdu (Speicherbelegung)
- nmon (Monitoring)
- cifs-utils (Mounting Laufwerke)
- zip
- sshpass (sftp transer)
Beschreibung der Docker-Dienste
Die meisten Dienste sind mit ihren Daten und Definitionen unter /var/html/dienst.tisento.com erreichbar.
Dabei sind in dem Ordner /var/html/dienst.tisento.com/.docker die Definitionen der Docker-Container.
In dem Ordner /var/html/dienst.tisento.com/backups sind die jeweiligen Backups der Daten.
Cockpit-PROD (cockpit.tisento.com)
Cockpit-PROD besteht aus:
- Apache Dienste
- MariaDB
- PHPMyAdmin
- LXConnector (Direktverbindung zu Lexware F2)
- Backup
Die Daten befinden sich unter /var/html/cockpit.tisento.com.
Backup
Der Backup-Service erstellt jeden Tag ein Backup der MariaDB und des HTML-Verzeichnisses vom Apache-Dienst.
Diese Backups werden auf dem Server unter "/srv/tisento-docker/cockpit-prod/backups gespeichert. Das tägliche Backup wird nach 30 Tagen gelöscht, die monatlichen nach einem Jahr und die jährlichen Backups nie.
EVTL. NOCH MONITOR HINZUFÜGEN DER BACKUP TÄGLICH PRÜFT!
Wiederherstellung
Mounting der Laufwerke via:
sudo mount.cifs -v //172.22.0.245/cockpit/_Daten /srv/tisento-docker/cockpit-prod/html/_Daten/ --verbose -o user=us,password=pw,domain=TISENTOSAN2,vers=2.0,uid=33,gid=33
Die ID 33 muss ggfs. angepasst werden um
id www-data
damit die Rechte passen.
Es müssen auch die Laufwerke _Cockpit_Daten und _Cockpit_Verwaltung gemounted werden.
Weiter müssen ggfs. einige ".env"-Dateien angepasst werden.
"html/api/connection/.env"
".docker/backup/backup.env"
Siehe die jeweiligen "*.env.example"-Dateien
Danach muss das Backup der HTML-Dateien in das Verzeichnis /srv/tisento-docker/cockpit-prod/html kopiert werden.
Danach müssen noch die SQL-Dateien eingespielt werden:
Dazu die SQL-Datei in den Server laden ("root" => user, "test" ist das Passwort).
Evtl. muss die erste Zeile gelöscht werden:
tail -n +2 cockpit-dev_db.sql > cockpit-dev_db2.sql
sudo docker exec -i cockpit-prod-db-1 mariadb -u root -ptest < cockpit-prod_db.sql
Danach muss das Root-PW händisch geändert werden (bspw. im PMA)
WICHTIG: Die Daten beim LX DW-Importer müssen auch geändert werden!
Cockpit-TEST (cockpit-test.tisento.com)
Cockpit-PROD besteht aus:
- Apache Dienste
- MariaDB
- PHPMyAdmin
- LXConnector (Direktverbindung zu Lexware F902)
- Backup
Die Daten befinden sich unter /var/html/cockpit-test.tisento.com.
Backup
Der Backup-Service erstellt jeden Tag ein Backup der MariaDB und des HTML-Verzeichnisses vom Apache-Dienst.
Diese Backups werden auf dem Server unter "/var/www/cockpit-test.tisento.com/backups gespeichert.
Wiederherstellung
Siehe PROD (ohne Mounting)
Cockpit-DEV (cockpit-dev.tisento.com)
Cockpit-PROD besteht aus:
- Apache Dienste
- MariaDB
- PHPMyAdmin
- LXConnector (Direktverbindung zu Lexware F902)
- Backup
Die Daten befinden sich unter /var/html/cockpit-dev.tisento.com.
Backup
Der Backup-Service erstellt jeden Tag ein Backup der MariaDB und des HTML-Verzeichnisses vom Apache-Dienst.
Diese Backups werden auf dem Server unter "/var/www/cockpit-dev.tisento.com/backups gespeichert.
Wiederherstellung
Siehe PROD (ohne Mounting)
UpTime Kuma / Monitor (monitor.tisento.com)
Dieses Tool ist für die Überwachung der diversen Docker-Container, als auch für diverse Systeme da (z.B. HEALTH, also CPU, RAM, HDD von diversen Servern).
Die Daten befinden sich unter /var/html/monitor.tisento.com.
Backup
Es wird das /data -Verzeichnis gesichert
Wiederherstellung
Kopie des /data-Verzeichnisses zurück nach /srv/tisento-docker/monitor/app/data. Es muss evtl. die Datei backup_db.db in kuma.db umbenannt werden
Portainer (portainer.tisento.com)
Dieses Tool ist für die Verwaltung der verschiedenen Docker-Container notwendig.
Die Daten befinden sich unter /var/html/portainer.tisento.com.
Backup
Es wird das data-Verzeichnis gesichert.
Wiederherstellung
Das data-Verzeichnis muss in /srv/tisento-docker/portainer/data gespeichert werden.
FTP
Dieses Tool ist für die FTP-Verbindung zu den jeweiligen HTML-Verzeichnissen von cockpit.tisento.com, cockpit-test.tisento.com und cockpit-dev.tisento.com zuständig.
Die Daten befinden sich unter /var/html/ftp.tisento.com.
Backup
Es wird die pureftpd.passwd Datei als backup gespeichert. Diese beinhaltet die FTP-Verzeichnisse und Server und Passwörter.
Wiederherstellung
Die pureftpd.passwd muss in das Verzeichnis /srv/tisento-docker/ftp/.docker/passwd/ lopiert werden.
Es muss in dem docker-compose evtl. die Zeile "PUBLICHOST: "172.22.0.223"" angepasst werden.
Ticketsystem / Otobo (service.tisento.com)
Dieses Tool ist für die Erstellung und Verwaltung der Tickets zuständig.
Die Daten befinden sich unter /var/html/TODO.tisento.com.
Backup
TODO
Wiederherstellung
TODO
Fehlerbehebung
Wenn bspw. die Festplatte vom Docker-Server vollgelaufen ist, dann müssen die Dienste einmal neugestartet werden (Portainer -> Connect -> Stacks -> tisento_cloud, Container alle auswählen und "Restart").
Zusätzlich kann es sein, dass man die Caches mit folgenden Befehlen (im Daemon) löscht (Portainer -> Connect -> Stacks -> tisento_cloud -> tisento_cloud-daemon-1 -> ">_Console"):
bin/otobo.Console.pl Maint::Cache::Delete
bin/otobo.Console.pl Maint::Config::Rebuild --cleanup
bin/otobo.Console.pl Maint::Loader::CacheCleanup
Wenn es in dem DB-Container zu dem Fehler kommt (Prüfen Portainer -> Connect -> Stacks -> tisento_cloud -> tisento_cloud-db-1 -> "Logs"):
2025-10-13 10:56:49 0 [ERROR] Could not open mysql.plugin table: "Unknown storage engine 'Aria'". Some plugins may be not loaded 2025-10-13 10:56:49 0 [ERROR] Failed to initialize plugins. 2025-10-13 10:56:49 0 [ERROR] Aborting
Dann müssen in dem DB-Container die ARIA-Files gelöscht werden:
Container stoppen (z.B. in Portainer), danach das Volume mounten (mit sudo vorher und direkt in der SSH Verbindung vom Server!):
docker run --rm -it -v tisento_cloud_mariadb_data:/var/lib/mysql alpine sh
und dann die Aria-Files in dem Ordner /var/lib/mysql löschen:
cd /var/lib/mysql
rm aria_log.*
Danach Container starten und testen (Und Logs anschauen, s. oben!)
NGINX (noch nicht als Docker-Container)
nginx ist ein Reverse-Proxy, damit die verschiedenen Domains den richtigen Weg zu den Services finden.
Die Daten befinden sich unter /srv/tisento-docker/SERVICENAME/.....
Backup
Es werden die verzeichnisse certbot and nginx gebackupped
Wiederherstellung
Die beiden Verzeichnisse müssen in /srv/tisento-docker/nginx/nginx und srv/tisento-docker/nginx/certbot kopiert werden!
UFW (Firewall)
Backup
Es wird einmal am Tag die Liste mit den Regeln abgespeichert.
TODO
Wiederherstellung
Erstellen der einzelnen Richtlinien mit:
sudo ufw allow 10021/tcp
Git (gitea) (gitea.tisento.com)
Die Daten befinden sich unter /srv/tisento-docker/gitea/data.
Backup
Es wird das data-Verzeichnis gesichert.
Wiederherstellung
Das data-Verzeichnis muss in /srv/tisento-docker/portainer/data gespeichert werden.
Recovery (git & wiki)
Backup
In diesem Dienst wird von dem aktuellen Git-Repo ein Backup gemacht, weiter wird auch diese Wiki-Seite gesichert, damit die Daten hiermit wiederhergestellt werden können
Wiederherstellung
Die Daten müssen entpackt werden. Dann dem PDF folgen!
Backup // Wiederherstellung
Jeder Service hat ein eigenes Backup-System.
Diese Backups werden gemeinsam per FTP auf den Server XY übertragen. (TODO)
Dort läuft ein kleiner PHP-Cronjob, der diese Backups in ein anderes Verzeichnis überträgt. (TODO)
Diese Dateien werden für eine Wiederherstellung benötigt!
Wiederherstellung
Für die Wiederherstellung werden die Backups vom Server benötigt. Weiter wird diese Anleitung benötigt.
Weiter wird für ein vollständigen Backups ein neuer Server benötigt, dort müssen folgende Schritte in der Reihenfolge ausgeführt werden.
Installation s.o. "Neuinstallation".
Außerdem muss der DNS und weitere Weiterleitungen der entsprechenden Domains auf den neuen Server geändert werden!
Es werden auch einige Passwörter gebraucht. Dieses sind in keepass.tisento.com und auch in der Passwort-Datei abgespeichert. Diese kann mit dem üblichen Passwort geöffnet werden (TODO)!
Kopie des git-Repos in dem Verzeichnis /srv/tisento-docker/.
Per SSH Beispielsweise mit dem CMD zum Server kopiert werden:
sudo scp -P XXXX /srv/tisento-docker/nginx/backups/daily/backup_nginx_20250620_020000.tar.gz USER@IP:/tmp/nginx.tar.gz
Entpacken der Dateien mit bspw.:
tar -xvzf yourfile.tar.gz -C /path/to/your/special/folder
Wiederherstellung nginx s.o.
Wiederherstellung Portainer s.o.
Wiederherstellung gitea s.o.
Wiederherstellung der restlichen Docker-Services mithilfe der Docker-Compose-Dateien in gitea. Alternativ sind die Docker-Compose-Dateien auch in den Backup gespeichert und wurden im best-case zu "/srv/tisento-docker" zurückgespielt!
Wiederherstellung der einzelnen Daten der Services mithilfe der obigen Erklärungen.
Test der Systeme
Cockpit-PROD (cockpit.tisento.com)
Erstellung einer Zeiterfassung.
Erstellung eines Auftragsscheines => per FTP & V-Laufwerk prüfen, ob dieser erstellt wurde.
Cockpit-TEST (cockpit-test.tisento.com)
Erstellung einer Zeiterfassung.
Erstellung eines Auftragsscheines => per FTP prüfen, ob dieser erstellt wurde.
Cockpit-DEV (cockpit-dev.tisento.com)
Erstellung einer Zeiterfassung.
Erstellung eines Auftragsscheines => per FTP prüfen, ob dieser erstellt wurde.
UpTime Kuma / Monitor (monitor.tisento.com)
Aufruf der Website, schauen, ob alle Monitore noch vorhanden sind.
Portainer (portainer.tisento.com)
Aufruf der Website und schauen, ob zu den Containern eine Verbindung herstgestellt wird.
FTP
Hestellung der Verbindung zu Cockpit-Prod,-Test und -Dev.
Testübertragung (bspw. Task) und test davon!
Ansonsten einfach mal die index.html umbenennen!
Ticketsystem / Otobo (service.tisento.com)
Erstellung eines Test-Tickets via Mail an: support@tisento.com
Prüfen, ob dieses Ticket in der GUI auftaucht.
Antworten auf dieses Ticket und schauen, ob die Antwort in dem Mail-Client ankommt.
NGINX
Aufrufen der diversen Websiten.
UFW (Firewall)
Git (gitea) (gitea.tisento.com)
Anmeldung mit dem AD-Nutzern
Neuen Docker-Dienst anlegen
Hier wird davon ausgegangen, dass es sich um einen Dockerdienst handelt, der auf einem Port wie 80 oder 443 angesprochen werden soll. Wir gehen davon aus, dass das Portmapping "127.0.0.1:10443:443" ist, also der Container den Port 10443 auf das lokale Interface öffnet und mit dem Container-Port 10443 mappt. Weiter gehen wir davon aus, dass der Service über die Subdomain "sub.tisento.com" über HTTP und HTTPS erreichbar sein soll. HTTP wird auf HTTPS weitergeleitet.
- Erstellung der Sub-Domain sub.tisento.com
- Torsten diese Sub-Domain dem Server zuweisen lassen.
- Für das SSL-Zertifikat muss die Domain öffentlich erreichbar sein!
- Erstellung der Konfiguration im nginx Service
- Erstellung einer Datei sub.tisento.com.conf in dem Pfad /var/www/nginx.tisento.com/nginx/...
- Hinzufügen von dem Inhalt:
adasdsa
- Prüfung ob die Konfiguration korrekt ist (optional)
- nginx neu laden
- Hinzufügen eines Zertifikates mit dem Befehl:
- asdasd
- Hinzufügen der SSL Konfuguration zur Datei (sub.tisento.com.conf)
- Prüfen ob die Konfiguration korrekt ist (optional)
- nginx neuladen
- Prüfen der Verbindung
Datev-Relay Einstellungen
Netzwerk
Hinzufügen:
sudo nano /etc/iproute2/rt_tables 100 eth0table 101 eth1table
Erstellen:
sudo nano /usr/local/sbin/custom-routes.sh ip route add 172.22.0.0/24 dev eth0 src 172.22.0.224 table eth0table ip route add default via 172.22.0.254 dev eth0 table eth0table ip route add 10.10.10.0/24 dev eth1 src 10.10.10.224 table eth1table ip route add default via 10.10.10.254 dev eth1 table eth1table ip rule add from 172.22.0.224/32 table eth0table ip rule add from 10.10.10.224/32 table eth1table
Ändern der Rechte:
sudo chmod +x /usr/local/sbin/custom-routes.sh
Erstellen
sudo nano /etc/systemd/system/custom-routes.service [Unit] Description=Add custom routes to tables After=network-online.target Wants=network-online.target [Service] Type=oneshot ExecStart=/usr/local/sbin/custom-routes.sh RemainAfterExit=yes [Install] WantedBy=multi-user.target
und aktivieren:
sudo systemctl enable custom-routes.service
Anpassung der Netzwerkeinstellungen
sudo nano /etc/netplan/50-cloud-init.yaml network:
version: 2
ethernets:
eth0:
dhcp4: true
adresses: [172.22.0.224/24]
gateway4: 172.22.0.254
nameservers:
addresses: [172.22.0.210,172.22.0.254]
eth1:
dhcp4: false
addresses: [10.10.10.224/24]
gateway4: 10.10.10.254
nameservers:
addresses: [8.8.8.8, 9.9.9.9]