LFCA apprend la disponibilité, les performances et l'évolutivité du cloud - Partie 14
- 2067
- 285
- Clara Nguyen
Dans le sujet précédent de notre série LFCA, nous avons donné une introduction au cloud computing, les différents types et nuages et les services cloud et vous avons parcouru certains des avantages associés au cloud computing.
Si votre entreprise monte toujours sur l'environnement informatique informatique traditionnel, il est temps que vous vous dirigeiez et déplacez-vous vers le cloud. On estime qu'à la fin de 2021, plus de 90% de la charge de travail totale sera gérée dans le cloud.
Parmi les principaux avantages associés à l'adoption du cloud computing figurent les performances, la haute disponibilité et l'évolutivité. En fait, nous les avons repoussés comme l'un des principaux avantages de l'utilisation de la technologie cloud.
Dans ce sujet, nous nous concentrons sur la disponibilité, les performances et l'évolutivité du cloud et cherchons à comprendre comment ces trois fusionnent pour répondre aux demandes des clients et assurer que les utilisateurs accèdent à leurs données car ils en ont besoin depuis n'importe quelle partie du monde.
1. Disponibilité du cloud
Les applications et services informatiques d'une organisation sont essentiels et toute perturbation des services peut avoir un effet profond sur les revenus. L'attente des clients est que les services sont accessibles 24 heures sur 24 à tout moment à partir de n'importe quel endroit. Et c'est ce que la technologie cloud cherche à fournir.
La haute disponibilité est l'objectif ultime du cloud computing. Il cherche à fournir le temps de disponibilité maximal possible des services d'une entreprise, même face aux perturbations qui peuvent être occasionnées par des temps d'arrêt du serveur sans précédent ou une dégradation du réseau.
La haute disponibilité est rendue possible en ayant des systèmes redondants et de basculement. Cela se produit dans un environnement de cluster où plusieurs serveurs ou systèmes effectuent les mêmes tâches et fournissent ainsi une redondance.
Lorsqu'un serveur tombe en panne, le reste peut continuer à s'exécuter et à fournir les services fournis par le serveur affecté. Un exemple parfait de redondance est la réplication des données sur plusieurs serveurs de base de données dans un cluster. Dans le cas où le serveur de base de données principal du cluster rencontre un problème, un autre serveur de base de données fournira toujours les données requises par les utilisateurs malgré l'échec.
La redondance élimine un seul point de défaillance et garantit qu'il y en a 99.999% Disponibilité des services et applications. Le clustering fournit également l'équilibrage de charge entre les serveurs et garantit que la charge de travail est équitablement distribuée et qu'aucun serveur n'est dépassé.
2. Évolutivité des nuages
Une autre caractéristique du cloud computing est l'évolutivité. L'évolutivité est la capacité d'ajuster les ressources cloud pour répondre aux demandes changeantes. En termes simples, vous pouvez augmenter ou diminuer de manière transparente des ressources au fur et à mesure que vous avez besoin pour répondre à la demande sans compromettre la qualité des services ou des temps d'arrêt.
Supposons que vous exécutez un blog qui commence à obtenir des succès et plus de trafic. Vous pouvez facilement ajouter plus de ressources de calcul telles que le stockage, la RAM et le CPU à votre instance de calcul cloud pour gérer la charge de travail supplémentaire. Inversement, vous pouvez réduire les ressources lorsque cela est nécessaire. Cela garantit que vous ne payez que ce dont vous avez besoin, et cela souligne les économies d'échelle que le cloud fournit.
L'évolutivité est double: mise à l'échelle verticale et échelle horizontale.
Échelle verticale
Également appelé 'étendue'La mise à l'échelle verticale implique d'ajouter plus de ressources telles que la RAM, le stockage et le processeur à votre instance de calcul cloud pour s'adapter à la charge de travail supplémentaire. Ceci est l'équivalent de l'alimentation de votre PC ou serveur physique pour mettre à niveau le RAM ou ajouter un disque dur supplémentaire ou un SSD.
Mise à l'échelle horizontale
Échelle horizontale, également connue sous le nom de 'mettre à l'échelle'Implique d'ajouter plus de serveurs à votre pool de serveurs préexistants pour assurer la distribution de la charge de travail sur plusieurs serveurs. Avec une mise à l'échelle horizontale, vous n'êtes pas limité à la capacité d'un seul serveur, contrairement à l'échelle verticale. Cela offre plus d'évolutivité et moins de temps d'arrêt.
La mise à l'échelle est plus souhaitable par rapport à la mise à l'échelle
Et voici pourquoi. Avec mise à l'échelle horizontale, Vous ajoutez essentiellement plus de ressources telles que les serveurs ou le stockage à votre pool de ressources déjà existant. Cela vous permet de combiner la puissance et les performances de plusieurs instances de calcul en une seule, et d'obtenir ainsi de meilleures performances plutôt que d'ajouter des ressources sur un seul serveur. Des serveurs supplémentaires impliquent que vous n'aurez pas à faire face à un déficit de ressources.
En outre, mise à l'échelle horizontale Fournit la redondance et la tolérance aux défauts de manière à ce qu'un serveur est affecté, le reste continuera à prouver l'accès aux services requis. Échelle verticale est associé à un seul point d'échec. Si l'instance de calcul s'écrase, alors tout va avec.
Mise à l'échelle horizontale offre également une flexibilité maximale par opposition à échelle verticale Lorsque les applications sont construites comme une grande unité. Cela rend plus difficile à gérer, à mettre à niveau ou à modifier des sections de code sans avoir à redémarrer l'ensemble du système. La mise à l'échelle permet le découplage des applications et permet une mise à niveau transparent avec un temps d'arrêt minimal.
3. Performance du cloud
Assurer que les performances de l'application répondent aux demandes des clients peuvent être une tâche assez difficile, surtout si vous avez plusieurs composants assis dans différents environnements qui doivent constamment communiquer entre eux.
Des problèmes comme la latence sont susceptibles de se manifester et d'impact les performances. De plus, il n'est pas facile de prédire les performances où les ressources sont partagées par diverses entités. Quoi qu'il en soit, vous pouvez toujours atteindre des performances élevées et rester à flot en mettant en œuvre les mesures suivantes.
1. Instance cloud
Assurez-vous d'utiliser les bonnes instances de cloud avec suffisamment de ressources pour gérer les charges de travail de vos applications et services. Pour les applications à forte intensité de ressources, assurez-vous de fournir suffisamment de RAM, de CPU et de ressources de stockage à votre instance cloud pour éviter un éventuel déficit de ressources.
2. Équilibreur de charge
Implémentez un équilibreur de charge pour distribuer équitablement le trafic réseau entre vos ressources. Cela garantira qu'aucune de vos applications n'est submergée par la demande. Supposons que votre serveur Web obtienne beaucoup de trafic qui entraîne des retards et un impact sur les performances.
Une solution parfaite serait de mettre en œuvre mise à l'échelle horizontale avec un total de 4 serveurs Web assis derrière un équilibreur de charge. L'équilibreur de charge distribuera le trafic réseau sur les 4 serveurs Web et s'assurera qu'aucun n'est submergé par la charge de travail.
3. Mise en cache
Utilisez des solutions de mise en cache pour accélérer l'accès aux fichiers par applications. Le magasin des caches lira fréquemment des données et éliminait ainsi les recherches de données constantes qui peuvent avoir un impact sur les performances. Ils réduisent la latence et la charge de travail à mesure que les données sont déjà mises en cache, améliorant ainsi les temps de réponse.
La mise en cache peut être mise en œuvre à différents niveaux tels que le niveau d'application, le niveau de base de données. Les outils de mise en cache populaires incluent Redis, Memcached et Vernis Cache.
4. Suivi de la performance
Enfin, assurez-vous de surveiller les performances de vos serveurs et applications. Les fournisseurs de cloud fournissent des outils natifs qui peuvent vous aider à garder un œil sur vos serveurs cloud à partir d'un navigateur Web.
De plus, vous pouvez prendre votre propre initiative et installer des outils de surveillance gratuits et open source qui peuvent vous aider à garder un œil sur vos applications et vos serveurs. Des exemples de telles applications incluent Grafana, Netdata et Prometheus, pour en mentionner quelques-uns.
Conclusion
Nous ne pouvons pas souligner suffisamment comment la disponibilité, l'échelle et les performances sont cruciales dans le cloud. Les trois facteurs déterminent la qualité de service que vous obtiendrez de votre fournisseur de cloud et tracerez finalement la frontière entre le succès ou l'échec de votre entreprise.
Devenez un associé IT Certified IT (LFCA)- « Comment installer Apache NiFi dans Ubuntu Linux
- Comment utiliser les scripts de moteur de script NMAP (NSE) dans Linux »