]> Git — Sourcephile - sourcephile-txt.git/blob - ddc/ddc8-une-infra.md
ddc6: renomme plurasoft vers sourcephile
[sourcephile-txt.git] / ddc / ddc8-une-infra.md
1 # Une première infrastructure informatique pour LessBuggy
2 - Demande de Critiques: 8
3 - De: Julien Moutinho (julm)
4 - À: Plurasoft
5 - Phase: Écriture
6 - Révision: 1 (2019-11-15)
7 - Licence: Creative Commons BY-SA
8 - Préoccupations: autonomie, développement, financement, librisme, maintenance, performance, sécurité, service, social
9
10 # Bilan approximatif
11 ## Analyses reconnues
12 - [G] financement
13 - [G] julm: on est sur une dépense de ~500€ de matériel pour une espérance de fonctionnement et d’usage >5ans, et un récurrent de ~60€/an pour l’hébergement. C’est un prix très correct pour ce que c’est.
14 - [T] autonomie
15 - [T] julm: on a la main sur le matériel, le logiciel, mais pas sur l’hébergement (toutefois 15km, ça reste à portée de vélo).
16 - [T] développement
17 - [T] julm: on peut mettre du NixOS, mais ce n’est pas une machine avec beaucoup de CPU et de RAM, mais ça devrait largement suffire et me dépanner tant que je n’ai pas d’élec @home.
18 - [T] performance
19 - [T] julm: la machine peut suffire pour commencer, l’hébergement aussi mais peut rapidement être limitant (ce n’est qu’une VDSL2+).
20 - [A] librisme
21 - [A] julm: on est en logiciel libre, mais que partiellement en matériel ouvert. Deux raisons bloquantes à cela : le manque de support de NixOS (quid de Guix ? et plus gravement de Haskell pour les architectures ARM.
22 - [A] maintenance
23 - [A] julm: on peut mettre du NixOS ce qui me simplifiera la tâche. L’hébergeur n’offre pas (encore) de seconde connexion via le port série et n'est que semi-professionnel, par contre il est proche.
24 - [A] sécurité
25 - [A] julm: on est en logiciel libre, mais que partiellement en matériel ouvert. Mutualiser pleins de services sur une seule machine n’est pas très sécurisant. L’hébergement est semi-professionnel (porte à serrure standard dont il n’est pas clair qui a les clés, et pas (encore) de caméra).
26 - [A] social
27 - [A] Les machines sont fabriquées à l'autre bout de la planète dans des conditions probablement déplorables.
28 - [C] service
29 - [C] julm: aucun service non-lié à la production n’est proposé aux membres.
30 ## Mentions possibles
31 - R: « À rejeter »
32 - C: « À clarifier »
33 - A: « À améliorer »
34 - T: « À tester »
35 - G: « À garder »
36
37 # Explications
38 ## Motivations
39 ### S'émanciper d'autogeree.net
40 Les logiciels que j'écris sont actuellement hébergés sur `chomsky.autogeree.net`, une machine virtuelle (VM) relativement modeste que me fournie Grésille depuis 2011 (en contre-partie d'un Dell R210 surnommé « chomsky » et acquis dans l'enthousiasme naïf de l'essaimage de FDN, puis resurnommé « rouf » par Grenode). Cette VM m'a longtemps servi de bac à sable pour jouer à l'adminsys, qui sert encore à un copain et moi-même pour avoir du mél et de l'IRC.
41
42 `chomsky` est une Debian dans une machine virtuelle Xen (1 CPU, 750Mo de RAM, 50Go de stockage **probablement** HDD), dans une machine hébergée professionnellement en datacenter à Grenoble. Cette machine est actuellement reliée à l'Internet par une autre infrastructure de Grenode à Lyon (au Netcenter via l'association Rézopole).
43 `chomsky` n’a pas vraiment les ressources d’une machine de développement (nixpkgs c’est déjà 10Go de stockage, stack 5Go, et le REPL de GHC ou de PureScript c’est minimum 0.5Go de RAM).
44
45 ### S'émanciper de Debian
46 Depuis que je me suis mis à NixOS, je ne suis plus enthousiasmé par Debian. En tant que dev il est bien plus facile de faire et de partager de manière reproductible et récente des paquets NixOS que des paquets Debian (dans le cas de paquets Haskell tout du moins). Et en tant qu'adminsys il est bien plus facile de maîtriser ce qu'il se passe sur une NixOS que sur une Debian. Le seul avantage de Debian en ce qui me concerne c'est sa plus grande portabilité sur des architectures basse conso ou OSHW comme certaines ARM ou MIPS. Mais ce n'est **certainement** qu'un avantage temporaire.
47 Pour approfondir ces raisons techniques, on peut voir par exemple les tutoriels francophones de Nokomprendo : https://nokomprendo.gitlab.io/
48
49 Cependant, il est **peu probable** que je puisse passer `chomsky` sous NixOS, car mon copain n’envisage pas de se mettre à NixOS, et puis c'est une opération risquée demandant une intervention délicate sur une machine hébergeant actuellement des services en production (essentiellement nos méls persos en MX n°1).
50
51 - https://www.fsf.org/resources/hw
52 - https://wiki.debian.org/FreedomBox/Hardware
53 - https://nixos.wiki/wiki/NixOS_on_ARM
54
55 ## Objectif
56 ### Objectif minimal : infra de développement
57 Cette infra adresse en priorité les besoins du développement : dépôts Git publiables et boîtes méls dédiées.
58 - Noms de domaine (nsd4, unbound)
59 - Shell distant SSH (openssh)
60 - Authentification double: yubikey
61 - Pare-feu (shorewall)
62 - Forge logicielle (gitolite, gitweb, nginx)
63 - Adresses méls (postfix, dovecot2, rspamd)
64 - Listes méls internes (aliases postfix)
65
66 ### Objectif modeste : infra de collaboration
67 Cette infra adresse en priorité les besoins de la collaboration en ligne : stockages sécurisés et connexions sécurisées.
68 - Chiffrement du stockage (logiciel par dm-crypt, dropbear)
69 - Certificats X.509 pour du HTTPS (certbot, nginx)
70 - Gestion des accès (unix | openldap)
71 - Partages volumineux en ligne (nextcloud)
72 - Partages jetables (pastebin interne | pastebin externe)
73 - Ecriture collaborative en ligne en temps réel (gobby | etherpad)
74 - Messagerie instantanée (salon IRC type #plurasoft@irc.freenode.net ou #plurasoft@irc.oftc.net | prosody interne | serveur Jabber externe)
75 - (optionnel) Calendriers en ligne (davical | nextcloud)
76 - (optionnel) VPN DNS (iodined)
77 - (optionnel) Audioconf (mumble)
78 - (optionnel) VPN (wireguard)
79 - (optionnel) Visioconf (jitsi)
80
81 ### Objectif honorable : infra de communication
82 Cette infra adresse en priorité les besoins de la communication en ligne : sites Web de présentation et réseaux sociaux en ligne.
83 - Site Web de rendu des journaux de bord (nginx)
84 - Site Web de rendu des demandes de critiques (nginx)
85 - Site Web de rendu des documentations (nginx)
86 - Site Web des (futures) démonstrations (lessbuggy-vote, lessbuggy-doc, lessbuggy-compta, lessbuggy-loto)
87 - (optionnel) Microblogging (mastodon | serveur externe)
88
89 ### Objectif ambitieux : infra de mise en commun
90 Cette infra adresse en priorité les besoins de la mise en commun en ligne :
91 - Listes méls publiques (discourse)
92 - Forums publics (discourse)
93
94 ### Objectif maximal : infra de services
95
96
97 # Actions
98 ## Serveur APU2 de PCengines
99 L’APU2 est un routeur conçu par une entreprise suisse (PCengines) et fabriqué à Taïwan. Le CPU est un AMD, dont l'architecture « x86_64 » est officiellement supportée par NixOS et ses caches binaires. Ce n'est pas complètement en matériel ouvert car certains composants clés comme le CPU ne le sont pas, mais PCengines publie ce qu'elle fait elle pour sa part (schémas et code source des modifications à Coreboot).
100
101 L’APU2 est généralement utilisé comme routeur, mais peut aussi servir de petit (en terme de services peu gourmands côté serveur) serveur, voire de petit (en taille de stockage) « NAS » (Network Attached Storage), voire de petite (en puissance de calculs) machine de développement pour dépanner.
102
103 L’APU a plusieurs versions : APU2, APU3 et APU4.
104 L'APU2 est annoncé comme celui consommant le moins : 10W max contre 12W max pour l’APU3 et l’APU4.
105 L’APU3 est optimisé pour faire de la 3G/LTE.
106 Et l’APU4 a un quatrième port Ethernet.
107
108 ### Caractéristiques
109 - Processeur : AMD G series GX-412TC, 1 GHz quad core (Jaguar core) with 64 bit support, AES-NI, 32K data + 32K instruction cache per core, 2MB shared L2 cache
110 - 170€HT, http://store.clemanis.com (PCE-APU2D4)
111 - 148€HT, https://teklager.se/en/products/router-components/pc-engines-apu2d4
112 - Coprocesseur : AMD CCP (pour cryptographie AES-GCM) https://openwrt.org/toh/pcengines/apu2#cryptographic_hardware
113 - Mémoire : 1x 4Go DDR3-DRAM 1333Mhz ECC (soudée !) (4Go permet de rester en 32 bits)
114 - Stockage : Boot from SD card (built-in adapter, connected through USB), USB or m-SATA SSD. 1 SATA data + power connector
115 - Électricité : 12V DC. About 6 to 10W depending on CPU load. Recommend for at least 1.5A to provide margin for peripherals
116 - Extensions : 2 miniPCI express (one with SIM socket for 3G modem), LPC bus, GPIO header, optional I2C bus, COM2 (3.3V RXD/TXD)
117 - Réseau : 3 Gigabit Ethernet (Intel i210AT / i211AT), 1 DB9 serial port (console)
118 - Firmware : CoreBoot open source system BIOS with support for iPXE and USB boot
119 - Taille : 152,4mm x 152,4mm
120 - 35€HT, http://store.clemanis.com (RMT-CASE-S1)
121 - 12€HT, https://teklager.se/en/products/router-components/pc-engines-apu-enclosure
122 - Refroidissement : conductive cooling from the CPU to the enclosure
123 - Conception : Suisse
124 - Fabrication : Taïwan
125
126 ### Mémoire
127 4GB de RAM ce n’est pas énorme, ce serait peut-être même trop peu pour une machine de build, mais pour un serveur hébergeant des choses assez légères c'est pas mal. D’un point de vue sécurité, il semble d'ailleurs préférable d'avoir plusieurs petites machines physiques distinctes qu’une grosse machine blindée hébergeant des machines virtuelles. Machines blindées qu'on ne trouvera d'ailleurs probablement pas de si tôt en matériel ouvert.
128 La RAM a de l’ECC (Error Correcton Code), supportée depuis peu dans le firmware.
129 ### Réseau
130 Quelques commentaires signalent que l’APU2 sature un peu quand il s’agit d’utiliser la pleine connectivité d’une fibre optique via un VPN ne pouvant utiliser qu'un seul coeur de CPU (single thread) type OpenVPN, avec certains types d'algorithmes de chiffrement. L'APU2 aurait un horloge CPU trop lente et un cache L2 trop petit.
131 Mais ici le VPN n'est pas un objectif premier et pas à ces débits là. Et à PTT il n’y a pas de fibre optique pour le moment de toute façon.
132 ### Maintenance
133 La présence d’un port série permet un accès de maintenance plus simple et plus sécurisé que de l’IPMI (qui est un second OS en parallèle).
134 Cependant PTT n'a pas de switch de ports série pour le moment.
135
136 Câbles utiles :
137 - USB to serial port
138 - 17€HT, https://www.ldlc.com/fiche/PB00026389.html
139 - 11€HT, https://teklager.se/en/products/router-components/serial-to-usb-cable
140 - null-modem "DB9" serial cable, 5€HT, https://www.ldlc.com/fiche/PB00170050.html
141 ### Stockage
142 Il est possible de mettre deux disques SSD, un sur le port mSATA et un sur le port SATA.
143 Il est aussi possible de mettre une extension PCIe pour rajouter 4 ports SATA : https://pcengines.ch/howto.htm#add_on_cards
144 Il est également possible de mettre une carte SD, mais les cartes SD tendent à mourrir plus vite et sont plus lentes.
145 ### Enclosure
146 Il existe de nombreuses enclosures.
147 Les noires dissipent mieux la chaleur : https://openwrt.org/toh/pcengines/apu2
148 La RMT-CASE-S1 de Clemanis est 15€ plus chère que d’autres enclosures plus petites, mais permet de stocker deux disques 2.5" sur le côté, ou de mettre une extension : http://store.clemanis.com/en/cases/324-pc-engines-alix-2d22d32d13-apu1apu2-case-with-hdd-wifi-black-3700667301379.html
149
150 ### Espérance de fonctionnement
151 Matériellement, les disques peuvent mourrir assez vite, entre 3 et 5 ans.
152 Une redondance en RAID1 logiciel (mdadm) rendra **probablement** le remplacement assez simple.
153 La carte de l’APU2 devrait pouvoir durer plus de 10 ans.
154 Mais le fait que la RAM soit soudée fait qu'il faudra tout changer si elle vient à avoir des défaillances.
155
156 Concernant l'usage, à court et moyen terme les disques n'ont pas besoin d'être particulièrement grands, 64GB ou 128GB seront largement assez.
157
158 ### Ressources
159 - https://pcengines.ch/howto.htm
160 - https://openwrt.org/toh/pcengines/apu2
161 - https://www.cs.cmu.edu/~davide/howto/apu4c4.html
162 - https://blog.linuxserver.io/2016/12/17/review-pcengines-apu2-c4-prebuilt-by-linitx/#vpnperformance
163 - https://teklager.se/en/knowledge-base/
164
165 ## 120GB de stockage
166 TODO: détailler l’usage
167
168 ## Hébergement chez PTT
169 PTT propose de l’hébergement à Tarnac (Corrèze).
170 L’hébergement se fait dans une petite salle dédiée et climatisée d’un "tier-lieu" (médiathèque, cyberespace) du village.
171 La connexion est derrière une VDSL2+ fournie par l’association Ilico.
172
173 - https://www.fnac.com/mp37714266/Transcend-ts128gmsa230s-ssd-interne-msata-iii-128-go-sata-iii-6-gbps-3d-tlc/w-4
174 - https://www.ldlc.com/fiche/PB00253086.html
175
176 ## Travaux futurs
177 ### Backups automatiques
178 ### Machine de build ARM
179
180 # Critiques
181 ## Inconvénients
182 ### Vulnérabilités Metldown et Spectre
183 Problème : l’AMD GX-412TC de l’APU2 est vulnérable à Meltdown et Spectre. L’atténuation n’est que partielle : https://blog.3mdeb.com/2019/2019-05-29-spectre-and-meltdown-on-apu2/
184
185 Réponse : tous les CPU Intel ou AMD sont plus ou moins affectés par ces vulnérabilités.
186
187 ### nsd4 et iodined nécessitent tous deux le port 53
188 Problème : normalement nsd4 et iodined sont incompatibles sur une seule et même IPv4 (à 3€/mois ici), car ils requièrent tous deux l’écoute sur le port 53 du DNS.
189
190 Réponse : il est possible de mutualiser ce port avec une règle iptables du genre : `-A nat -p udp --dport 53 -m string --algo kmp --from 40 --hex-string |01|i|05|plura|02|fr|00| -j DNAT --to-destination :5353` où iodined écoute maintenant sur le port 5353.
191
192 ## Question non-résolues
193 ## Alternatives
194 ### TLsense
195 - Processeur : Intel i3 | i5 | i7
196 - i7 : https://teklager.se/en/products/routers/tlsense-i7-4lan
197 - Mémoire : 8Go
198 - Réseau : 4x Gigabit Ethernet
199 - Conception : Suède
200 - Fabrication : ?
201
202 ### Helios4
203 - Infos : https://kobol.io/helios4/
204 - Prix : 177€
205 Open hardware mais ARM pas x86, et plus en vente pour le moment.
206
207 ### HPE ProLiant MicroServer
208 - Processeur : AMD Opteron X3416 (2x 1.6–3.0GHz) | X3421 (4x 2.1–3.4GHz)
209 - Mémoire : 1x 8Go (max 2x 16Go) DDR4-SDRAM (X3416: 1600Mhz | X3421: 2400MHz) Unbuffered ECC (non-soudées)
210 - Cache L2 : X3416: 1Mo | X3421: 12Mo
211 - Réseau : 2x Gigabit Ethernet
212 - Électricité : 12-35W
213 - Stockage : 4x SATA 3.5"
214 - Extensions : 2x PCIe 3.0
215 - Prix :
216 - X3416 : 328€HT https://www.senetic.fr/product/873830-421
217 - X3421 : 415€HT https://www.senetic.fr/product/P04923-421
218 - Conception : USA
219 - Fabrication : ?