ansible-ffibk/Readme.md

197 lines
6.2 KiB
Markdown
Raw Normal View History

# Ansible Freifunk MWU
2016-06-21 16:32:27 +02:00
Wir, die Freifunk MWU Community, nutzen Ansible um unsere Freifunk Server aufzusetzen und zu konfigurieren. In
diesem Repository verwalten wir unsere Ansible Roles und Playbooks.
2017-09-06 12:05:22 +02:00
Ein Server muss minimal vorbereitet sein, bevor dieser per Ansible z.B. zu einem Freifunk-Gateway gemacht werden
kann. Die folgenden Voraussetzungen müssen erfüllt sein:
2016-06-21 16:32:27 +02:00
- Ein dedizierter (v)server muss existieren und unter einer IPv4- und einer IPv6-Adresse öffentlich erreichbar sein.
- Die Adressen müssen im MWU-DNS eingetragen sein.
2017-09-06 12:05:22 +02:00
- Als Betriebssystem muss Debian stretch installiert sein.
- Für ansible muss Python 2.5 oder Python 2.4 + python-simplejson installiert sein.
- Es muss einen User admin geben, auf den die Admins Zugriff haben; dieser muss Root-Zugang über sudo haben.
2016-06-21 16:32:27 +02:00
Die Voraussetzungen werden von der Rolle `prerequisites` geprüft, die Rolle sollte als erste Rolle in jedem
Playbook eingebunden sein.
Die Server werden mit ihren FQDNs im Ansible Inventory hinterlegt, bedenkt das für eure ssh-config.
2016-07-24 01:57:37 +02:00
## Variablen für jedes Mesh
2016-07-24 01:57:37 +02:00
Viele Rollen brauchen spezifische Informationen, wie IP-Adresse, Masken, Interface-Namen, etc.
Wir verwalten diese Mesh-Informationen in einer Liste von Dictionaries unter `inventory/group_vars/all`:
2016-07-24 01:57:37 +02:00
```
meshes:
- id: mz
site_number: 37
site_code: ffmz
site_name: Mainz
ipv4_network: 10.37.0.0/18
ipv6_ula:
- fd37:b4dc:4b1e::/48
ipv6_public:
- 2a03:2260:11a::/48
dnssl:
- ffmz.org
- user.ffmz.org
batman:
it: 10000
gw: server 96mbit/96mbit
mm: 0
dat: 0
2017-10-03 21:36:14 +02:00
hop_penalty: 60
radvd:
maxrtradvinterval: 900
advvalidlifetime: 864000
advpreferredlifetime: 172800
iface_mtu: 1350
fastd:
nodes:
instances:
- id: 0
mtu: 1406
peers:
repo: https://github.com/freifunk-mwu/peers-ffmz.git
version: master
- id: 1
mtu: 1312
peers:
repo: https://github.com/freifunk-mwu/peers-ffmz.git
version: master
intragate:
instances:
- id: 0
mtu: 1406
peers:
repo: https://github.com/freifunk-mwu/ffmz-infrastructure-peers.git
version: master
2017-10-03 21:36:14 +02:00
dns:
master: fd37:b4dc:4b1e::a25:103
forward_zones:
- name: ffmz.org
- name: user.ffmz.org
- name: bb.ffmz.org
- name: nodes.ffmz.org
- name: ffbin
2017-10-03 21:36:14 +02:00
master: fd37:b4dc:4b1e::a25:10c
2016-07-24 01:57:37 +02:00
- id: wi
site_number: 56
site_code: ffwi
site_name: Wiesbaden
ipv4_network: 10.56.0.0/18
ipv6_ula:
- fd56:b4dc:4b1e::/48
ipv6_public:
- 2a03:2260:11b::/48
dnssl:
- ffwi.org
- user.ffwi.org
batman:
it: 10000
gw: server 96mbit/96mbit
mm: 0
dat: 0
2017-10-03 21:36:14 +02:00
hop_penalty: 60
radvd:
maxrtradvinterval: 900
advvalidlifetime: 864000
iface_mtu: 1350
fastd:
nodes:
instances:
- id: 0
mtu: 1406
peers:
repo: https://github.com/freifunk-mwu/peers-ffwi.git
version: master
- id: 1
mtu: 1312
peers:
repo: https://github.com/freifunk-mwu/peers-ffwi.git
version: master
intragate:
instances:
- id: 0
mtu: 1406
peers:
repo: https://github.com/freifunk-mwu/ffwi-infrastructure-peers.git
version: master
2017-10-03 21:36:14 +02:00
dns:
master: fd56:b4dc:4b1e::a38:103
forward_zones:
- name: ffwi.org
- name: user.ffwi.org
- name: bb.ffwi.org
- name: nodes.ffwi.org
```
2016-07-24 01:57:37 +02:00
## Sensible Informationen
Sensible Daten, z.B. private keys für Dienste wie fastd und tinc verwalten wir in einem [Password Store](https://www.passwordstore.org/).
Falls ihr mehrere Password Stores verwaltet, denkt vor Benutzung von Ansible daran, die Umgebungsvariable auf den richtigen Store zu verweisen:
```
2017-10-03 21:36:14 +02:00
export PASSWORD_STORE_DIR=...
```
2016-07-24 01:57:37 +02:00
## Aufsetzen eines neuen Gateways
2016-07-24 01:57:37 +02:00
- FQDN im Inventory zur Gruppe ffmwu-gateways hinzufügen
- Host-Variablen setzen
- inventory/host_vars/$FQDN
2016-07-24 01:57:37 +02:00
```
---
# Gateway-Nummer, von der vieles abgeleitet wird. Integer zwischen 1-254. Muss eindeutig unter allen FFMWU Servern sein.
2017-10-03 21:36:14 +02:00
magic:
2016-07-24 01:57:37 +02:00
2017-10-03 21:36:14 +02:00
# Die Nummer des /22er IPv4-Subnetzes, das per DHCP verteilt werden soll.
2017-10-06 14:04:29 +02:00
# z.B. 5 für 10.X.16.0/22 (fünftes /22 Subnetz aus 10.X.0.0/18)
2017-10-03 21:36:14 +02:00
ipv4_dhcp_range:
2016-07-24 01:57:37 +02:00
# FFRL (muss vorher bereits zugewiesen worden sein)
2017-10-03 21:36:14 +02:00
# Öffentliche IPv4 NAT Adresse, Format: IP/Prefix
ffrl_public_ipv4_nat:
2016-07-24 01:57:37 +02:00
ffrl_exit_server:
ffrl-a-ak-ber:
2017-10-03 21:36:14 +02:00
public_ipv4_address: 185.66.195.0
tunnel_ipv4_network: # Format: IP/Maske
2017-10-03 21:36:14 +02:00
tunnel_ipv6_network:
ffrl-b-ak-ber:
2017-10-03 21:36:14 +02:00
public_ipv4_address: 185.66.195.1
tunnel_ipv4_network: # Format: IP/Maske
2017-10-03 21:36:14 +02:00
tunnel_ipv6_network:
ffrl-a-ix-dus:
2017-10-03 21:36:14 +02:00
public_ipv4_address: 185.66.193.0
tunnel_ipv4_network: # Format: IP/Maske
2017-10-03 21:36:14 +02:00
tunnel_ipv6_network:
ffrl-b-ix-dus:
2017-10-03 21:36:14 +02:00
public_ipv4_address: 185.66.193.1
tunnel_ipv4_network: # Format: IP/Maske
2017-10-03 21:36:14 +02:00
tunnel_ipv6_network:
ffrl-a-fra2-fra:
2017-10-03 21:36:14 +02:00
public_ipv4_address: 185.66.194.0
tunnel_ipv4_network: # Format: IP/Maske
2017-10-03 21:36:14 +02:00
tunnel_ipv6_network:
ffrl-b-fra2-fra:
2017-10-03 21:36:14 +02:00
public_ipv4_address: 185.66.194.1
tunnel_ipv4_network: # Format: IP/Maske
2017-10-03 21:36:14 +02:00
tunnel_ipv6_network:
# Pfade zu den fastd secrets im passwordstore
fastd_secrets:
mzVPN: "{{ lookup('passwordstore', 'fastd/mzVPN/$Hostname subkey=secret') }}"
wiVPN: "{{ lookup('passwordstore', 'fastd/wiVPN/$Hostname subkey=secret') }}"
mzigVPN: "{{ lookup('passwordstore', 'fastd/mzVPN/$Hostname subkey=secret') }}"
wiigVPN: "{{ lookup('passwordstore', 'fastd/wiVPN/$Hostname subkey=secret') }}"
2016-07-24 01:57:37 +02:00
2017-10-03 21:36:14 +02:00
# Pfade zum tinc secret im passwordstore
tinc_private_key: "{{ lookup('passwordstore', 'tinc/icVPN/$hostname_private returnall=true') }}"
```
2017-09-06 12:05:22 +02:00
- Neues Gateway aufsetzen per `ansible-playbook playbooks/gateways.yml`
- Hierbei werden die definierten Rollen auch auf schon aufgesetzte Gateways angewandt, was unkritisch ist, weil wir unsere Rollen idempotent schreiben.
2017-09-06 12:05:22 +02:00
- Um die Rollen nur auf das neu aufzusetzende Gateway anzuwenden: `ansible-playbook playbooks/gateways.yml --limit=$FQDN`