Working around the 90 minute limit
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
โ01-15-2021 04:17 AM
[Dec 3, 2020] Mike Power (CRM Enterprise Architect at American University) posted:
Good afternoon all,
I have a parent recipe that retrieves records from an outside source, then loops through each transaction and calls a child recipe to process that individual transaction. When all are done, it marks a flag that all transactions are complete.
Currently I make the calls to the child recipe synchronously so that when I get to the last steps in the parent recipe, I know theyโre all done. Recently I started hitting that 90 minute timeout in Workato.
So Iโm considering how to re-do things.
My initial thoughts are to call the child recipe asynchronously (though it seems to only allow it up to 5 times in parallel, where I may have a couple thousand transactions to get through), then at the end of the parent recipe update either a Lookup table or maybe thereโs something in the pub/sub I can utilize (though I havenโt read up on that yet). Then maybe each child recipe, when they finish, they update either the Lookup or pub/sub so that a recipe gets triggered to compare the count completed with the total count (recorded by the parent recipe when it finished), and only when they equal does a triggered recipe update the flag.
Clearly this is half-baked and Iโm just starting to think it through. Iโd welcome any thoughts from anyone who has already cracked this nut before.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
โ01-15-2021 04:18 AM
[Dec 4, 2020] Deven Maru (CSM at Workato) replied:
Mike,
Take a look at the wait featurehttps://docs.workato.com/features/callable-recipes/wait-for-async-action.html. This way you'll avoid manual callable recipe completion synchronization.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
โ01-15-2021 04:18 AM
[Dec 4, 2020] Mike Power (CRM Enterprise Architect at American University) replied:
Thanks Deven. I did consider that but if I can only execute 5 of my child workflows at a time (Iโm assuming the โConcurrencyโ setting applies regardless of sync/async), I still worry about the parent recipe waiting for all of the child recipes to finish within the 90 minute allotment. I had hoped to get away from the 90 minute limit completely. Do you think thereโs another way to go about that?
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
โ01-15-2021 04:19 AM
[Dec 10, 2020] Deven Maru (CSM at Workato) replied:
Posting rest of the conversation here after the above message was posted by Mike.
[DEVEN] Mike, there's a timeout limit input field in the Wait action of Callable recipe. You can set it to more than90mins and try it out. I'm including Gabriel who can provide more information.
[MIKE] Thanks Deven. Doesnโt that timeout limit mean that the parent recipe which is awaiting the child recipe will wait longer than 90 minutes, but the parent recipe itself will still get timed out after 90 minutes?
[DEVEN] No, the parent recipe will "sleep" at the Wait step waiting for your callable recipes to complete. The parent recipe timeout clock "sleeps" as well. When the wait is over, the timeout clock resumes. So, to answer your question, the parent recipe should not get timed out.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
โ01-15-2021 04:20 AM
[Dec 11, 2020] Mike Power (CRM Enterprise Architect at American University) replied:
Thanks. Iโve set the child recipe to be asynchronously called (concurrency = 5) and then I calculate a wait time based on the number of transactions.
Worked ok in Test so Iโll move it to Prod soon, and hopefully all will be well!