Is it possible to re-try or skip a Java Service Task?
data:image/s3,"s3://crabby-images/8803b/8803bd9923a8b3c0f48d8b78551990c82ba216fe" alt="rtitov1 rtitov1"
Options
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
‎12-19-2011 09:08 AM
Dear Activiti Gurus,
We're investigating a possibility of using Activiti in our corporate document handling system which has plenty of complex workflows. Those workflows consist of multiple steps that would be Java Service Tasks in Activiti. Most of the steps involve interacting with humans (our advanced analog of a User Task) and transferring data to other corporate systems. Sometimes workflows get stuck in a middle, e.g. due to data inconsistency. When this happens our engineers have to either re-try the stuck task once the problem is resolved or to skip the task and push workflow to the next step if the task was performed manually. In most of our cases re-starting process from the beginning in case of a problem isn't an option since multiple persons may have already approved it and asking them again for approval is not feasible. Therefore when an exception occurs the workflow has to be "suspended" on the errored task with an option of retrying or skipping it. Sometimes a task may even have to be retried if there was no exception altogether (for example, if we transfer data to an external system and the external system reports success but later we discover that somehow the receiver system didn't get data succesfully and we have to re-transfer it again).
Therefore, here is a question: is there a technical possibility to re-try or skip a Java Service Task in a middle of an Activiti process without having to re-start the process from scratch?
Thank you in advance for answering,
Slava
We're investigating a possibility of using Activiti in our corporate document handling system which has plenty of complex workflows. Those workflows consist of multiple steps that would be Java Service Tasks in Activiti. Most of the steps involve interacting with humans (our advanced analog of a User Task) and transferring data to other corporate systems. Sometimes workflows get stuck in a middle, e.g. due to data inconsistency. When this happens our engineers have to either re-try the stuck task once the problem is resolved or to skip the task and push workflow to the next step if the task was performed manually. In most of our cases re-starting process from the beginning in case of a problem isn't an option since multiple persons may have already approved it and asking them again for approval is not feasible. Therefore when an exception occurs the workflow has to be "suspended" on the errored task with an option of retrying or skipping it. Sometimes a task may even have to be retried if there was no exception altogether (for example, if we transfer data to an external system and the external system reports success but later we discover that somehow the receiver system didn't get data succesfully and we have to re-transfer it again).
Therefore, here is a question: is there a technical possibility to re-try or skip a Java Service Task in a middle of an Activiti process without having to re-start the process from scratch?
Thank you in advance for answering,
Slava
Labels:
- Labels:
-
Archive
6 REPLIES 6
Options
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
‎12-19-2011 09:22 PM
I too would like to know if it is possible.
Is it possible using JBPM 5 ? Workflow engines are not meant for such processing ?
Appreciate some pointers.
Thanks
Saprar
Is it possible using JBPM 5 ? Workflow engines are not meant for such processing ?
Appreciate some pointers.
Thanks
Saprar
data:image/s3,"s3://crabby-images/8803b/8803bd9923a8b3c0f48d8b78551990c82ba216fe" alt="rtitov1 rtitov1"
Options
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
‎12-26-2011 06:33 AM
Dear Saprar,
I recon it must be possible since this is a very useful feature and we use it on daily basis. I know it is supported by the ActiveVOS engine and I believe it is supported also by Oracle BPM. We had it as early as in 90s with the Oracle Workflow engine (that one wasn't based on any standards)…
Slava
I recon it must be possible since this is a very useful feature and we use it on daily basis. I know it is supported by the ActiveVOS engine and I believe it is supported also by Oracle BPM. We had it as early as in 90s with the Oracle Workflow engine (that one wasn't based on any standards)…
Slava
data:image/s3,"s3://crabby-images/8803b/8803bd9923a8b3c0f48d8b78551990c82ba216fe" alt="rtitov1 rtitov1"
Options
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
‎12-26-2011 06:34 AM
Can somebody of the Activiti developers please answer this question?
data:image/s3,"s3://crabby-images/8803b/8803bd9923a8b3c0f48d8b78551990c82ba216fe" alt="trademak trademak"
Options
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
‎12-27-2011 04:20 AM
Hi,
Yes this is possible by using async continuations.
So if you set the async attribute to true on a service task the execution will be handled by the job executor.
When the service task fails, it's retried 3 times.
After 3 times the job is in a failed state, but you can still manually start it again.
Best regards,
Yes this is possible by using async continuations.
So if you set the async attribute to true on a service task the execution will be handled by the job executor.
When the service task fails, it's retried 3 times.
After 3 times the job is in a failed state, but you can still manually start it again.
Best regards,
data:image/s3,"s3://crabby-images/8803b/8803bd9923a8b3c0f48d8b78551990c82ba216fe" alt="shanegirl shanegirl"
Options
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
‎12-30-2013 09:51 PM
Hi, may I know how can we start the service task manually if the job is in a failed state?
data:image/s3,"s3://crabby-images/8803b/8803bd9923a8b3c0f48d8b78551990c82ba216fe" alt="trademak trademak"
Options
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
‎12-31-2013 04:29 AM
When the job is in a failed state you can use the JobQuery to retrieve these failed jobs and execute them manually via the ManagementService API.
Best regards,
Best regards,
data:image/s3,"s3://crabby-images/84277/84277780c904bab1f192c002d3f104f10a4e8390" alt=""