Comment installer MODX Revolution sur un VPS CentOS 7 LAMP
Vous utilisez un système différent? MODX Revolution est un système de gestion de contenu (CMS) de niveau entreprise rapide, flexible, évolutif, gratuit et open source écrit i
Docker Swarm transforme vos serveurs individuels en un cluster d'ordinateurs, facilitant la mise à l'échelle, la haute disponibilité et l'équilibrage de charge. L'équilibreur de charge Swarm implémente une stratégie d'équilibrage de charge à tour de rôle et cela peut interférer avec le bon fonctionnement des applications avec état (héritées) qui nécessitent une certaine forme de sessions persistantes pour permettre une configuration à haute disponibilité avec plusieurs instances. Docker Enterprise Edition prend en charge la session persistante Layer-7, mais dans ce guide, nous nous concentrerons sur la version gratuite (CE) de Docker. Pour implémenter des sessions persistantes, nous utiliserons Traefik.
Dans ce tutoriel, nous utiliserons deux instances Vultr avec des adresses IP privées 192.168.0.100 et 192.168.0.101, les deux étant des nœuds de gestionnaire Docker Swarm (ce qui n'est pas idéal pour la production mais suffisant pour ce tutoriel).
Ce didacticiel utilise l' jwilder/whoami
image docker comme application de démonstration. Ce conteneur simple répondra à un appel REST avec le nom du conteneur répondant, ce qui permet de tester très facilement si les sessions persistantes fonctionnent. Cette image n'est utilisée qu'à des fins de démonstration et doit être remplacée par l'image de votre propre application. Le whoami-service
est configuré comme suit:
sudo docker network create whoaminet -d overlay
sudo docker service create --name whoami-service --mode global --network whoaminet --publish "80:8000" jwilder/whoami
sudo firewall-cmd --zone=public --add-port=80/tcp --permanent
sudo firewall-cmd --reload
Si nous devions par curl
la suite le whoami
point de terminaison REST à http://192.168.0.100/
, nous pouvons voir l'équilibrage de charge à tour de rôle de Docker Swarm à l'œuvre.
curl http://192.168.0.100
I'm a6a8c9294fc3
curl http://192.168.0.100
I'm ae9d1763b4ad
curl http://192.168.0.100
I'm a6a8c9294fc3
curl http://192.168.0.100
I'm ae9d1763b4ad
curl http://192.168.0.100
I'm a6a8c9294fc3
Il n'a aucune utilité de le tester avec des navigateurs modernes comme Chrome ou Firefox, car ils sont conçus pour maintenir les connexions actives (ouvertes) et l'équilibreur de charge Docker Swarm ne basculera sur l'autre conteneur qu'à chaque nouvelle connexion. Si vous souhaitez tester cela avec un navigateur, vous devrez attendre au moins 30 secondes pour que la connexion se ferme avant de l'actualiser à nouveau.
Traefik prend en charge nativement Docker Swarm, il peut détecter et enregistrer ou désenregistrer des conteneurs à la volée et il communique avec votre application via le réseau de superposition interne. Traefik a besoin de quelques informations sur votre application avant de pouvoir commencer à traiter les demandes. Ces informations sont fournies à Traefik en ajoutant des étiquettes à votre service Swarm.
sudo docker service update --label-add "traefik.docker.network=whoaminet" --label-add "traefik.port=8000" --label-add "traefik.frontend.rule=PathPrefix:/" --label-add "traefik.backend.loadbalancer.stickiness=true" whoami-service
La liste ci-dessous décrit la signification de chaque étiquette:
traefik.docker.network
: Le réseau de superposition Docker sur lequel Traefik communiquera avec votre service traefik.port
: Le port sur lequel votre service écoute (c'est le port exposé en interne, pas le port publié)traefik.frontend.rule
: PathPrefix:/
lie la racine de contexte /
à ce service.traefik.backend.loadbalancer.stickiness
: Permet des sessions persistantes pour ce serviceMaintenant que le whoami-service
a été configuré avec les étiquettes requises, nous pouvons ajouter le service Traefik à l'essaim:
sudo docker service create --name traefik -p8080:80 -p9090:8080 --mount type=bind,source=/var/run/docker.sock,destination=/var/run/docker.sock --mode=global --constraint 'node.role == manager' --network whoaminet traefik --docker --docker.swarmmode --docker.watch --web --loglevel=DEBUG
Cette commande fait un certain nombre de choses à la fois. La liste ci-dessous vous expliquera plus en détail:
--name traefik
: Le nom de notre nouveau service Docker est traefik
-p8080:80
: Nous publions le port 80
à port de Traefik 8080
(le port 80
est déjà utilisé par notre whoami-service
)-p9090:8080
: Nous publions la propre interface Web de Traefik pour le portage 9090
--mount ...
: Nous montons le Docker Socket dans le conteneur afin que Traefik puisse accéder au runtime Docker de l'hôte --global
: Nous voulons des conteneurs Traefik sur chaque nœud gestionnaire pour des raisons de haute disponibilité --constraint 'node.role == manager'
: Nous souhaitons que Traefik s'exécute uniquement sur les nœuds de gestionnaire, car les nœuds de travail ne peuvent pas fournir à Traefik les informations dont il a besoin. Par exemple, docker service ls
sur un nœud de travail ne fonctionne pas, Traefik ne pourrait même pas découvrir quels services sont en cours d'exécution--network whoaminet
: Connecte Traefik au même réseau que le nôtre whoami-service
, sinon ils ne peuvent pas se connecter. Nous avons précédemment dit à Traefik de se connecter à notre service sur ce réseau avec le traefik.docker.network
labeltraefik
: Indiquer à docker d'utiliser la dernière image de docker Traefik pour ce service--docker --docker.swarmmode --docker.watch --web --loglevel=DEBUG
: Arguments de ligne de commande passés directement à Traefik pour lui permettre de s'exécuter en mode Swarm Docker ( --loglevel=DEBUG
est facultatif ici mais intéressant lors de la configuration et pour ce tutoriel)Il ne reste plus qu'à ouvrir les ports nécessaires dans le pare-feu CentOS:
sudo firewall-cmd --zone=public --add-port=8080/tcp --permanent
sudo firewall-cmd --zone=public --add-port=9090/tcp --permanent
sudo firewall-cmd --reload
Dès que Traefik démarre, vous pouvez voir dans les journaux que Traefik découvre les deux whoami
conteneurs. Il génère également le nom du cookie qu'il utilisera pour gérer la session persistante:
time="2018-11-25T13:17:30Z" level=debug msg="Configuration received from provider docker: {\"backends\":{\"backend-whoami-service\":{\"servers\":{\"server-whoami-service-1-a179b2e38a607b1127e5537c2e614b05\":{\"url\":\"http://10.0.0.5:8000\",\"weight\":1},\"server-whoami-service-2-df8a622478a5a709fcb23c50e689b5b6\":{\"url\":\"http://10.0.0.4:8000\",\"weight\":1}},\"loadBalancer\":{\"method\":\"wrr\",\"stickiness\":{}}}},\"frontends\":{\"frontend-PathPrefix-0\":{\"entryPoints\":[\"http\"],\"backend\":\"backend-whoami-service\",\"routes\":{\"route-frontend-PathPrefix-0\":{\"rule\":\"PathPrefix:/\"}},\"passHostHeader\":true,\"priority\":0,\"basicAuth\":null}}}"
time="2018-11-25T13:17:30Z" level=debug msg="Wiring frontend frontend-PathPrefix-0 to entryPoint http"
time="2018-11-25T13:17:30Z" level=debug msg="Creating backend backend-whoami-service"
time="2018-11-25T13:17:30Z" level=debug msg="Adding TLSClientHeaders middleware for frontend frontend-PathPrefix-0"
time="2018-11-25T13:17:30Z" level=debug msg="Creating load-balancer wrr"
time="2018-11-25T13:17:30Z" level=debug msg="Sticky session with cookie _a49bc"
time="2018-11-25T13:17:30Z" level=debug msg="Creating server server-whoami-service-1-a179b2e38a607b1127e5537c2e614b05 at http://10.0.0.5:8000 with weight 1"
time="2018-11-25T13:17:30Z" level=debug msg="Creating server server-whoami-service-2-df8a622478a5a709fcb23c50e689b5b6 at http://10.0.0.4:8000 with weight 1"
time="2018-11-25T13:17:30Z" level=debug msg="Creating route route-frontend-PathPrefix-0 PathPrefix:/"
time="2018-11-25T13:17:30Z" level=info msg="Server configuration reloaded on :80"
time="2018-11-25T13:17:30Z" level=info msg="Server configuration reloaded on :8080"
Si nous nous recroquevillons, http://192.168.0.100:8080
nous pouvons voir qu'un nouveau cookie _a49bc
a été défini:
curl -v http://192.168.0.100:8080
* About to connect() to 192.168.0.100 port 8080 (#0)
* Trying 192.168.0.100...
* Connected to 192.168.0.100 (192.168.0.100) port 8080 (#0)
> GET / HTTP/1.1
> User-Agent: curl/7.29.0
> Host: 192.168.0.100:8080
> Accept: */*
>
< HTTP/1.1 200 OK
< Content-Length: 17
< Content-Type: text/plain; charset=utf-8
< Date: Sun, 25 Nov 2018 13:18:40 GMT
< Set-Cookie: _a49bc=http://10.0.0.5:8000; Path=/
<
I'm a6a8c9294fc3
* Connection #0 to host 192.168.0.100 left intact
Si, lors d'appels ultérieurs, nous envoyons ce cookie à Traefik, nous serons toujours transférés vers le même conteneur:
curl http://192.168.0.100:8080 --cookie "_a49bc=http://10.0.0.5:8000"
I'm a6a8c9294fc3
curl http://192.168.0.100:8080 --cookie "_a49bc=http://10.0.0.5:8000"
I'm a6a8c9294fc3
curl http://192.168.0.100:8080 --cookie "_a49bc=http://10.0.0.5:8000"
I'm a6a8c9294fc3
curl http://192.168.0.100:8080 --cookie "_a49bc=http://10.0.0.5:8000"
I'm a6a8c9294fc3
Le cookie ne contient que l'adresse IP interne (superposition) du conteneur auquel Traefik doit envoyer la demande. Si vous modifiez la valeur du cookie en, http://10.0.0.4:8000
la demande serait effectivement transmise à l'autre conteneur. Si le cookie ne devait jamais être renvoyé à Traefik, la session persistante ne fonctionnera pas et les demandes seront équilibrées entre les conteneurs de l'application et les conteneurs Traefik.
C'est tout ce qui est nécessaire pour configurer les sessions persistantes de couche 7 dans Docker CE sur CentOS 7.
Vous utilisez un système différent? MODX Revolution est un système de gestion de contenu (CMS) de niveau entreprise rapide, flexible, évolutif, gratuit et open source écrit i
Vultr vous offre une connectivité réseau privée impressionnante pour les serveurs fonctionnant au même endroit. Mais parfois, vous voulez deux serveurs dans des pays différents
Vous utilisez un système différent? Introduction CyberPanel est lun des premiers panneaux de contrôle du marché à la fois open source et utilisant OpenLiteSpeed. Quest-ce que
Vous utilisez un système différent? ESpeak peut générer des fichiers audio de synthèse vocale (TTS). Ceux-ci peuvent être utiles pour de nombreuses raisons, telles que la création de votre propre Turin
Vous utilisez un système différent? Thelia est un outil open source pour la création de sites Web de commerce électronique et la gestion de contenu en ligne, écrit en PHP. Code source Thelia i
BBR (Bottleneck Bandwidth and RTT) est un nouvel algorithme de contrôle de congestion qui est contribué à la pile TCP du noyau Linux par Google. Avec BBR en place,
YOURLS (Your Own URL Shortener) est une application open source de raccourcissement dURL et danalyse de données. Dans cet article, nous couvrirons le processus dinstallation
Vous utilisez un système différent? RTMP est idéal pour diffuser du contenu en direct. Lorsque RTMP est associé à FFmpeg, les flux peuvent être convertis en différentes qualités. Vultr i
LimeSurvey est un outil de sondage en ligne gratuit et open source qui est largement utilisé pour publier des sondages en ligne et recueillir des commentaires sur les sondages. Dans cet article, je vais
Introduction Java est une plate-forme logicielle populaire qui vous permet de développer et dexécuter des applications et des applets Java dans divers environnements matériels. Il y a
Vous utilisez un système différent? Le forum Vanilla est une application de forum open source écrite en PHP. Il est entièrement personnalisable, facile à utiliser et prend en charge externa
Vous utilisez un système différent? Netdata est une étoile montante dans le domaine de la surveillance des métriques système en temps réel. Par rapport à dautres outils du même type, Netdata:
Dans ce didacticiel, découvrez comment configurer un serveur multijoueur Just Cause 2. Prérequis Veuillez vous assurer que le système est entièrement mis à jour avant de commencer
Vous utilisez un système différent? Dans ce tutoriel, je vais vous expliquer comment configurer un serveur Starbound sur CentOS 7. Prérequis Vous devez posséder ce jeu sur vous
ZNC est un videur IRC gratuit et open-source qui reste connecté en permanence à un réseau afin que les clients puissent recevoir des messages envoyés lorsquils sont hors ligne. Thi
Django est un framework Python populaire pour lécriture dapplications Web. Avec Django, vous pouvez créer des applications plus rapidement, sans réinventer la roue. Si tu veux
ionCube Loader est une extension PHP qui permet à un serveur Web dexécuter des fichiers PHP qui ont été encodés à laide dionCube Encoder et qui est requis pour exécuter e
Vous utilisez un système différent? Reader Self 3.5 est un lecteur RSS auto-hébergé simple et flexible, gratuit et open source et une alternative à Google Reader. Reader Sel
Introduction Dans ce tutoriel, installez bien PufferPanel sur notre Vultr VPS. PufferPanel est un panneau de contrôle open source et gratuit pour vous gérer
Vous utilisez un système différent? Introduction BoltWire est un système de gestion de contenu gratuit et léger écrit en PHP. Comparé à la plupart des autres gestionnaires de contenu
Les attaques de ransomware sont en augmentation, mais l'IA peut-elle aider à lutter contre le dernier virus informatique ? L'IA est-elle la réponse ? Lisez ici, sachez que l'IA est un boone ou un fléau
ReactOS, un système d'exploitation open source et gratuit est ici avec la dernière version. Cela peut-il suffire aux besoins des utilisateurs de Windows modernes et faire tomber Microsoft ? Découvrons-en plus sur cet ancien style, mais une expérience de système d'exploitation plus récente.
Whatsapp a finalement lancé l'application de bureau pour les utilisateurs Mac et Windows. Vous pouvez désormais accéder facilement à Whatsapp depuis Windows ou Mac. Disponible pour Windows 8+ et Mac OS 10.9+
Lisez ceci pour savoir comment l'intelligence artificielle devient populaire parmi les petites entreprises et comment elle augmente les probabilités de les faire grandir et de donner à leurs concurrents un avantage.
Récemment, Apple a publié macOS Catalina 10.15.4, une mise à jour supplémentaire pour résoudre les problèmes, mais il semble que la mise à jour cause davantage de problèmes, ce qui entraîne le bridage des machines mac. Lisez cet article pour en savoir plus
13 outils commerciaux d'extraction de données de Big Data
Notre ordinateur stocke toutes les données d'une manière organisée connue sous le nom de système de fichiers de journalisation. C'est une méthode efficace qui permet à l'ordinateur de rechercher et d'afficher des fichiers dès que vous appuyez sur la recherche.https://wethegeek.com/?p=94116&preview=true
Alors que la science évolue à un rythme rapide, prenant le pas sur une grande partie de nos efforts, les risques de nous soumettre à une Singularité inexplicable augmentent également. Lisez, ce que la singularité pourrait signifier pour nous.
Un aperçu de 26 techniques d'analyse des mégadonnées : partie 1
L'IA dans le domaine de la santé a fait de grands progrès au cours des dernières décennies. Ainsi, l'avenir de l'IA dans les soins de santé continue de croître de jour en jour.