Installation d'un package sur une instance Windows - 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.

Installation d'un package sur une instance Windows

Important

Le AWS OpsWorks Stacks le service a pris fin 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 le AWS Support L'équipe sur AWS Re:post ou via AWS Support premium.

Note

Cet exemple suppose que vous avez déjà fait l'exemple Exécution d'une recette sur une instance Windows. Si tel n'est pas le cas, commencez par cet exemple. Il décrit notamment comment activer l'RDPaccès à vos instances.

Si votre logiciel est fourni dans un package d'installation, tel qu'unMSI, vous devez télécharger le fichier sur l'instance, puis l'exécuter. Cet exemple montre comment implémenter un livre de recettes pour installer un MSI package, le runtime Python, y compris comment définir les variables d'environnement associées. Pour plus d'informations sur l'installation de fonctionnalités Windows telles queIIS, voirInstallation d'une fonctionnalité Windows : IIS.

Pour configurer le livre de recettes
  1. Créez un répertoire nommé installpython et accédez à celui-ci.

  2. Ajoutez un fichier metadata.rb à installpython avec le contenu suivant.

    name "installpython" version "0.1.0"
  3. Ajoutez les répertoires recipes et files à installpython, et ajoutez un répertoire default aux fichiers.

  4. Téléchargez un package Python à partir de Versions Python pour Windows et copiez-le dans le répertoire files\default du livre de recettes. Cet exemple installe la version Windows x86-64 de Python 3.5.0a3, qui utilise un programme d'installation nommé. MSI python-3.4.3.amd64.msi

  5. Ajoutez un fichier nommé default.rb au répertoire recipes avec le code suivant de la recette.

    directory 'C:\tmp' do rights :full_control, 'Everyone' recursive true action :create end cookbook_file 'C:\tmp\python-3.4.3.amd64.msi' do source "python-3.4.3.amd64.msi" rights :full_control, 'Everyone' action :create end windows_package 'python' do source 'C:\tmp\python-3.4.3.amd64.msi' action :install end env "PATH" do value 'c:\python34' delim ";" action :modify end

    La recette exécute les tâches suivantes :

    1. Utilisez une ressource directory pour créer un répertoire C:\tmp.

      Pour plus d'informations sur cette ressource, consultez Exemple 3 : Création de répertoires.

    2. Utilisez une ressource cookbook_file pour copier le programme d'installation du répertoire files\default du livre de recettes vers C:\tmp.

      Pour plus d'informations sur cette ressource, consultez Installation d'un fichier à partir d'un livre de recettes.

    3. Utilise une ressource windows_package pour exécuter le MSI programme d'installation, qui installe Python sur. c:\python34

      Le programme d'installation crée les répertoires nécessaires et installe les fichiers, mais il ne modifie pas la variable d'environnement PATH du système.

    4. Utilise une ressource env pour ajouter c:\python34 au chemin d'accès système.

      La ressource env vous permet de définir des variables d'environnement. Dans ce cas, la recette vous permet d'exécuter facilement des scripts Python à partir de la ligne de commande en ajoutant c:\python34 au chemin d'accès.

      • Le nom de la ressource spécifie le nom de la variable d'environnement, PATH pour cet exemple.

      • L'attribut value spécifie la valeur de la variable, c:\\python34 pour cet exemple (vous avez besoin d'échapper le caractère \).

      • L'action :modify ajoute la valeur spécifiée à la valeur actuelle de la variable.

      • L'attribut delim spécifie un délimiteur qui sépare la nouvelle valeur de la valeur existante, à savoir ; pour cet exemple.

  6. Créez une archive .zip du fichier installpython, chargez l'archive dans un compartiment S3 et rendez-la publique. Enregistrez les archives URL pour une utilisation ultérieure. Pour de plus amples informations, veuillez consulter Référentiels de livres de recettes.

    Le contenu livré aux compartiments Amazon S3 peut contenir du contenu client. Pour plus d'informations sur la suppression de données sensibles, consultez How Do I Empty an S3 Bucket? (Comment puis-je vider un compartiment S3 ?) ou How Do I Delete an S3 Bucket? (Comment supprimer un compartiment S3 ?).

Créez une pile pour cet exemple, comme suit. Vous pouvez aussi utiliser une pile Windows existante. Il vous suffit de mettre à jour les livres de recettes, comme décrit plus tard.

Création d'une pile
  1. Ouvrez le fichier AWS OpsWorks Console Stacks et choisissez Add Stack. Spécifiez les paramètres suivants, acceptez les valeurs par défaut pour les autres paramètres et choisissez Add Stack (Ajouter une pile).

    • Nom — InstallPython

    • Région — Ouest des États-Unis (Oregon)

      Cet exemple fonctionne dans n'importe quelle région, mais nous vous recommandons d'utiliser US West (Oregon) pour les didacticiels.

    • Système d'exploitation par défaut : Microsoft Windows Server 2012 R2

  2. Choisissez Add a layer (Ajouter une couche) et ajoutez une couche personnalisée à la pile avec les paramètres suivants.

    • Nom — Python

    • Nom court — python

  3. Ajoutez une instance 24/7 avec les paramètres par défaut de la couche Python et démarrez-la.

Une fois que l'instance est en ligne, vous pouvez installer le livre de recettes et exécuter la recette

Pour installer le livre de recettes et exécuter la recette
  1. Modifiez la pile pour activer les livres personnalisés et spécifiez les paramètres suivants.

    • Type de référentiel : archive S3.

    • Référentiel URL — L'archive du livre de recettes URL que vous avez enregistrée précédemment.

    Acceptez les valeurs par défaut pour les autres paramètres, puis choisissez Save (Enregistrer) pour mettre à jour la configuration de la pile.

  2. Exécutez la commande de pile Update Custom Cookbooks (Mettre à jour les livres de recettes personnalisées), qui installe la dernière version de vos livres de recettes personnalisées sur les instances en ligne de la pile. Si une version antérieure de votre livre de recettes est présente, cette commande la remplace.

  3. Exécutez la recette à l'aide de la commande de pile Execute Recipes (Exécuter les recettes) après avoir défini Recipes to execute (Recettes à exécuter) sur installpython::default. Cette commande lance une exécution de Chef, avec une liste d'exécution composée de installpython::default.

    Note

    Cet exemple utilise Execute Recipes pour des raisons pratiques, mais vous avez généralement AWS OpsWorks Stacks exécute automatiquement vos recettes en les affectant à l'événement du cycle de vie approprié. Vous pouvez exécuter ces recettes en déclenchant manuellement l'événement. Vous pouvez utiliser une commande de pile pour déclencher des événements Setup et Configure et une commande de déploiement pour déclencher des événements Deploy et Undeploy.

  4. Pour vérifier l'installation, connectez-vous RDP à l'instance et ouvrez l'Explorateur Windows.

    • Le système de fichiers doit maintenant comporter un répertoire C:\Python34.

    • Si vous exécutez path à partir de la ligne de commande, il doit ressembler à : PATH=c:\python34;C:\Windows\system32;...

    • Si vous exécutez python --version à partir de la ligne de commande, il doit retourner Python 3.4.3.