33
Real-Life Szenario mit der Workflow Foundation 4 Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht.

Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

Embed Size (px)

Citation preview

Page 1: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

Real-Life Szenario mit der Workflow Foundation 4

Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma?

Eine "Schnell"übersicht.

Page 2: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

Keine Zeit, kein Code Keine Zwischenfragen Kein Anspruch auf Vollständigkeit

Motivation Wer kennt die Workflow Foundation? Was könnten Gründe für den Einsatz sein?

1) Prolog

Page 3: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

Begriff “Workflow” Etwas Theorie Scenario: “Registration” Scenario: Decoded Das Ganze in .NET Scenario: Reloaded Sonstiges Zur Ausgangsfrage Quellen

2) Agenda

Page 4: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

Ein Arbeitsfluss (englisch: workflow) ist eine inhaltlich abgeschlossene, zeitlich und sachlogisch zusammenhängende Folge von Funktionen, die zur Bearbeitung eines betriebswirtschaftlich relevanten Objektes notwendig sind und deren Funktionsübergänge von einem Informationssystem gesteuert werden.

Quelle: http://de.wikipedia.org/wiki/Arbeitsablauf

3) Begriff

Page 5: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

Skalierbare Geschäftslogik mit einfacher Zustandsverwaltung

Gesamtheitlicher Blick auf den Ablauf der Anwendung

Anwendungen persistierbar machen Anteil der “Sichtbarkeit” erhöhen

4) Ziele der WF-Entwicklung

Page 6: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

5) Gesamtheitlicher Code (1/2)

Page 7: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

Vorteile:◦ Einfach zu verstehen ◦ Einfach zu pflegen◦ Zustand der Anwendung ist immer „sichtbar“

Nachteile:◦ Nicht skalierbar◦ Eine Anfrage könnte geblockt werden

6) Gesamtheitlicher Code (2/2)

Page 8: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

7) Code Blöcke (1/2)

Page 9: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

Vorteile:◦ Ressourcen können freigegeben werden

(Entladen)◦ Skalierbar auf mehrere Maschinen (bspw.)

Nachteile :◦ Der Zustand muss irgendwo „geteilt“ werden◦ Ablauf ist nicht offenkundig◦ Schwerer zu pflegen

8) Code Blocks (2/2)

Page 10: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

Was ist denn nun ein Workflow?◦ Workflows are a way to execute a business

process.◦ A workflow is a set of elemental units called

activities that are stored as a model that describes a process

◦ Workflows provide a way of describing the order of execution and relationships between different pieces of running work

Was sind Activities?◦ Möglichst atomarer Block von Logik mit einem

Ergebnis

9) Theorie: Grundlagen

Page 11: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

Anmelde-System der Usergroup: Ein Benutzer meldet sich mit Name und Adresse an. Das System prüft die Validität einiger Felder, u.a. die PLZ.

Danach wartet das System entweder auf die manuelle Freigabe des UG Admins oder prüft die Berechtigung über externe Daten ab.

Sollte der User berechtigt sein, der UG beizutreten, wird er eingebucht und erhält eine Email.

10) Scenario: Registration

Page 12: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

11) Scenario: Diagramm

ValidateZip

Wait For Approval

Send Mail

ApproveUser

Check Webservice

Daten erfasst

User akzeptiert

Page 13: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

Arten von Activities◦ Base Activity Library

.NET

12) Scenario: Decoded

Page 14: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

Flow Control

• Flowchart• ForEach• Parallel• ParallelForEach• DoWhile• Pick

Collection

• AddToCollection• RemoveFromCollection• ExistsInCollection• ClearCollection

Others

• Assign• InvokeMethod• Persist• TryCatch• Interop

13) Base Activity Library

Page 15: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

Arten von Activities◦ Base Activity Library

.NET Drittanbieter (Sharepoint, Dynamics, TFS, etc.)

◦ Custom Activities (drei Arten) Automatische Event-getriebene Hybride

◦ Composite Activities

14) Scenario: Decoded (1/5)

Page 16: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

15) Scenario: Decoded (2/5)

ValidateZip

Wait For Approval

Send Mail

ApproveUser

Check Webservice

Daten erfasst

User akzeptiert

Page 17: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

Activity “Validate Zip”◦ Überprüft ob eine erfasste PLZ valide ist.

Custom Activity◦ Einfacher Task◦ Zusammengesetzte Activity (Composite)◦ Low Level Activity – Skilled Programmer◦ High Level Activity – Less technical people

16) Scenario: Decoded (2/5)

Page 18: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

17) Scenario: Decoded (3/5)

ValidateZip

Wait For Approval

Send Mail

ApproveUser

Check Webservice

Daten erfasst

User akzeptiert

Page 19: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

Activity “Approve User”◦ Wartet auf ein Benutzerereignis. (Button Click)

Bookmarks (Resume Workflow)◦ Name◦ Daten

Base Activity Library◦ Flow control

18) Scenario: Decoded (3/5)

Page 20: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

19) Scenario: Decoded (4/5)

ValidateZip

Wait For Approval

Send Mail

ApproveUser

Check Webservice

Daten erfasst

User akzeptiert

Page 21: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

Activity “Wait for Approval”◦ Erwartet Approval entweder vom Event oder vom

Webservice, der periodisch anfragt.

Parallel Activity◦ Kein Multi-Core Unterstützung◦ Einfache Art Quasi-parallele Abläufe zu gestalten◦ Akzeptiert nur “Sequence” Activity◦ Mehrere “Sequence” Activities möglich

20) Scenario: Decoded (4/5)

Page 22: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

21) Scenario: Decoded (4/5)

ValidateZip

Wait For Approval

Send Mail

ApproveUser

Check Webservice

Daten erfasst

User akzeptiert

Page 23: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

Activity “Check Webservice”◦ Webservice fragt periodisch ab, ob Benutzer

approved ist.

Long-running Processes◦ Persistieren von Workflows

Geschieht automatisch Lassen sich in anderen Prozessen (Maschinen) laden

◦ Entladen von Workflows Persistieren und Speicher frei geben

22) Scenario: Decoded (5/5)

Page 24: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

23) Scenario: Workflow Persistenz

Page 25: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

Activities sind C# Klassen◦ In Argumente ◦ Out Argumente◦ Variablen / Zustand (Scopes)

Was sind Workflows?◦ Arten von Workflows

Sequence Flowchart State Machine

24) Das Ganze in .NET (1/2)

Page 26: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

Workflow Definitionen◦ Definieren Ablauf der Activities◦ Format ist XAML (XML)

Eigene Runtime◦ Verwaltet Threads◦ Kennt die Grenzen zwischen Activties◦ Kennt die Semantik der Activities nicht

25) Das Ganze in .NET (2/2)

Page 27: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

Anwendungsentwicklung im klassischen Sinne bedeutet Code schreiben

Der Kontrollfluss eines Workflows kann grafisch zusammengesetzt werden, und ist somit:

hilfreich für Personen die existierende Anwendungen pflegen und ändern müssen◦ (Lernaufwand bei Einarbeitung ist relativ hoch)

26) Sichtbare Prozesse (1/1)

Page 28: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

27) Sichtbare Prozesse (2/3)

Page 29: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

28) Sichtbare Prozesse (2/3)

Page 30: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

29) Scenario: Reloaded

ValidateZip

Wait For Approval

Send Mail

ApproveUser

Check Webservice

Daten erfasst

User akzeptiert

Page 31: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

Tracking◦ Runtime sieht Übergänge (Boundaries)◦ Event-getriggert / konfigurierbar

Entered Exited Faulted

◦ Kein Entwicklungsaufwand nötig◦ Entwicklung von eigenem Tracking möglich

Testing◦ Workflow ist Activity◦ In / Out Parameter

Designer Hosting in Anwendung ist möglich Hosting der Workflow Runtime

◦ Application◦ Service

30) Sonstiges

Page 32: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

Brauchen wir ein neues Programmierparadigma?

Mögliche Gründe:◦ Lang laufende Prozesse◦ Parallele Aktivitäten◦ Flexible Logik / Copy & Paste von Prozessen◦ Team mit weniger Skills

31) Zur Ausgangsfrage

Page 33: Einsatzmöglichkeiten der Workflow Foundation 4, oder: Brauchen wir wirklich noch ein Programmierparadigma? Eine "Schnell"übersicht

The Workflow Way; David Chappell, Chappell & Associates (April 2009)

Essential Windows Workflow Foundation; Dharma Shukla, Bob Schmidt (2007)

Vom Geschäftsprozess zum Workflow; Jakob Freund, Klaus Götzer (2008)

http://blog.helmichs.net

Quellen