Alles die Administration von web betreffend.
Es ist das Paket etckeeper mit Git als Backend installiert um den Vorteil einer Versionsverwaltung für /etc zu haben. Nach administrativen Aufgaben einfach kurz
sudo etckeeper commit
und kurz eine Commit Message eingeben. Das Repository ist ausschließlich lokal vorhanden und wird nicht nach draußen gepusht!
(aka Nutzer mit sudo Rechten)
docker network create --driver=bridge --ipv6 --subnet=fda9:26e:5805:bab1:aeb:d0c0::/96 doc0
| Query Location | Description |
|---|---|
| http://web.md.freifunk.net:8010/data/meshviewer.json | Meshviewer nodes.json v2 |
| http://web.md.freifunk.net:8010/#!/de/map | Meshviewer Map |
Yanic dient der erfassung der Nodes im Batman und Babel Netz
Auf jeden Gateways läuft eine Yanic Instanz die Ihre information zur WEB schickt
Hier läuft der zentrale Yanic Service der die Daten für den meshviewer bereitstellt.
Der Zentrale Yanic legt seine Daten einmal as JSON für den Meshviewer ab und zusätzich in einer influxDB
Compose File um alle Services für Freifunk zu starten.
Location /opt/
File docker-compose.yaml
Config File unter /opt/…
version: '3.0'
volumes:
prometheus-storage:
external: true
grafana-storage:
external: true
networks:
front-tier:
back-tier:
services:
prometheus:
image: prom/prometheus:latest
container_name: ffmd_prometheus
volumes:
- /opt/prometheus/prometheus.yml:/etc/prometheus/prometheus.yml
- prometheus-storage:/prometheus
ports:
- 9090:9090
restart: unless-stopped
networks:
- back-tier
grafana:
image: grafana/grafana:latest
container_name: ffmd_grafana
depends_on:
- prometheus
- influxdb
ports:
- 3000:3000
environment:
- GF_INSTALL_PLUGINS:grafana-piechart-panel
volumes:
- grafana-storage:/var/lib/grafana
- /opt/grafana/grafana.ini:/etc/grafana/grafana.ini
restart: unless-stopped
networks:
- front-tier
- back-tier
yanic:
image: ffmd/yanic:latest
depends_on:
- influxdb
network_mode: "host"
restart: unless-stopped
container_name: ffmd_yanic
volumes:
- /opt/yanic/config.toml:/etc/yanic.conf
meshviewer:
image: ffmd/meshviewer-server:latest
container_name: ffmd_meshviewer_server
restart: unless-stopped
depends_on:
- yanic
ports:
- 8010:80
environment:
MeshviewerRepo: "https://github.com/FreifunkMD/Meshviewer --branch ffmd"
LoopHookCMD: "wget http://5.252.224.201:8080/data/meshviewer.json -O /var/www/html/data/meshviewer.json"
networks:
- back-tier
- front-tier
influxdb:
environment:
INFLUXDB_ADMIN_USER: user
INFLUXDB_ADMIN_PASSWORD: *Ü****
INFLUXDB_USER: User
INFLUXDB_USER_PASSWORD: *Ü****
INFLUXDB_DB: babelstats
INFLUXDB_READ_USER: Reader
INFLUXDB_READ_USER_PASSWORD: *Ü****
image: influxdb:latest
container_name: ffmd_influxdb
volumes:
- /opt/influxdb/data/:/var/lib/influxdb
- /opt/influxdb/influxdb.conf:/etc/influxdb/influxdb.conf:ro
restart: unless-stopped
networks:
- back-tier
- front-tier
ports:
- "8086:8086"
siehe Compose
docker pull grafana/grafana docker volume create grafana-storage
Siehe compose
docker volume create prometheus-storage docker pull prom/prometheus
Sieh Compose
Der DNS verwaltet die Zone ffmd., für das Docker-Netz. Es ist außerdem eine Weiterleitung auf ns1.netz39.de eingerichtet, der die Zone md.freifunk.net. verwaltet.
Setup des Docker-Containers:
docker run -d --restart always --ip6 fda9:26e:5805:bab1:aeb:d0c0::53 --network doc0 --name bind9-ffmd ffmd/bind9-ffmd
Test-Aufruf:
dig @fda9:26e:5805:bab1:aeb:d0c0::53 -t AAAA stable-babel.updates.firmware.ffmd
Diese Firewall-Konfiguration mit ip6tables sorgt dafür, dass Aufrufe an fda9:26e:5805:bab1:53::1 an den Docker-Container weitergeleitet werden: (persistiert in /etc/ufw/before6.rules)
ip6tables -t nat -A PREROUTING -d fda9:26e:5805:bab1:53::0 -j DNAT --to-destination fda9:26e:5805:bab1:aeb:d0c0::53 ip6tables -t nat -A OUTPUT -d fda9:26e:5805:bab1:53::0 -j DNAT --to-destination fda9:26e:5805:bab1:aeb:d0c0::53 ip6tables -A ufw6-before-forward -p udp --dport 53 -d fda9:26e:5805:bab1:aeb:d0c0::53 -j ACCEPT ip6tables -A ufw6-before-forward -p tcp --dport 53 -d fda9:26e:5805:bab1:aeb:d0c0::53 -j ACCEPT
Anschließend funktioniert folgender Test-Aufruf:
dig @fda9:26e:5805:bab1:53::0 -t AAAA stable-babel.updates.firmware.ffmd
Für die Auflösung der Unicast-Adresse müssen Routen angelegt werden, z.B.:
ip -6 r a fda9:26e:5805:bab1:53::0 dev backend-web t local
Bearbeitet in #13
curl -s https://api.github.com/repos/prometheus/node_exporter/releases/latest \ | grep browser_download_url \ | grep linux-amd64 \ | cut -d '"' -f 4 \ | wget -qi - tar xzf node_exporter-0.18.1.linux-amd64.tar.gz cd node_exporter-0.18.1.linux-amd64/ sudo cp node_exporter /usr/local/bin/
sudo nano /etc/systemd/system/node_exporter.service [Unit] Description=Node Exporter Wants=network-online.target After=network-online.target [Service] User=prometheus ExecStart=/usr/local/bin/node_exporter \ --collector.cpu \ --collector.diskstats \ --collector.filesystem \ --collector.loadavg \ --collector.meminfo \ --collector.filefd \ --collector.netdev \ --collector.stat \ --collector.netstat \ --collector.systemd \ --collector.uname \ --collector.vmstat \ --collector.time \ --collector.mdadm \ --collector.zfs \ --collector.tcpstat \ --collector.bonding \ --collector.hwmon \ --collector.arp \ --web.listen-address=:9100 \ --web.telemetry-path="/metrics" /etc/systemd/system/node_exporter.service [Install] WantedBy=default.target
sudo systemctl daemon-reload sudo systemctl enable node_exporter.service sudo systemctl start node_exporter.service
tbd
Docker-Container:
Archiv vom gesamten WP Content
tar -czf /tmp/website.`date +%Y%m%d-%H%M%S`.tar.gz website
Datenbank dump
mysqldump --databases website -u website -p > /tmp/wordpress.sql
Übertragen der Daten auf den neuen Sever ⇒ Wordpress SQL Dump in das Verzeichnis initdb.d
mkdir -pv /var/www/example.com/database/initdb.d cd /var/www/example.com/database/initdb.d
Wordpress Content in das Verzeichnis srv entpacken
mkdir -pv /var/www/example.com/src
Docker-compose in /var/www/md.freifunk.net
version: '3'
networks:
frontend:
backend:
services:
wordpress_db:
image: mariadb:latest
container_name: ffmd_mariadb
volumes:
- ./database/data:/var/lib/mysql
- ./database/initdb.d:/docker-entrypoint-initdb.d
restart: unless-stopped
networks:
- backend
environment:
MYSQL_ROOT_PASSWORD: **secret**
MYSQL_DATABASE: **DB_Name**
MYSQL_USER: **user**
MYSQL_PASSWORD: **secret**
wordpress:
depends_on:
- wordpress_db
image: wordpress:latest
restart: unless-stopped
container_name: ffmd_wordpress
networks:
- backend
- frontend
ports:
- "1234:80"
environment:
WORDPRESS_DB_HOST: wordpress_db:3306
WORDPRESS_DB_USER: **user**
WORDPRESS_DB_PASSWORD: **secret**
WORDPRESS_DB_NAME: **db_namen**
restart: unless-stopped
links:
- wordpress_db:mariadb
volumes:
- ./src:/var/www/html
starten der
docker-compose up -d
Apache / Ngingx Config erstellen
apache config
VirtualHost *:80>
ServerAdmin kontakt@md.freifunk.net
ServerName web.md.freifunk.net
ServerAlias web.md.freifunk.net
ErrorLog /var/log/apache2/web.md.freifunk.net-error.log
CustomLog /var/log/apache2/web.md.freifunk.net-access.log common
Redirect / https://md.freifunk.net/
</VirtualHost>
<VirtualHost *:443>
ServerAdmin kontakt@md.freifunk.net
ServerName web.md.freifunk.net
ServerAlias web.md.freifunk.net
ErrorLog /var/log/apache2/web.md.freifunk.net-error.log
CustomLog /var/log/apache2/web.md.freifunk.net-access.log common
SSLEngine on
SetEnvIf User-Agent ".*MSIE.*" nokeepalive ssl-unclean-shutdown
SSLCertificateFile **
SSLCertificateKeyFile **
SSLCertificateChainFile **
Redirect / https://md.freifunk.net/
</VirtualHost>