Migration de Chef Server vers Stacks AWS OpsWorks - AWS OpsWorks

Les traductions sont fournies par des outils de traduction automatique. En cas de conflit entre le contenu d'une traduction et celui de la version originale en anglais, la version anglaise prévaudra.

Migration de Chef Server vers Stacks AWS OpsWorks

Important

Le AWS OpsWorks Stacks service a atteint sa fin de vie le 26 mai 2024 et a été désactivé tant pour les nouveaux clients que pour les clients existants. Nous recommandons vivement aux clients de migrer leurs charges de travail vers d'autres solutions dès que possible. Si vous avez des questions sur la migration, contactez l' AWS Support équipe sur AWS Re:Post ou via le AWS Support Premium.

Comme AWS OpsWorks Stacks est basé sur Chef, la migration de Chef Server vers AWS OpsWorks Stacks est relativement simple. Cette rubrique présente les directives relatives à la modification du code Chef Server pour qu'il fonctionne avec AWS OpsWorks Stacks.

Note

Il est déconseillé de migrer vers les piles à l'aide des versions Chef antérieures à 11.10, car elles sont basées sur chef-solo et ne prennent pas en charge la recherche ou les conteneurs de données.

Mappage des rôles et des couches

Chef Server utilise des rôles pour représenter et gérer les instances ayant les mêmes objectif et configuration, telles qu'un ensemble d'instances qui hébergent chacune un serveur d'applications Java. Une couche AWS OpsWorks Stacks obéit pour l'essentiel au même objectif qu'un rôle Chef. Une couche est un modèle permettant de créer un ensemble d'instances Amazon Elastic Compute Cloud (AmazonEC2) avec la même configuration, les mêmes packages installés, la même procédure de déploiement d'applications, etc.

AWS OpsWorks Stacks inclut un ensemble de couches intégrées pour plusieurs types de serveurs d'applications, un équilibreur de HAProxy charge, un maître de SQL base de données My et un master de surveillance Ganglia. Par exemple, la couche Java App Server intégrée est un modèle pour créer des instances hébergeant un serveur Tomcat.

Pour migrer vers AWS OpsWorks Stacks, vous devez associer chaque rôle à une couche fournissant des fonctionnalités équivalentes. Pour certains rôles, il se peut que vous puissiez simplement utiliser l'une des couches intégrées. D'autres rôles peuvent nécessiter différents degrés de personnalisation. Commencez par examiner les fonctionnalités des couches intégrées, y compris les recettes associées à chacune d'elles, pour voir si l'une offre au moins certaines fonctionnalités de votre rôle. Pour plus d'informations sur les couches intégrées, consultez Couches et AWS OpsWorks Référence de la couche Stacks. Pour examiner les recettes intégrées, consultez le GitHub référentiel public AWS OpsWorks Stacks.

La façon dont vous procédez dépend étroitement de la manière dont vous pouvez associer une couche à chaque rôle, comme suit.

Une couche intégrée prend en charge toutes les fonctionnalités du rôle

Vous pouvez utiliser la couche intégrée directement, avec des personnalisations mineures, si nécessaire. Par exemple, si un rôle prend en charge un serveur Tomcat, les recettes de la couche Java App Server peuvent déjà gérer toutes les tâches du rôle, éventuellement avec une légère personnalisation. Par exemple, vous pouvez faire en sorte que les recettes intégrées de la couche utilisent les paramètres de configuration Tomcat ou Apache en remplaçant les attributs ou les modèles appropriés.

Une couche intégrée prend en charge certaines, mais pas toutes, fonctionnalités du rôle

Vous pouvez utiliser une couche intégrée en étendant la couche. Cette extension implique généralement d'implémenter des recettes personnalisées pour prendre en charge les fonctionnalités manquantes et d'affecter les recettes aux événements du cycle de vie de la couche. Par exemple, supposons que votre rôle installe un serveur Redis sur les mêmes instances qui hébergent un serveur Tomcat. Vous pouvez étendre la couche Java App Server pour qu'elle corresponde aux fonctionnalités du rôle en implémentant une recette personnalisée pour installer Redis sur les instances de la couche et en attribuant la recette à l'événement de configuration de la couche.

Aucune couche intégrée ne prend en charge de façon adéquate la fonctionnalité du rôle

Mettez en place une couche personnalisée. Par exemple, supposons que votre rôle prenne en charge un serveur de base de données MongoDB, qui n'est pris en charge par aucune des couches intégrées. Vous pouvez fournir cette prise en charge en implémentant des recettes pour installer les packages requis, configurer le serveur, etc., et attribuer les recettes aux événements du cycle de vie d'une couche personnalisée. Généralement, vous pouvez utiliser au moins certaines recettes du rôle à cet effet. Pour plus d'informations sur l'implémentation d'une couche personnalisée, consultez Création d'une couche serveur Tomcat personnalisée.

Utilisation des conteneurs de données

Chef Server vous permet de transmettre à vos recettes des données définies par l'utilisateur à l'aide de conteneurs de données.

  • Vous stockez les données avec vos livres de recettes et Chef les installe sur chaque instance.

  • Vous pouvez utiliser les conteneurs de données chiffrées pour les données sensibles telles que les mots de passe.

AWS OpsWorks Stacks prend en charge les sacs de données ; les recettes peuvent récupérer les données en utilisant exactement le même code qu'avec Chef Server. Cependant, la prise en charge présente les différences et limites suivantes :

  • Les conteneurs de données ne sont pris en charge que sur les piles Linux Chef 11 .10 et versions ultérieures.

    Les piles Windows et les piles Linux exécutant des versions antérieures de Chef ne prennent pas en charge les conteneurs de données.

  • Vous ne stockez pas les conteneurs de données dans votre référentiel de livres de recettes.

    Au lieu de cela, vous utilisez JSON la personnalisation pour gérer les données de votre sac de données.

  • AWS OpsWorks Stacks ne prend pas en charge les sacs de données cryptés.

    Si vous devez stocker des données sensibles sous une forme chiffrée, telle que mots de passe ou certificats, nous vous recommandons de les stocker dans un compartiment S3 privé. Vous pouvez ensuite créer une recette personnalisée qui utilise Amazon SDK for Ruby pour récupérer les données. Pour obtenir un exemple, consultez Utilisation de SDK for Ruby.

Pour de plus amples informations, veuillez consulter Utilisation des conteneurs de données.

Chef Server stocke les informations de configuration de pile, telles que les adresses IP et les configurations de rôle, sur le serveur. Les recettes utilisent la recherche Chef pour récupérer ces données. AWS OpsWorks Stacks utilise une approche quelque peu différente. Par exemple, les piles Linux Chef 11.10 reposent sur le mode local client Chef, option qui exécute localement une version légère de Chef Server (souvent appelé Chef Zero) sur l'instance. Chef Zero prend en charge la recherche sur les données stockées dans l'objet nœud de l'instance.

Au lieu de stocker les données de pile sur un serveur distant, AWS OpsWorks Stacks ajoute un ensemble d'attributs de configuration et de déploiement de la pile à l'objet nœud de chaque instance pour chaque événement du cycle de vie. Ces attributs représentent un instantané de la configuration de la pile. Ils utilisent la même syntaxe que Chef Server et représentent la plupart des données dont les recettes ont besoin pour récupérer des données à partir du serveur.

Vous n'avez souvent pas besoin de modifier le code de recherche de vos recettes pour Stacks. AWS OpsWorks Comme Chef search fonctionne sur l'objet nœud, qui inclut la configuration de la pile et les attributs de déploiement, les requêtes de recherche dans AWS OpsWorks Stacks fonctionnent généralement exactement comme elles le font avec Chef Server.

La principale exception est due au fait que les attributs de configuration et de déploiement de la pile contiennent uniquement des données dont AWS OpsWorks Stacks a connaissance lorsqu'il installe les attributs sur l'instance. Si vous créez ou modifiez un attribut localement sur une instance particulière, ces modifications ne sont pas répercutées vers AWS OpsWorks Stacks et ne sont pas incorporées dans la configuration de la pile et les attributs de déploiement installés sur les autres instances. Vous pouvez utiliser la recherche pour récupérer la valeur d'attribut uniquement sur cette instance. Pour de plus amples informations, veuillez consulter Utilisation de Chef Search.

Pour des raisons de compatibilité avec Chef Server, AWS OpsWorks Stacks ajoute un ensemble d'roleattributs à l'objet nœud, chacun contenant l'un des attributs de couche de la pile. Si votre recette utilise roles comme clé de recherche, vous n'avez pas besoin de modifier le code de recherche. La requête retourne automatiquement les données de la couche correspondante. Par exemple, les requêtes suivantes interrogent toutes deux les attributs de la couche php-app.

phpserver = search(:node, "layers:php-app").first
phpserver = search(:node, "roles:php-app").first

Gestion des recettes et des livres de recettes

AWS OpsWorks Stacks et Chef Server gèrent les livres de cuisine et les recettes de manière quelque peu différente. Avec Chef Server :

  • Vous fournissez tous les livres de recettes, en les mettant en œuvre vous-même ou en utilisant les livres de recettes de la communauté.

  • Vous stockez les livres de recettes sur le serveur.

  • Vous exécutez les recettes manuellement ou selon une planification régulière.

Avec AWS OpsWorks Stacks :

  • AWS OpsWorks Stacks fournit un ou plusieurs livres de recettes pour chacune des couches intégrées. Ces livres de recettes gèrent les tâches standards, telles que l'installation et la configuration des logiciels d'une couche intégrée, et le déploiement d'applications.

    Pour gérer des tâches qui ne sont pas exécutées par les livres de recettes intégrés, vous ajoutez des livres de recettes personnalisés à votre pile ou utilisez les livres de recettes de la communauté.

  • Vous stockez les livres de recettes AWS OpsWorks Stacks dans un référentiel distant, tel qu'un compartiment S3 ou un dépôt Git.

    Pour de plus amples informations, veuillez consulter Stockage des livres de recettes.

  • Vous pouvez exécuter des recettes manuellement, mais AWS OpsWorks Stacks exécute généralement des recettes pour vous en réponse à un ensemble d'événements du cycle de vie qui se produisent à des moments clés du cycle de vie d'une instance.

    Pour de plus amples informations, veuillez consulter Exécution des recettes.

  • AWS OpsWorks Stacks prend uniquement en charge les stacks Berkshelf on Chef 11.10. Si vous utilisez Berkshelf pour gérer les dépendances de vos livres de recettes, vous ne pouvez pas utiliser les piles exécutant Chef 11.4 ou versions antérieures.

    Pour de plus amples informations, veuillez consulter Utilisation de Berkshelf.

Stockage des livres de recettes

Avec Chef Server, vous stockez vos livres de recettes sur le serveur et les déployez depuis le serveur vers les instances. Avec AWS OpsWorks Stacks, vous stockez des livres de recettes dans un dépôt : un S3 ou une HTTP archive, un dépôt Git ou Subversion. Vous spécifiez les informations dont AWS OpsWorks Stacks a besoin pour télécharger le code du référentiel vers les instances d'une pile lorsque vous installez des livres de recettes.

Pour migrer à partir de Chef Server, vous devez placer vos livres de recettes dans l'un de ces référentiels. Pour plus d'informations sur la façon de structurer un référentiel de livres de recettes, consultez Référentiels de livres de recettes.

Exécution des recettes

Dans AWS OpsWorks Stacks, chaque couche est associée à un ensemble d'événements du cycle de vie (installation, configuration, déploiement, annulation du déploiement et arrêt) qui se produisent chacun à un moment clé du cycle de vie d'une instance. Pour exécuter une recette personnalisée, vous l'assignez généralement à l'événement approprié de la couche appropriée. Lorsque l'événement se produit, AWS OpsWorks Stacks exécute les recettes associées. Par exemple, l'événement Setup se produit après qu'une instance a fini de démarrer et, par conséquent, vous lui assignez généralement les recettes qui exécutent des tâches telles que l'installation et la configuration de packages, ou le démarrage de services.

Vous pouvez exécuter les recettes manuellement grâce à la commande de pileExecute Recipes. Cette commande est utile pour le développement et les tests, mais vous pouvez également l'utiliser pour exécuter des recettes qui ne sont pas mappées avec un événement du cycle de vie. Vous pouvez aussi utiliser la commande Execute Recipes pour déclencher manuellement les événements Setup et Configure.

En plus de la console AWS OpsWorks Stacks, vous pouvez utiliser le AWSCLIou SDKspour exécuter des recettes. Ces outils prennent en charge toutes les APIactions AWS OpsWorks Stacks, mais sont plus simples à utiliser que lesAPI. Utilisez la CLI commande create-deployment pour déclencher un événement du cycle de vie, qui exécute toutes les recettes associées. Vous pouvez également utiliser cette commande pour exécuter une ou plusieurs recettes sans déclencher un événement. Le SDK code équivalent dépend de la langue utilisée, mais est généralement similaire à la CLI commande.

Les exemples suivants décrivent deux manières d'utiliser la create-deployment CLI commande pour automatiser le déploiement d'applications.

  • Déployez votre application selon un calendrier régulier en ajoutant à votre pile une couche personnalisée avec une seule instance.

    Ajoutez à la couche une recette Setup personnalisée qui crée un travail cron sur l'instance pour exécuter la commande selon un calendrier spécifié. Pour obtenir un exemple d'utilisation d'une recette pour créer un travail cron, consultez Exécution de tâches cron sur les instances Linux.

  • Ajoutez une tâche à votre pipeline d'intégration continue qui utilise la create-deployment CLI commande pour déployer l'application.

Utilisation des environnements Chef

AWS OpsWorks Stacks ne prend pas en charge les environnements Chef ; revient node.chef_environment _default toujours.