Gérer une application Azure Service Fabric à l’aide d’Azure Service Fabric CLI (sfctl)
Découvrez comment créer et supprimer des applications qui s’exécutent dans un cluster Azure Service Fabric.
Prérequis
Installez Service Fabric CLI. Sélectionnez ensuite votre cluster Service Fabric. Pour plus d’informations, consultez Prise en main de Service Fabric CLI.
Vous devez également avoir un package d’application Service Fabric prêt à être déployé. Pour plus d’informations sur la création et l’empaquetage d’une application, consultez la documentation dédiée au modèle d’application Service Fabric.
Vue d’ensemble
Pour déployer une nouvelle application, suivez les étapes ci-dessous :
- Téléchargez un package d’application dans le magasin d’images Service Fabric.
- Approvisionnez un type d’application.
- Supprimez le contenu du magasin d’images.
- Spécifiez et créez une application.
- Spécifiez et créez des services.
Pour supprimer une application existante, procédez comme suit :
- Supprimez l’application.
- Annulez l’approvisionnement du type d’application associé.
Déployer une nouvelle application
Pour déployer une nouvelle application, suivez les étapes ci-dessous :
Charger un nouveau package d’application dans le magasin d’images
Avant de créer une application, vous devez charger le package d’application dans le magasin d’images Service Fabric.
Par exemple, si votre package d’application se trouve dans le répertoire app_package_dir
, utilisez les commandes suivantes pour charger le répertoire :
sfctl application upload --path ~/app_package_dir
Pour les packages d’application volumineux, vous pouvez spécifier l’option --show-progress
pour afficher la progression du chargement.
Approvisionner le type d’application
Lorsque le chargement est terminé, approvisionnez l’application. Pour approvisionner l’application, utilisez la commande suivante :
sfctl application provision --application-type-build-path app_package_dir
La valeur de application-type-build-path
est le nom du répertoire où vous avez chargé le package d’application.
Supprimer le package d’application
Nous vous recommandons de supprimer le package d’application une fois que l’application est inscrite. La suppression de packages d’application du magasin d’images libère des ressources système. La conservation des packages d’application inutilisés consomme du stockage sur disque et affecte le niveau de performance des applications.
Pour supprimer le package d’application du magasin d’images, utilisez la commande suivante :
sfctl store delete --content-path app_package_dir
content-path
doit être le nom du répertoire que vous avez chargé lors de la création de l’application.
Créer une application à partir d’un type d’application
Une fois que vous avez approvisionné l’application, utilisez la commande suivante pour nommer et créer votre application :
sfctl application create --app-name fabric:/TestApp --app-type TestAppType --app-version 1.0
app-name
est le nom que vous souhaitez utiliser pour l’instance de l’application. Vous pouvez obtenir des paramètres supplémentaires à partir du manifeste de l’application déjà approvisionné.
Le nom de l’application doit commencer par le préfixe fabric:/
.
Créer des services pour la nouvelle application
Après avoir créé une application, créez des services à partir de l’application. Dans l’exemple suivant, nous créons un service sans état à partir de notre application. Les services que vous pouvez créer à partir d’une application sont définis dans un manifeste de service placé dans le package d’application déjà approvisionné.
sfctl service create --app-id TestApp --name fabric:/TestApp/TestSvc --service-type TestServiceType \
--stateless --instance-count 1 --singleton-scheme
Vérifier le déploiement et l’intégrité de l’application
Pour vérifier que tout est correct, utilisez les commandes de contrôle d’intégrité suivantes :
sfctl application list
sfctl service list --application-id TestApp
Pour vérifier l’intégrité du service, utilisez des commandes similaires afin de récupérer des informations sur l’intégrité du service et de l’application :
sfctl application health --application-id TestApp
sfctl service health --service-id TestApp/TestSvc
Les applications et services intègres ont une valeur HealthState
égale à Ok
.
Supprimer une application existante
Pour supprimer une application, suivez les étapes ci-dessous :
Supprimer l’application
Pour supprimer l’application, utilisez la commande suivante :
sfctl application delete --application-id TestEdApp
Annuler l’approvisionnement de l’application
Après avoir supprimé l’application, vous pouvez annuler l’approvisionnement du type d’application s’il n’est plus nécessaire. Pour annuler l’approvisionnement du type d’application, utilisez la commande suivante :
sfctl application unprovision --application-type-name TestAppType --application-type-version 1.0
Le nom et la version du type doivent correspondre au nom et à la version du manifeste de l’application précédemment approvisionné.
Mettre à niveau l’application
Après avoir créé votre application, vous pouvez répéter la même procédure pour configurer une deuxième version de votre application. Avec une mise à niveau d’application Service Fabric, vous pouvez ensuite exécuter la deuxième version de l’application. Pour plus d’informations, consultez la documentation Mise à niveau des applications Service Fabric.
Pour effectuer une mise à niveau, configurez d’abord la version suivante de l’application à l’aide des mêmes commandes que précédemment :
sfctl application upload --path ~/app_package_dir_2
sfctl application provision --application-type-build-path app_package_dir_2
sfctl store delete --content-path app_package_dir_2
Il est ensuite recommandé d’effectuer une mise à niveau automatique surveillée et de lancer cette dernière en exécutant la commande suivante :
sfctl application upgrade --app-id TestApp --app-version 2.0.0 --parameters "{\"test\":\"value\"}" --mode Monitored
Les mises à niveau remplacent les paramètres existants par ce qui est spécifié. Les paramètres de l’application doivent être transmis en tant qu’arguments à la commande de mise à niveau, si nécessaire. Les paramètres de l’application doivent être codés en tant qu’objet JSON.
Pour récupérer les paramètres spécifiés antérieurement, vous pouvez utiliser la commande sfctl application info
.
Lorsqu’une mise à niveau de l’application est en cours, l’état peut être récupéré à l’aide de la commande sfctl application upgrade-status
.
Enfin, si une mise à niveau est en cours et doit être annulée, vous pouvez utiliser la commande sfctl application upgrade-rollback
pour restaurer la mise à niveau.