Rancher Server avec Apache Mesos, Marathon et Traefik dans Azure …

deep75

Karim

Posted on August 24, 2019

Rancher Server avec Apache Mesos, Marathon et Traefik dans Azure …

Rancher Server avec Apache Mesos, Marathon et Traefik dans Azure …

Rancher Server 1.6 paraît déprécié néanmoins il permet le déploiement rapide d’un orchestrateur de containers Docker avec Apache Mesos :

Mesos in Rancher

Je pars du déploiement d’un premier Scale Set dans Azure qui va porter le serveur Rancher 1.6 :

Le serveur Rancher émet via une adresse IP fournie par ZeroTier :

On configure préalablement son moyen d’authentification (ici local dans cet exemple) avec le serveur Rancher.

Puis il faut configurer un nouvel environnement avec Apache Mesos (en lieu et place de l’environnement Rancher Cattle par défaut) :

J’obtiens le script nécessaire au déploiement des hôtes du cluster Mesos via Rancher Agent. Après la création d’un environnement Mesos, les services d’infrastructure ne seront pas lancés tant que l’on n’aura pas ajouté au moins un hôte à l’environnement. Il faudra en effet l’ajout d’au moins 3 hôtes. Le processus d’ajout d’hôtes est le même pour tous les types d’orchestration de containers Docker. Une fois le premier hôte ajouté, Rancher Server commencera automatiquement le déploiement des services d’infrastructure incluant les services Mesos (Mesos-master, Mesos-slave et Zookeeper). On peut visualiser la progression du déploiement via le tableau de bord fourni par le serveur Rancher :

Je crée donc un nouveau Scale Set dans Azure composé de 3 instances :

accompagné de ce fichier cloud-init :

Le second Scale Set est alors opérationnel :

J’utilise ZeroTier pour m’affranchir de l’utilisation du Load Balancer fourni dans le Scale Set avec ces instances ayant par défaut une adresse IP privée :

La configuration des hôtes du cluster est réalisé à partir du déploiement de Rancher Agent :

Les trois hôtes apparaissent dans le tableau de bord de l’environnement Mesos :

ainsi que l’état des stacks d’infrastructure :

Je peux alors déployer Marathon (pour notamment l’exécution des containers Docker) via le marketplace présent dans le serveur Rancher :

Il apparaît alors dans les stacks de l’environnement Mesos :

Toujours via ZeroTier, je peux accéder à Marathon. Je lance plusieurs groupes de containers Docker via des paramêtres JSON de ce type :

Les groupes de containers sont actifs dans le cluster Mesos :

Les containers sont visualisables dans le tableau de bord du serveur Rancher :

Une interface Web est également présente pour gérer son cluster Mesos :

Pour pouvoir accéder aux services proposés par ces containers, j’installe un serveur Traefik,

The Cloud Native Edge Router

en ajoutant une instance (avec une adresse IP publique) dans le Scale Set de Rancher :

et j’utilise ce fichier TOML en configuration de ce dernier :


$ nohup sudo traefik --configFile=traefik.toml &

Le serveur Traefik avec son tableau de bord est accessible (je me contente ici de la version Camembert 1.12) :

Les adresses fournies automatiquement dans Traefik à l’aide de domaines Wildcard permettent l’accès public aux différents services déployés précédemment à l’aide des containers Docker :

On peut également recréer ce cluster dans une seule instance. Je commence pour ce nouveau test à lancer un nouveau subnet pour l’utilisation d’Azure Bastion (en preview depuis le mois dernier) :

Azure Bastion | Microsoft Azure

Il se nomme AzureBastionSubnet. Et je vais lier Azure Bastion à une nouvelle instance Ubuntu :

J’ai configuré auparavant une augmentation de la taille du disque système de cette instance pour supporter la création de ce nouveau cluster Mesos :

Je peux alors me connecter à cette instance directement depuis le portail Azure :

avec l’apparition d’une nouvelle page web avec un accès au Shell :

Installation de la dernière version de Multipass :

et création de quatres machines virtuelles qui composeront l’ossature de ce nouveau cluster Mesos (dont le serveur Rancher). Elles sont connectées comme précedemment à ZeroTier :

Après le déploiement du serveur Rancher, je peux lancer le déploiement de Rancher Agent sur les machines virtuelles et constituer mon nouveau pool d’hôtes du cluster Mesos :

Les trois hôtes sont opérationnels :

J’ai installé le service Marathon dans le cluster :

Dans Marathon, je relance mes groupes de containers Docker :

et je redéploie Traefik au sein de l’instance Multipass via ce fichier TOML (identique au précédent et en ayant modifié des adresses IP) :

Traefik me restitue automatiquement des adresses via des domaines Wildcard :

qui me permettent d’accéder aux mêmes services précédents :

Ce cluster Mesos tient donc dans cet exemple dans une seule instance sans trop de consommation :

Cette version 1.6 du serveur Rancher sera amenée à disparaître (et peut être avec elle cette méthode simple de déploiement d’un cluster Mesos même si DC/OS a déjà pris la relève depuis longtemps) :

Rancher Labs Support and Maintenance - Terms of Service

A suivre ! …

💖 💪 🙅 🚩
deep75
Karim

Posted on August 24, 2019

Join Our Newsletter. No Spam, Only the good stuff.

Sign up to receive the latest update from our blog.

Related