Leçon 5 : suivi du flux de travail avec Windows PowerShell
Durée : 25 minutes
Objectif : apprendre à configurer un modèle de suivi pour surveiller des variables définies dans un flux de travail à l'aide de Windows PowerShell.
Fonction : présenter l'utilisation des cmdlets de Windows Server AppFabric pour configurer un modèle de suivi personnalisé pour l'application Order Service. Afficher les informations de suivi personnalisé du magasin de surveillance à l'aide d'une fonction de script.
Configuration préalable
Les conditions suivantes sont requises avant de commencer cette leçon :
L'application Order Service doit être déployée de la manière décrite dans la Leçon 2 : déploiement de l'application OrderService avec Windows PowerShell.
Vous devez suivre la Leçon 3 : configuration de l'application OrderService avec Windows PowerShell.
Vous devez disposer de certaines connaissances relatives à SQL Server afin de comprendre les sections de cette leçon.
Procédure
Au cours de cette leçon, vous allez effectuer les opérations suivantes :
créer un modèle de suivi personnalisé pour représenter les configurations définies à l'aide de Windows PowerShell ;
afficher la configuration de suivi actuelle à l'aide de Windows PowerShell ;
utiliser Windows PowerShell pour configurer l'utilisation du nouveau modèle de suivi personnalisé par l'application OrderWorkflowService ;
afficher les informations de suivi personnalisé du magasin de surveillance à l'aide de Windows PowerShell.
Création d'un modèle de suivi personnalisé
Dans cette section, vous allez créer un modèle de suivi personnalisé, copie de celui utilisé dans la Leçon 5 : reprise d'un flux de travail interrompu à l'aide d'AppFabric du Didacticiel utilisant l'interface de Windows Server AppFabric. Le nom du nouveau modèle de suivi incluera le suffixe « _PS », de sorte que vous pourrez l'associer à vos configurations à l'aide des cmdlets de AppFabric.
Dans Windows PowerShell, entrez la commande suivante.
Notepad OrderService_PS.tp
Cliquez sur Oui lorsque le Bloc-notes vous invite à créer le nouveau fichier.
Copiez et collez les éléments XML suivants dans le Bloc-notes.
<trackingProfile name="CustomOrderServiceProfile - Windows PowerShell Config"> <workflow activityDefinitionId="*"> <workflowInstanceQueries> <workflowInstanceQuery> <states> <state name="*" /> </states> </workflowInstanceQuery> </workflowInstanceQueries> <activityStateQueries> <activityStateQuery activityName="Wait for order"> <states> <state name="Closed" /> </states> <variables> <variable name="product"/> <variable name="quantity"/> </variables> </activityStateQuery> </activityStateQueries> <faultPropagationQueries> <faultPropagationQuery faultSourceActivityName="*" faultHandlerActivityName="*" /> </faultPropagationQueries> <bookmarkResumptionQueries> <bookmarkResumptionQuery name="*" /> </bookmarkResumptionQueries> <customTrackingQueries> <customTrackingQuery name="*" activityName="*" /> </customTrackingQueries> </workflow> </trackingProfile>
Ce modèle de suivi permet de suivre les variables de flux de travail product et quantity dans l'activité Wait for order du fichier OrderWorkflow.xamlx.
Fermez le Bloc-notes et cliquez sur Enregistrer lorsque vous êtes invité à enregistrer les modifications apportées au fichier OrderService_PS.tp.
Affichage de la configuration de suivi à l'aide de Windows PowerShell
Dans cette section, vous allez utiliser les cmdlets de AppFabric pour Windows PowerShell pour afficher la configuration de suivi actuelle de l'application OrderWorkflowService.
Dans Windows PowerShell, exécutez la commande suivante pour découvrir si le suivi est actuellement activé pour l'application OrderWorkflowService.
Get-ASAppServiceTracking -SiteName OrderService_PS -VirtualPath "/OrderWorkflowService/OrderWorkflow.xamlx" | fl *
Le résultat doit ressembler à ce qui suit.
IsTrackingEnabled : True ProfileName : HealthMonitoring Tracking Profile IsLocal : True BehaviorName :
Dans Windows PowerShell, exécutez la commande suivante pour afficher les modèles de suivi disponibles pour l'application OrderWorkflowService.
Get-ASAppServiceTrackingProfile -SiteName OrderService_PS -VirtualPath "/OrderWorkflowService/OrderWorkflow.xamlx" | fl Name
Le résultat doit ressembler à ce qui suit.
Name : Name : ErrorsOnly Tracking Profile Name : HealthMonitoring Tracking Profile Name : EndToEndMonitoring Tracking Profile Name : Troubleshooting Tracking Profile
Configuration du suivi personnalisé à l'aide de Windows PowerShell
Dans cette section, vous allez utiliser les cmdlets de AppFabric pour Windows PowerShell pour configurer l'utilisation du nouveau modèle de suivi personnalisé par l'application OrderWorkflowService.
Exécutez la commande suivante pour ajouter le fichier OrderService_PS.tp à la liste des modèles de suivi disponibles pour l'application OrderWorkflowService.
Import-ASAppServiceTrackingProfile -SiteName OrderService_PS -VirtualPath "/OrderWorkflowService/OrderWorkflow.xamlx" -FilePath $(Get-Item ".\OrderService_PS.tp").FullName | fl *
Notez que le fichier OrderService_PS.tp doit être placé dans le répertoire actuel de Windows PowerShell pour que la commande soit correctement exécutée.
Le résultat de l'opération doit ressembler à ce qui suit.
Name : CustomOrderServiceProfile - Windows PowerShell Config SiteName : OrderService_PS VirtualPath : /OrderWorkflowService/OrderWorkflow.xamlx IsLocal : True
Dans Windows PowerShell, exécutez la commande suivante pour afficher la nouvelle liste des modèles de suivi disponibles pour l'application OrderWorkflowService.
Get-ASAppServiceTrackingProfile -SiteName OrderService_PS -VirtualPath "/OrderWorkflowService/OrderWorkflow.xamlx" | fl Name
Le résultat doit ressembler à ce qui suit (inclut le modèle « CustomOrderServiceProfile - Windows PowerShell Config ».
Name : Name : ErrorsOnly Tracking Profile Name : HealthMonitoring Tracking Profile Name : EndToEndMonitoring Tracking Profile Name : Troubleshooting Tracking Profile Name : CustomOrderServiceProfile - Windows PowerShell Config
Pour configurer l'utilisation du nouveau modèle appelé « CustomOrderServiceProfile - Windows PowerShell Config » par l'application OrderWorkflowService, exécutez la commande suivante dans Windows PowerShell.
Set-ASAppServiceTracking -SiteName OrderService_PS -VirtualPath "/OrderWorkflowService/OrderWorkflow.xamlx" -ProfileName "CustomOrderServiceProfile - Windows PowerShell Config" | fl *
Le résultat doit ressembler à ce qui suit.
IsTrackingEnabled : True ProfileName : CustomOrderServiceProfile - Windows PowerShell Config IsLocal : True BehaviorName :
Dans Windows PowerShell, exécutez la commande suivante pour afficher la nouvelle configuration de suivi de l'application OrderWorkflowService.
Get-ASAppServiceTracking -SiteName OrderService_PS -VirtualPath "/OrderWorkflowService/OrderWorkflow.xamlx" | fl *
La configuration de suivi doit être affichée comme suit.
IsTrackingEnabled : True ProfileName : CustomOrderServiceProfile - Windows PowerShell Config IsLocal : True BehaviorName :
Utilisation de Windows PowerShell pour afficher les données de suivi personnalisé
Dans cette section, vous allez utiliser une fonction de script pour afficher les événements de flux de travail des variables de flux de travail suivies que vous avez configurées dans la section précédente. Pour afficher les nouvelles informations de suivi, vous devez exécuter une nouvelle instance de flux de travail et générer les données de suivi à l'aide de la nouvelle configuration de suivi.
Ajout d'une nouvelle fonction de script pour afficher les informations de suivi
Effectuez les opérations suivantes pour ajouter une nouvelle fonction de script au fichier Utility.ps1 et afficher les informations de suivi personnalisé.
Dans Windows PowerShell, entrez la commande suivante.
Notepad .\Utility.ps1
Copiez et collez le code de script suivant en bas du fichier Utility.ps1 dans le Bloc-notes.
#============================================================================================# #=== ===# #=== Retrieves Tracked WF Variable Events for the given workflow and variable from the ===# #=== specified monitoring store. ===# #=== ===# #============================================================================================# Function GetTrackedWFVariableEvents($FullWorkflowName,$trackedVariable,$database) { $SQL = "SELECT EventSources.Name AS WorkflowName, " + "EventSources.Computer, " + "EventSources.Site, " + "EventSources.VirtualPath, " + "WfEvents.Id AS EventID, " + "WfEvents.WorkflowInstanceId, " + "WfEvents.TimeCreated, " + "WfEvents.Name AS EventName, " + "WfEvents.State, " + "WfEvents.ActivityName, " + "WfEvents.Exception, " + "WfEventProperties.Name AS TrackedVariableName, " + "WfEventProperties.Value AS TrackedVariableValue " + "FROM EventSources INNER JOIN " + "WfEvents ON EventSources.Id = WfEvents.EventSourceId INNER JOIN " + "WfEventProperties ON WfEvents.Id = WfEventProperties.EventId " + "WHERE EventSources.Name = `'$FullWorkflowName`' AND WfEventProperties.Name = `'$trackedVariable`'" Invoke-Sqlcmd -Query $SQL -Database $database }
Cette nouvelle fonction GetTrackedWFVariableEvents comporte une légère modification par rapport à la fonction GetWFEvents. Elle ajoute un INNER JOIN à la vue WfEventProperties pour afficher les noms des variables suivies et leurs valeurs. Elle filtre également la requête SQL selon les noms de flux de travail et de variable suivie au lieu de l'ID d'instance (InstanceId). Ceci permet d'identifier l'instance de flux de travail par la valeur Quantity définie lorsque vous passez une commande. Un ID de commande doit être exposé à des fins de suivi.
Fermez le Bloc-notes et cliquez sur Enregistrer pour enregistrer les modifications apportées au fichier Utility.ps1.
Dans Windows PowerShell, entrez la commande suivante pour importer les nouvelles modifications apportées au fichier Utility.ps1 pour la session Windows PowerShell actuelle.
Import-Module .\Utility.ps1
Génération et affichage des nouvelles données de suivi
Exécutez OrderClient.exe. Ce fichier doit avoir été déployé dans le dossier C:\DublinTutorial\OrderClient comme décrit dans la Leçon 1 : mise en route du Didacticiel utilisant l'interface de Windows Server AppFabric.
Entrez 88 pour la valeur Quantity.
Cliquez sur Submit dans le formulaire de commande Contoso.com. En bas du formulaire, vérifiez que la section d'état affiche le texte Your order has been received avant de poursuivre. Une nouvelle instance du flux de travail de commande est ensuite exécutée et simule le traitement d'une commande.
Patientez environ 30 secondes, le temps que les informations de suivi soient enregistrées.
Dans la fenêtre de Windows PowerShell, entrez la commande suivante pour afficher les événements de suivi.
GetTrackedWFVariableEvents "Microsoft.Samples.Dublin.Tutorials.OrderService.OrderWorkflowService.OrderWorkflow" quantity OrderService_PS
Le résultat doit ressembler au rapport suivant. Notez les variables TrackedVariableName et TrackedVariableValue suivies pour l'instance de flux de travail.
WorkflowName : Microsoft.Samples.Dublin.Tutorials.OrderService.OrderWorkflowService.OrderWorkflow Computer : server1 Site : OrderService_PS VirtualPath : /OrderWorkflowService/OrderWorkflow.xamlx EventID : 1439 WorkflowInstanceId : ac0fd7fb-d463-4683-9c75-80d90a8b75ed TimeCreated : 2009-11-02 10:09:21.3108822 EventName : Wait for order State : Closed ActivityName : Exception : TrackedVariableName : quantity TrackedVariableValue : 88
Actions effectuées
Dans cette leçon, vous avez créé un modèle de suivi et utilisé les cmdlets de AppFabric pour Windows PowerShell pour configurer l'utilisation de ce nouveau modèle par l'application OrderWorkflowService. Vous avez ensuite généré les informations de suivi en créant une instance du flux de travail, puis vous avez affiché les données de suivi à l'aide d'une fonction de script Windows PowerShell personnalisée.
Voir aussi
Concepts
Leçon 1 : prise en main des cmdlets de Windows Server AppFabric pour Windows PowerShell
Leçon 2 : déploiement de l'application OrderService avec Windows PowerShell
Leçon 3 : configuration de l'application OrderService avec Windows PowerShell
Leçon 4 : surveillance de l'application OrderService avec Windows PowerShell
2011-12-05