You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
What is a workflow? Wikipedia says "A workflow consists of an orchestrated and repeatable pattern of activity, enabled by the systematic organization of resources into processes that transform materials, provide services, or process information."
10
+
11
+
None of that is incorrect. But it is certainly a mouthful. If I am asked in an elevator what a workflow orchestration is, I like to use analogies to make the point as approachable as possible:
12
+
13
+
14
+
"It's like a recipe for code. A recipe has a series of steps, that must be run in a specific order. Iyt can also have different options for food allergies, or different ingredients you might have on hand? A workflow is a recipe for your code, and can be built to handle many of the changes that might reasonably occur when the code runs."
15
+
16
+
## Workflows as recipes
17
+
18
+
You may have seen one of the name videos out there of parents teaching kids code by writing out the steps to create a Peanut butter and Jelly sandwich.
19
+
20
+
<palign="center"><iframewidth="560"height="315"src="https://www.youtube.com/embed/Ct-lOOUqmyY"title="YouTube video player"frameborder="0"allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture"allowfullscreen></iframe></p>
21
+
22
+
23
+
We're not going to be quite as silly as that Dad, but we'll run through some instructions on how to [create a PB&J](https://www.instructables.com/How-to-Make-a-Peanut-Butter-and-Jelly-Sandwich-4/) from Instructables..
24
+
25
+
> If you look at the URL of that recipe - it appears it took 4 tries to get it right :Dhttps://www.instructables.com/How-to-Make-a-Peanut-Butter-and-Jelly-Sandwich-4/
26
+
27
+
The steps are (skipping some substeps for clarity):
28
+
29
+
1. Gather Your Ingredients for the Sandwich
30
+
2. Pull Out Two Slices of Bread
31
+
3. Open Peanut Butter and Jelly
32
+
4. Spread the Peanut Butter Onto One Slice of Bread
33
+
5. Spread the Jelly Onto the Other Slice of Bread
34
+
6. Combine the Two Slices
35
+
7. Clean Up Your Workspace
36
+
8. Enjoy Your Sandwich
37
+
38
+
(if you read closely, I skipped 3 steps - wearing gloves, removing the crust and cutting the sandwich in half... because, well - that's all just ridiculous)
39
+
40
+
The eight steps above are a workflow. They must be performed in that order to create a sandwich - you cannot spread the PB before you lay out the bread.
41
+
42
+
## Building a Conductor Workflow
43
+
44
+
We can turn these 8 steps into a Conductor workflow.
45
+
<palign="center"><imgsrc="/content/img/blogassets/pbj1.png"alt="PB&J example workflow"width="400"style={{paddingBottom:40,paddingTop:40}} /></p>
46
+
47
+
> If you'd like to see the definition of this workflow, you can check out the code on the [Orkes Playground](https://play.orkes.io/workflowDef/PBJ/1). It's free to sign up.
48
+
49
+
50
+
This workflow shows clear steps with arrows pointing to the next step - so it is visually possible to see how the workflow will progress.
51
+
52
+
## Improving the workflow
53
+
54
+
Each task is run by a microservice, so making changes and adding tasks is easy to do. In this example - you see that the recipe calls for PB to be spread first, and then the jelly. This works for a single human - these steps each take 2 hands. But there is no reason that the jelly cannot go first, and THEN the PB. Or - if you had more hands - the PB and the Jelly could be spread simultaneously.
55
+
56
+
### Independent tasks
57
+
58
+
Let's remove the PB dependency from the jelly spreading - as the order of PB vs. jelly does not matter.
59
+
60
+
We can do this in Conductor with a [FORK](https://orkes.io/content/docs/reference-docs/fork-task). A fork splits your workflow into 2 asynchronous tasks, and then a [JOIN](https://orkes.io/content/docs/reference-docs/join-task) reconnects the the workflow into a single path.
61
+
62
+
We can now apply a fork to apply PB, and a second fork to apply the jelly:
63
+
64
+
<palign="center"><imgsrc="/content/img/blogassets/pbj2.jpg"alt="PB&J example workflow"width="800"style={{paddingBottom:40,paddingTop:40}} /></p>
65
+
66
+
This is version 2 of the workflow, and you can see it in the [playground](https://play.orkes.io/workflowDef/PBJ/2)
67
+
68
+
Now, these operations are independent, and if there is space in the jelly task queue - that can be completed ahead of the PB.
69
+
70
+
## Recipe variations
71
+
72
+
Often, recipes have variations to preparation, and they can be read like an IF statement in programming (If (fresh tomatoes) {do x}, else if (tinned tomatoes) {do y}.
73
+
74
+
75
+
### Cooking a burrito
76
+
77
+
Let's look at a common example - from a burrito in my freezer. The directions vary depending on the cooking method.
We can emulate this in a workflow using a switch task. The Switch task takes in the workflow ovenType input ```${workflow.input.ovenType}``` and based on this value will make a decision. The default case is for the microwave, and then second ```decisionCase``` is set to "oven". From that input, the different tasks can be run.
Workflows are a series of tasks that must be followed in a certain order. In this post, we used cooking recipes as an analogy to a workflow - they too are a series of tasks that must be followed in a certain order.
90
+
91
+
We created sample workflows for making a peanut and jelly sandwich ([version 1](https://play.orkes.io/workflowDef/PBJ/1) and [version2](https://play.orkes.io/workflowDef/PBJ/2)) and another workflow to cook a [frozen burrito](https://play.orkes.io/workflowDef/burrito) with microwave or oven instructions.
92
+
93
+
If you're curious about how to build a workflow orchestration - it might be a fun exercise to try your favorite recipe as a workflow. You can build on the workflows from this post in our free playground. Feel free to share what you came up with in our [Discord](https://discord.gg/pYYdYsYTAw). We love seeing creative uses of workflows!
Copy file name to clipboardExpand all lines: docs/how-tos/sdks/conductor-csharp/main/README.md
+81-31Lines changed: 81 additions & 31 deletions
Original file line number
Diff line number
Diff line change
@@ -6,12 +6,15 @@ To find out more about Conductor visit: [https://github.com/Netflix/conductor](h
6
6
`conductor-csharp` repository provides the client SDKs to build Task Workers and Clients in C#
7
7
8
8
## Quick Start
9
+
1.[Get Secrets](#Get-Secrets)
10
+
2.[Write workers](#Write-workers)
11
+
3.[Run workers](#Run-workers)
12
+
4.[Worker Configurations](#Worker-Configurations)
13
+
5.[Starting workflow](#Starting-workflow)
9
14
10
-
1.[Write workers](#Write-workers)
11
-
2.[Run workers](#Run-workers)
12
-
3.[Worker Configurations](#Worker-Configurations)
13
-
4.[Starting workflow](#Starting-workflow)
14
-
15
+
### Get Secrets
16
+
Executing workflow or polling a task from a playground requires keyId and keySecret.
17
+
Please follow [guide](https://orkes.io/content/docs/codelab/helloworld#application-permissions) to provision one for your application.
15
18
16
19
### Write workers
17
20
@@ -50,7 +53,8 @@ To find out more about Conductor visit: [https://github.com/Netflix/conductor](h
50
53
51
54
### Run workers
52
55
Create main method that does the following:
53
-
1. Adds configurations such as metrics, authentication, thread count, Conductor server URL
56
+
1. Search for package called conductor-csharp in microsoft nuget package manager and install it as dependencies. If you are planning to run worker then
57
+
Microsoft.Extensions.Hosting is also required.
54
58
2. Add your workers
55
59
3. Start the workers to poll for work
56
60
```
@@ -66,28 +70,33 @@ using Conductor.Client.Extensions;
66
70
using Conductor.Client.Interfaces;
67
71
68
72
using Task = System.Threading.Tasks.Task;
73
+
using Conductor.Client;
74
+
using System.Collections.Concurrent;
69
75
70
-
namespace SimpleConductorWorker
76
+
namespace TestOrkesSDK
71
77
{
72
78
class Program
73
79
{
74
-
static async Task Main(string[] args)
80
+
static void Main(string[] args)
75
81
{
76
-
await new HostBuilder()
77
-
.ConfigureServices((ctx, services) =>
78
-
{
79
-
80
-
Configuration configuration = new Configuration(new ConcurrentDictionary<string, string>(), "keyId", "keySecret");
0 commit comments