Articles

Conception de microservices pour l'IA

La conception de microservices pour l’IA est une tâche complexe qui nécessite une compréhension approfondie des principes de l’intelligence artificielle et des technologies modernes.

2. Event-driven Architecture

The event-driven architecture pattern is based on the concept of an event-driven system, where events are generated by components and handled by other components. In AI microservices, events are triggered by changes in data or model parameters, and the corresponding services are notified to take appropriate actions. This pattern is useful for real-time applications such as autonomous vehicles, where the system must respond quickly to changing conditions.

3. Containerization

Containerization is a key component of AI microservices, allowing for the deployment of multiple services in a single environment. This pattern enables the efficient packaging and deployment of AI models, making it easier to scale and manage them. Additionally, containers provide an isolated environment for each service, ensuring that any changes made to one service do not affect the others.

Conclusion

The integration of AI into microservices architecture is becoming increasingly important in today’s software landscape. The 10 design patterns discussed in this article are essential for developing efficient, robust, and scalable AI solutions. By leveraging these patterns, developers can create powerful AI applications that are modular, scalable, and flexible.

1. Modèle en tant que service (MaaS)

MaaS considère chaque modèle d’intelligence artificielle (IA) comme un service autonome. En exposant les fonctionnalités d’IA via des API REST ou gRPC, MaaS permet un redimensionnement et une mise à jour indépendants des modèles. Ce modèle est particulièrement avantageux pour gérer plusieurs modèles d’IA, permettant une intégration et une déploiement continus sans perturber l’ensemble du système.

2. Architecture orientée événement

Le modèle d’architecture orientée événement est basé sur le concept d’un système orienté événement, où les événements sont générés par des composants et traités par d’autres composants. Dans les microservices d’IA, les événements sont déclenchés par des changements de données ou de paramètres de modèle, et les services correspondants sont notifiés pour prendre les actions appropriées. Ce modèle est utile pour les applications en temps réel telles que les véhicules autonomes, où le système doit réagir rapidement aux conditions changeantes.

3. Conteneurisation

La conteneurisation est un composant clé des microservices d’IA, permettant le déploiement de plusieurs services dans un seul environnement. Ce modèle permet l’empaquetage et le déploiement efficaces des modèles d’IA, facilitant leur mise à l’échelle et leur gestion. De plus, les conteneurs fournissent un environnement isolé pour chaque service, ce qui garantit que tout changement apporté à un service n’affecte pas les autres.

Conclusion

L’intégration de l’IA dans l’architecture des microservices devient de plus en plus importante dans le paysage logiciel actuel. Les 10 modèles de conception discutés dans cet article sont essentiels pour développer des solutions d’IA efficaces, robustes et évolutives. En exploitant ces modèles, les développeurs peuvent créer des applications d’IA puissantes qui sont modulaires, évolutives et flexibles.

Source de l’article sur DZONE

Test d'automatisation piloté par GenAI pour moderniser les mainframes

Découvrez comment GenAI peut moderniser les mainframes grâce à son test d’automatisation innovant ! Une solution simple et efficace pour rester à la pointe de la technologie.

## La migration du code et des données d’applications principales vers des technologies contemporaines représente une phase pivotale dans l’évolution des systèmes de technologie de l’information, en particulier dans la poursuite d’une efficacité et d’une scalabilité accrues.

Software solutions such as Worksoft’s Mainframe Migration Solution provide the necessary tools to streamline the migration process and ensure the continuity of existing applications. This solution is designed to enable organizations to quickly and accurately migrate mainframe applications to modernized platforms, while simultaneously ensuring that the migrated applications maintain their original functionalities. The solution also provides automated test suite maintenance capabilities, allowing organizations to quickly and easily update their test suites as new changes are introduced. By leveraging this solution, organizations can ensure that their mainframe applications are successfully migrated and remain operational in their new environment.

La migration des codes d’application et des données de la machine principale vers des technologies contemporaines représente une phase pivotante dans l’évolution des systèmes de technologie de l’information, en particulier dans la poursuite d’une plus grande efficacité et d’une plus grande évolutivité. Cette transition, qui implique souvent le passage d’environnements hérités à des solutions sur site ou basées sur le cloud plus flexibles, n’est pas seulement un déplacement technique des ressources; c’est une transformation fondamentale qui nécessite un test rigoureux pour garantir l’équivalence fonctionnelle. L’objectif est de vérifier que ces applications, une fois exécutées sur des systèmes principaux, conservent leur intégrité et leurs normes de performance lorsqu’elles sont transférées vers des plates-formes modernisées.

Ce processus de migration est encore compliqué par la nature dynamique des environnements d’entreprise. Après la migration, les applications subissent souvent de nombreuses modifications motivées par de nouvelles exigences, des stratégies commerciales évolutives ou des changements de normes réglementaires. Chaque modification, qu’il s’agisse d’un ajustement mineur ou d’une refonte majeure, doit être soigneusement testée. Le défi critique consiste à s’assurer que ces nouveaux changements s’intègrent harmonieusement aux fonctionnalités existantes, sans induire de conséquences ou de perturbations involontaires. Cette double exigence de validation des nouvelles fonctionnalités et de sauvegarde des fonctionnalités existantes souligne la complexité du maintien du jeu de tests automatisés après la migration.

Des solutions logicielles telles que la solution de migration Mainframe Worksoft fournissent les outils nécessaires pour simplifier le processus de migration et assurer la continuité des applications existantes. Cette solution est conçue pour permettre aux organisations de migrer rapidement et précisément les applications principales vers des plates-formes modernisées, tout en garantissant que les applications migrées conservent leurs fonctionnalités originales. La solution fournit également des capacités de maintenance automatisée du jeu de tests, permettant aux organisations de mettre à jour rapidement et facilement leurs jeux de tests lorsque de nouveaux changements sont introduits. En exploitant cette solution, les organisations peuvent s’assurer que leurs applications principales sont migrées avec succès et restent opérationnelles dans leur nouvel environnement.

Source de l’article sur DZONE

Améliorer la prise de décision avec Dyna-Q et Q-Learning

Dyna-Q et Q-Learning sont des méthodes puissantes pour améliorer la prise de décision. Elles offrent des solutions innovantes et efficaces pour résoudre des problèmes complexes.

Introduction à l’apprentissage Q

The learning process begins with initializing the Q-values to arbitrary values. After that, the agent interacts with the environment, observing the reward for each action taken. The agent then updates its Q-values using the Bellman equation, which takes into account the reward observed and the estimated future reward.

The agent continues this process until it converges to a policy that maximizes its expected reward. This process is known as exploration-exploitation, where the agent explores different actions to find the best one, and then exploits that action to maximize its reward.

Introduction à l’apprentissage Q

L’apprentissage Q est un algorithme sans modèle essentiel dans l’apprentissage par renforcement, se concentrant sur l’apprentissage de la valeur, ou «valeur Q», des actions dans des états spécifiques. Cette méthode excelle dans les environnements imprévisibles, car elle n’a pas besoin d’un modèle prédéfini de son environnement. Il s’adapte aux transitions stochastiques et aux récompenses variées de manière efficace, ce qui le rend polyvalent pour les scénarios où les résultats sont incertains. Cette flexibilité permet à l’apprentissage Q d’être un outil puissant dans les scénarios nécessitant une prise de décision adaptative sans connaissance préalable des dynamiques de l’environnement.

Processus d’apprentissage:

L’apprentissage Q fonctionne en mettant à jour une table de valeurs Q pour chaque action dans chaque état. Il utilise l’équation de Bellman pour mettre à jour ces valeurs de manière itérative en fonction des récompenses observées et de sa estimation des récompenses futures. La politique – la stratégie de choix d’actions – est dérivée de ces valeurs Q.

Le processus d’apprentissage commence par l’initialisation des valeurs Q à des valeurs arbitraires. Après cela, l’agent interagit avec l’environnement, observant la récompense pour chaque action prise. L’agent met alors à jour ses valeurs Q en utilisant l’équation de Bellman, qui tient compte de la récompense observée et de la récompense future estimée.

L’agent continue ce processus jusqu’à ce qu’il converge vers une politique qui maximise sa récompense attendue. Ce processus est connu sous le nom d’exploration-exploitation, où l’agent explore différentes actions pour trouver la meilleure, puis exploite cette action pour maximiser sa récompense.

Architecture de l’apprentissage Q

L’architecture de l’apprentissage Q est relativement simple et peut être représentée par un diagramme à blocs. Il comprend un agent qui interagit avec un environnement et un tableau de valeurs Q qui stocke les valeurs Q pour chaque action dans chaque état. Lorsque l’agent interagit avec l’environnement, il observe la récompense et met à jour le tableau de valeurs Q en utilisant l’équation de Bellman.

Le tableau de valeurs Q est le cœur de l’architecture de l’apprentissage Q. Il stocke les valeurs Q pour chaque action dans chaque état et est mis à jour par l’agent en fonction des récompenses observées et des estimations des récompenses futures. Une fois que le tableau est mis à jour, l’agent peut choisir la meilleure action à prendre

Source de l’article sur DZONE

Devenir ingénieur DevOps: Guide complet pour réussir

Vous souhaitez devenir ingénieur DevOps ? Découvrez notre guide complet pour vous aider à réussir dans ce domaine passionnant !

Dans le paysage en constante évolution de l’informatique et du développement logiciel, DevOps est devenu une méthodologie critique qui relie les équipes de développement et d’exploitation.

2. Gather the Necessary Skills:

DevOps engineers need to possess a wide range of technical skills to be successful. These include knowledge of scripting languages such as Python and Bash, proficiency in configuration management tools like Ansible and Chef, and expertise in containerization and virtualization technologies like Docker and Kubernetes. Additionally, DevOps engineers should have a good understanding of source control systems like Git, continuous integration tools such as Jenkins, and monitoring solutions like Nagios.

3. Acquire Hands-on Experience:

The best way to learn DevOps is to gain hands-on experience. Start by setting up a local environment and deploying a simple application. Then, move on to more complex tasks such as automating builds, deploying applications in containers, and configuring monitoring tools. You can also join online communities such as Stack Overflow to interact with experienced DevOps engineers and get answers to your questions.

Conclusion

DevOps is a rapidly evolving field that requires a strong understanding of the underlying principles and technical skills. To become a successful DevOps engineer, you need to understand the DevOps philosophy, acquire the necessary skills, and gain hands-on experience. With the right attitude and dedication, you can embark on an exciting journey and make a successful career in DevOps.

1. Comprendre la philosophie DevOps :

Avant de plonger dans les aspects techniques, il est important de comprendre les principes et la philosophie de base derrière DevOps. DevOps met l’accent sur la collaboration, la communication et l’intégration entre les équipes de développement et d’exploitation pour atteindre une livraison et une amélioration continues. Familiarisez-vous avec la culture DevOps, ses valeurs et l’importance de l’automatisation dans le cycle de développement logiciel.

2. Acquérir les compétences nécessaires :

Les ingénieurs DevOps doivent posséder une large gamme de compétences techniques pour réussir. Ceux-ci incluent la connaissance des langages de script tels que Python et Bash, la maîtrise des outils de gestion de configuration tels que Ansible et Chef et l’expertise des technologies de conteneurisation et de virtualisation telles que Docker et Kubernetes. De plus, les ingénieurs DevOps devraient avoir une bonne compréhension des systèmes de contrôle des sources comme Git, des outils d’intégration continue tels que Jenkins et des solutions de surveillance telles que Nagios.

3. Acquérir une expérience pratique :

La meilleure façon d’apprendre DevOps est d’acquérir une expérience pratique. Commencez par configurer un environnement local et déployer une application simple. Ensuite, passez à des tâches plus complexes telles que l’automatisation des builds, le déploiement d’applications dans des conteneurs et la configuration des outils de surveillance. Vous pouvez également rejoindre des communautés en ligne telles que Stack Overflow pour interagir avec des ingénieurs DevOps expérimentés et obtenir des réponses à vos questions.

Conclusion

DevOps est un domaine en constante évolution qui nécessite une bonne compréhension des principes sous-jacents et des compétences techniques. Pour devenir un ingénieur DevOps réussi, vous devez comprendre la philosophie DevOps, acquérir les compétences nécessaires et acquérir une expérience pratique. Avec la bonne attitude et la dévotion nécessaires, vous pouvez entreprendre un voyage passionnant et faire une carrière réussie dans DevOps.

Source de l’article sur DZONE

Utiliser l'API CronJob de Kubernetes pour un planning de tâches efficace.

Utilisez l’API CronJob de Kubernetes pour planifier vos tâches de manière efficace et automatique ! Gérez vos tâches avec précision et sans effort.

Prérequis pour l’API CronJob de Kubernetes

La base de données API CronJob de Kubernetes est une fonctionnalité clé pour automatiser les tâches régulières dans un environnement cloud-native. Ce guide vous guide pas à pas à travers les étapes pour utiliser cette API et illustre également des cas d’utilisation pratiques où elle peut être très bénéfique.

Prérequis

  • Un cluster Kubernetes en cours d’exécution (version 1.21 ou ultérieure)
  • Outil de ligne de commande kubectl
  • Connaissances de base sur Kubernetes (Pods, Jobs, CronJobs)

Comprendre l’API CronJob

La ressource CronJob de Kubernetes est conçue pour l’exécution de tâches basées sur le temps. La nouvelle API (batch/v1) apporte des améliorations en matière de fiabilité et de scalabilité.

L’API CronJob de Kubernetes est un moyen pratique et efficace pour automatiser des tâches régulières et périodiques. Les développeurs peuvent définir des tâches à exécuter à intervalles réguliers, à des moments spécifiques ou à des dates spécifiques. Cela permet aux applications de se mettre à jour automatiquement et de rester à jour, ce qui est essentiel pour les applications cloud-native. La nouvelle API (batch/v1) apporte des améliorations en matière de fiabilité et de scalabilité, ce qui permet aux développeurs d’utiliser des clusters Kubernetes plus grands et plus complexes.

Les développeurs peuvent utiliser l’API CronJob pour automatiser des tâches telles que la sauvegarde des bases de données, la mise à jour des applications, la synchronisation des données entre les clusters, l’exécution de tests et bien plus encore. L’API CronJob est très utile pour les applications qui nécessitent une mise à jour régulière ou des tâches qui doivent être exécutées à intervalles réguliers. En outre, l’API permet aux développeurs de surveiller l’état des tâches et d’effectuer des ajustements si nécessaire.

En résumé, l’API CronJob de Kubernetes est un outil pratique et puissant pour automatiser des tâches régulières et périodiques. Les développeurs peuvent définir des tâches à exécuter à intervalles réguliers, à des moments spécifiques ou à des dates spécifiques. La nouvelle API (batch/v1) apporte des améliorations en matière de fiabilité et de scalabilité, ce qui permet aux développeurs d’utiliser des clusters Kubernetes plus grands et plus complexes. Cela permet aux applications de se mettre à jour automatiquement et de rester à jour, ce qui est essentiel pour les applications cloud-native. Les développeurs peuvent utiliser l’API CronJob pour automatiser des tâches telles que la sauvegarde des bases de données, la mise à jour des applications, la synchronisation des données entre les clusters, l’exécution de tests et bien plus encore.

Source de l’article sur DZONE

Un plan pour une observabilité complète.

Pour obtenir une observabilité complète, il est important de mettre en place un plan d’action bien défini. Découvrez comment le réaliser !

Rapport de tendances 2023 sur l’observabilité et les performances des applications de DZone

En 2023, le rapport sur les tendances en matière d’observabilité et de performance des applications de DZone révèle que le codage est un élément clé de l’observabilité. Les développeurs peuvent utiliser des outils tels que le codage pour créer des applications plus robustes et plus fiables. Le codage permet aux développeurs de créer des applications qui sont plus faciles à surveiller et à maintenir. Il permet également aux développeurs de mieux comprendre le comportement des applications et de les améliorer en conséquence. En outre, le codage permet aux développeurs d’accéder à des données plus précises et plus complètes, ce qui leur permet de prendre des décisions plus éclairées.

Le codage est également un outil essentiel pour améliorer la performance des applications. Les développeurs peuvent utiliser le codage pour optimiser le code et améliorer la vitesse et la stabilité des applications. En outre, le codage permet aux développeurs de créer des applications qui sont plus faciles à surveiller et à maintenir. Les développeurs peuvent également utiliser le codage pour créer des applications qui sont plus sûres et plus fiables. Enfin, le codage permet aux développeurs de mieux comprendre le comportement des applications et d’identifier rapidement les problèmes.

En conclusion, le codage est un outil essentiel pour améliorer l’observabilité et la performance des applications. Les développeurs peuvent utiliser le codage pour créer des applications plus robustes et plus fiables, ainsi que pour améliorer la vitesse et la stabilité des applications. Le codage permet également aux développeurs d’accéder à des données plus précises et plus complètes, ce qui leur permet de prendre des décisions plus éclairées. Pour en savoir plus sur les tendances en matière d’observabilité et de performance des applications, consultez le rapport sur les tendances 2023 d’Observability and Application Performance de DZone.

Source de l’article sur DZONE

Recherche dépasse les bonnes pratiques: une pensée de leadership Google

Découvrez comment la recherche de Google dépasse les bonnes pratiques et révèle une nouvelle pensée de leadership !

La puissance de la prise de décision basée sur la recherche

Google’s commitment to research-driven decision-making has enabled it to stay ahead of the competition. By leveraging data and insights from research, Google is able to identify trends and anticipate customer needs. This allows the company to develop new products and services that meet the changing needs of the market. Additionally, Google’s research-focused approach has enabled the company to identify opportunities for growth and develop strategies to capitalize on them.

Google’s research-driven leadership approach has been a major factor in its success. The company has consistently been able to stay ahead of the competition by leveraging data and insights from research. This has enabled Google to develop innovative products and services that meet the changing needs of the market. Additionally, Google’s research-focused approach has enabled the company to identify opportunities for growth and develop strategies to capitalize on them.

Pourquoi les autres organisations devraient adopter cette stratégie

Les organisations qui souhaitent rester compétitives doivent adopter une approche de leadership axée sur la recherche. Les données et les informations recueillies par la recherche peuvent aider les entreprises à mieux comprendre leurs clients et à identifier des tendances et des opportunités. En outre, l’utilisation des données pour prendre des décisions peut aider les entreprises à développer des produits et services innovants qui répondent aux besoins changeants du marché.

En outre, l’utilisation de données pour prendre des décisions peut aider les entreprises à réduire leurs risques et à améliorer leurs performances. Les données peuvent également aider les entreprises à mieux comprendre leurs clients et à identifier des opportunités de croissance. Enfin, l’utilisation des données pour prendre des décisions peut aider les entreprises à améliorer leur efficacité et à réduire leurs coûts.

En conclusion, l’utilisation de données pour prendre des décisions est un élément essentiel de la stratégie de leadership de Google. Cette approche a permis à l’entreprise de rester compétitive et d’innover constamment. Les autres organisations devraient également envisager d’adopter cette stratégie pour rester compétitives et réussir dans un environnement commercial en constante évolution.

Source de l’article sur DZONE

Transfert de données depuis SQL Server vers Excel

Le transfert de données depuis SQL Server vers Excel est un processus important pour les entreprises qui souhaitent faciliter l’analyse et le partage des informations.

Dans cet article, je partagerai des informations sur la façon de transférer des données de n’importe quelle table de notre base de données vers un fichier Excel personnalisé à l’aide de l’outil SSIS fourni par les développeurs MSSQL.

Once the installation is complete, we can open Visual Studio and create a new project. We will select the Integration Services Project type, which will allow us to create a package that will contain our data transfer process. After that, we can add a Data Flow Task to our package. This task will be responsible for transferring data from any table in our database to the custom-designed Excel file.

In order to do this, we need to configure the Data Flow Task. We will start by adding an OLE DB Source component to our Data Flow Task. This component will be used to connect to our database and retrieve the data from the table we want to transfer. We then need to configure the Excel Destination component, which will be used to write the data into the custom-designed Excel file.

Finally, we can configure the Data Flow Task to run in debug mode. This will allow us to test the data transfer process and make sure that it is working correctly. Once we are satisfied with the results, we can deploy the package to our production environment and start using it for our data transfer needs.

Dans cet article, je partagerai des informations sur la façon de transférer des données à partir de n’importe quelle table de notre base de données vers un fichier Excel personnalisé à l’aide de l’outil SSIS fourni par les développeurs MSSQL.

Tout d’abord, pour permettre notre développement via Visual Studio, nous devons installer Microsoft SQL Server Data Tools sur notre ordinateur.

Une fois l’installation terminée, nous pouvons ouvrir Visual Studio et créer un nouveau projet. Nous sélectionnerons le type de projet Integration Services, qui nous permettra de créer un package qui contiendra notre processus de transfert de données. Après cela, nous pouvons ajouter une tâche de flux de données à notre package. Cette tâche sera responsable du transfert des données à partir de n’importe quelle table de notre base de données vers le fichier Excel personnalisé.

Pour ce faire, nous devons configurer la tâche de flux de données. Nous commencerons par ajouter un composant Source OLE DB à notre tâche de flux de données. Ce composant sera utilisé pour se connecter à notre base de données et récupérer les données de la table que nous voulons transférer. Nous devons ensuite configurer le composant Destination Excel, qui sera utilisé pour écrire les données dans le fichier Excel personnalisé.

Enfin, nous pouvons configurer la tâche de flux de données pour qu’elle s’exécute en mode débogage. Cela nous permettra de tester le processus de transfert de données et de nous assurer qu’il fonctionne correctement. Une fois que nous sommes satisfaits des résultats, nous pouvons déployer le package dans notre environnement de production et commencer à l’utiliser pour nos besoins de transfert de données.

Pour vérifier que le transfert des données se déroule correctement, nous pouvons utiliser l’outil SSIS pour exécuter des tests unitaires sur le package. Ces tests unitaires vérifieront que les données sont transférées correctement et que le fichier Excel personnalisé est correctement mis à jour avec les données provenant de la base de données. Une fois que les tests unitaires sont terminés

Source de l’article sur DZONE

Tutoriel OIDC pour sécuriser votre CI/CD

Apprenez à sécuriser votre CI/CD avec ce tutoriel OIDC ! Découvrez comment utiliser ce protocole pour protéger votre système de livraison continue.

Commençons par une histoire : Avez-vous entendu parler de la breach de CircleCI ? Non, pas celle où ils ont accidentellement divulgué des informations d’identification de clients il y a quelques années. Cette fois, c’est un peu plus sérieux.

The incident highlights the importance of testing security measures regularly. It’s not enough to just set up security measures and forget about them. Companies need to regularly test their security measures to make sure they are up-to-date and effective.

Commençons par une histoire : Avez-vous entendu parler de la violation de CircleCI ? Non, pas celle où ils ont accidentellement divulgué des informations d’identification de certains clients il y a quelques années. Cette fois, c’est un peu plus sérieux.

Il semble que des individus non autorisés ont pu accéder aux systèmes de CircleCI, compromettant les secrets stockés dans CircleCI. CircleCI a conseillé aux utilisateurs de faire tourner « tous les secrets » stockés dans CircleCI, y compris ceux stockés dans les variables d’environnement ou les contextes du projet.

L’incident met en évidence l’importance des tests de sécurité réguliers. Il ne suffit pas de mettre en place des mesures de sécurité et de les oublier. Les entreprises doivent régulièrement tester leurs mesures de sécurité pour s’assurer qu’elles sont à jour et efficaces.

Source de l’article sur DZONE

Migration Cloud: Comment surmonter les craintes et saisir les opportunités

La migration vers le cloud peut sembler effrayante, mais elle offre de nombreuses opportunités. Découvrez comment surmonter vos craintes et saisir ces opportunités !

## Croissance du Cloud Computing au cours des dernières Décennies

Testing is a key factor in the success of cloud computing. It is essential to ensure that applications, services, and infrastructure are secure and reliable. Testing helps to identify and fix any issues before they become a problem. It also helps to ensure that the cloud environment is able to meet the needs of users. Testing should be done regularly and should include both automated and manual tests.

Depuis plus d’une décennie, le cloud computing est une tendance majeure. En 2015, sa croissance annuelle à trois chiffres a été enregistrée. Bien que, à la fin de 2019, les plus grands fournisseurs de cloud aient connu une croissance plus lente, à seulement 31 % par an, et que cette croissance devrait diminuer en 2020 et 2021 à mesure que l’industrie mûrit, la croissance du cloud a tout de même surpassé celle de nombreux autres secteurs.

De plus, en 2020, le marché du cloud a connu une croissance plus rapide qu’en 2019 selon certains critères. Cela s’est produit malgré la grave récession économique. La raison de cette croissance est l’augmentation de la demande provoquée par la pandémie, les confinements et le passage au travail à distance.

Le test est un facteur clé de la réussite du cloud computing. Il est essentiel de s’assurer que les applications, services et infrastructures sont sûrs et fiables. Le test permet d’identifier et de corriger les problèmes avant qu’ils ne deviennent un problème. Il aide également à s’assurer que l’environnement cloud est en mesure de répondre aux besoins des utilisateurs. Les tests doivent être effectués régulièrement et doivent inclure des tests automatisés et manuels.

Source de l’article sur DZONE