Ajouter un schéma
Les composants
Orchestrateur - L'orchestrateur est en charge de placer les applications sur les serveurs de sorte qu'en cas de crash, une application soit relancée ailleurs. En fonctionnement nominal, l'orchestrateur se charge de placer les applications de sorte à ce que les ressources soient utilisées au mieux. Nous utilison le logiciel Nomad à ces fins.
↣ Accéder au code source de Nomad
Catalogue de service - Le catalogue de service permet aux services ayant des dépendances, par exemple Matrix a une dépendance sur PostgreSQL et Garage, de savoir comment contacter ces dépendances. Pour ce faire, nous utilisons Consul, qui nous sert également à gérer nos secrets.
↣ Accéder au code source de Consul
Base de données relationnelle - Les bases de données relationnelles sont au coeur de la plupart des applications web car elles permettent de requêter efficacement des données structurées. Nous utilisons PostgreSQL qui est un des standard du libre, et afin de le distribuer, nous utilisons Stolon.
↣ Accéder au code source de PostgreSQL
↣ Accéder au code source de Stolon
Base de données NoSQL - Nous prévoyions certains développements spécifiques, pour lesquels nous avons le loisir de définir la structure de données. Dans ce cas, nous pouvons l'optimiser pour Garage K2V qui est bien plus facile à opérer que PostgreSQL.
↣ Accéder au code source de Garage
Stockage objet - De nombreuses applications ont besoin de stocker des fichiers également, des données considérées non structurées dans ce cas. Ici l'enjeu n'est plus tant de pouvoir requêter les données avec souplesse que de pouvoir stocker de grands volumes. On peut prendre comme exemple les médias (photo, vidéo) partagés sur Matrix. Nous utilisons l'API S3 de Garage pour ces besoins.
↣ Accéder au code source de Garage
Authentification - Afin de faciliter la vie des usager-es, il est possible de proposer un système d'authentification unique. Pour commencer, nous avons choisi le protocole LDAP qui a pour principal avantage d'être largement installé et compatible, principalement grâce à son ancienneté. Nous utilisons notre propre implémentation, nommée Bottin.
↣ Accéder au code source de Bottin
Conteneurs - Afin de packager, publier et isoler les différentes applications qui fonctionnent sur nos serveurs, nous utilisons des conteneurs Linux, et plus précisément, Docker. Afin de créer des images les plus petites possibles, nous utilisons NixOS. Pour certaines vieilles images, nous utilisons encore Debian.
↣ Accéder au code source de Docker
↣ Accéder au code source de Nix
↣ Accéder au code source de Debian