Permanente Verzögerung
Dieses Thema gilt für Windows Workflow Foundation 4.
In diesem Beispiel wird veranschaulicht, wie eine permanente Verzögerung verwendet wird, eine Verzögerung, die den Workflow während der Verzögerung auf einem permanenten Gerät beibehält. Der Beispielworkflow enthält zwei Meldungen an die Konsole, die durch eine Verzögerung getrennt sind. Wenn die Verzögerung ausgelöst wird, wird der Workflow entladen und verbleibt 5 Sekunden im Workflowinstanzspeicher, bevor er erneut in den Speicher geladen wird.
Workflowdetails
Der Workflowdiensthost hostet den Workflow und verwaltet die Workflowinstanzen durch Laden und Entladen. Zum Starten einer Instanz der Workflowdefinition wird im Beispiel ein Proxy festgelegt, der eine Meldung an die Receive-Aktivität im Workflow sendet. Die CanCreateInstance-Eigenschaft wird auf true festgelegt, sodass eine neue Instanz des Workflows erstellt werden kann, sobald eine Meldung empfangen wird.
Die folgende Liste enthält das Setup des Workflowdiensthosts während der Initialisierung.
Erstellt einen Diensthost mit einer Adresse (https://localhost:8080/Client).
Erstellt einen Endpunkt im Diensthost, um Kommunikation mit der Receive-Aktivität im Workflow zu aktivieren.
Richtet einen SQL-Instanzspeicher ein.
Fügt ein Verhalten zum Entladen von Instanzen hinzu, das die Bedingungen angibt, unter denen der Workflowdiensthost eine Workflowinstanz in den SQL-Persistenzspeicher entladen soll. Für dieses Beispiel wird die Instanz entladen, unmittelbar nachdem der Workflow in den Leerlauf eintritt (wenn die Verzögerung ausgelöst wird).
Erstellt den Proxy, der eine Meldung an die Receive-Aktivität im Workflow sendet.
So verwenden Sie dieses Beispiel
Richten Sie die Persistenzdatenbank ein.
Öffnen Sie eine Visual Studio 2010-Eingabeaufforderung.
Navigieren Sie zum .NET Framework-Verzeichnis (C:\Windows\Microsoft.NET\Framework\v4.X\).
Bearbeiten Sie die Datei "WorkflowManagementService.exe.config", und fügen Sie die folgende Verbindungszeichenfolge im <database>-Element hinzu.
<database connectionString="Data Source=localhost\SQLEXPRESS;Initial Catalog=DefaultSampleStore;Integrated Security=True;Asynchronous Processing=True" />
Navigieren Sie zum Verzeichnis DurableDelay\CS.
Führen Sie "Setup.cmd" aus.
Öffnen Sie Visual Studio 2010 mit erweiterten Berechtigungen, indem Sie mit der rechten Maustaste auf das Symbol Visual Studio 2010 klicken und Als Administrator ausführen auswählen.
Öffnen Sie die Projektmappendatei "Delay.sln".
Drücken Sie F6, um die Projektmappe zu erstellen.
Drücken Sie STRG+F5, um die Projektmappe auszuführen.
So deinstallieren Sie das Beispiel
Öffnen Sie eine Visual Studio 2010-Eingabeaufforderung.
Navigieren Sie zum Verzeichnis DurableDelay\CS.
Führen Sie die Datei "Cleanup.cmd" aus.
Hinweis: |
---|
Die Beispiele sind möglicherweise bereits auf dem Computer installiert. Überprüfen Sie das folgende (standardmäßige) Verzeichnis, bevor Sie fortfahren.
<Installationslaufwerk>:\WF_WCF_Samples
Wenn dieses Verzeichnis nicht vorhanden ist, rufen Sie Windows Communication Foundation (WCF) and Windows Workflow Foundation (WF) Samples for .NET Framework 4 auf, um alle Windows Communication Foundation (WCF)- und WF-Beispiele herunterzuladen. Dieses Beispiel befindet sich im folgenden Verzeichnis.
<Installationslaufwerk>:\WF_WCF_Samples\WF\Basic\Services\DurableDelay
|