flowable <-> flink integration

classic Classic list List threaded Threaded
3 messages Options
Reply | Threaded
Open this post in threaded view
|

flowable <-> flink integration

Martin Grofčík
Hi,

I want to implement flowable (BPMN platform  - www.flowable.org) <-> flink integration module. The motivation is to execute process simulations with flink (simple simulation experiment example https://gromar01.wordpress.com/2017/11/07/will-we-meet-our-kpis/). I was able to create 


Flink provides REST API through which I can easily create a job and monitor its execution.


at the end I can encapsulate whole process into one task (e.g. Execute flink job) which will do the same in java code. 
In fact I have no experience with flink that's why I can imagine only process steps to:
1. create flink job
2. monitor its state

Question 1:
Can you propose another useful process steps? (e.g.  to download results, upload datasets, .....)
(Provide me a link how I can proceed with their implementation, please)

Question 2:
The problem with the process is that it is always checking job state. I would prefer to add a hook at the end of flink job execution to call flowable rest API to notify process instance about the job finished (failed....) events.
The way which I have found is to implement rest end point org.apache.flink.runtime.webmonitor.handlers.JarPlanHandler which calls flowable rest api at the end of flink job execution.
What I would prefer is to make something like wrapper around the main class to execute flowable rest call at the end.
Can you provide me a hint how to implement this wrapper please?

Thank you in advance for the answer.

Regards
Martin

wordCountProcess.PNG (20K) Download Attachment
Reply | Threaded
Open this post in threaded view
|

Re: flowable <-> flink integration

Maciek Próchniak

Hi Martin,


I did some activiti development so your mail caught my attention :)

I don't think I understand what are you trying to achieve - where is process you're simulating, where is simulation running and where is place for Flink. Do you want to invoke Flink (batch job I suppose?) from Flowable process? Or do you want to run simulations of BPMN process as Flink job?


thanks,

maciek


On 16/01/2018 22:29, Martin Grofčík wrote:
Hi,

I want to implement flowable (BPMN platform  - www.flowable.org) <-> flink integration module. The motivation is to execute process simulations with flink (simple simulation experiment example https://gromar01.wordpress.com/2017/11/07/will-we-meet-our-kpis/). I was able to create 


Flink provides REST API through which I can easily create a job and monitor its execution.


at the end I can encapsulate whole process into one task (e.g. Execute flink job) which will do the same in java code. 
In fact I have no experience with flink that's why I can imagine only process steps to:
1. create flink job
2. monitor its state

Question 1:
Can you propose another useful process steps? (e.g.  to download results, upload datasets, .....)
(Provide me a link how I can proceed with their implementation, please)

Question 2:
The problem with the process is that it is always checking job state. I would prefer to add a hook at the end of flink job execution to call flowable rest API to notify process instance about the job finished (failed....) events.
The way which I have found is to implement rest end point org.apache.flink.runtime.webmonitor.handlers.JarPlanHandler which calls flowable rest api at the end of flink job execution.
What I would prefer is to make something like wrapper around the main class to execute flowable rest call at the end.
Can you provide me a hint how to implement this wrapper please?

Thank you in advance for the answer.

Regards
Martin

Reply | Threaded
Open this post in threaded view
|

Re: flowable <-> flink integration

Martin Grofčík
Hi Maciek,

Thanks a lot for your answer. The first step which I did was that I am able execute flink job through flink REST API. Until flink job runs flowable process instance checks the status of the process through the flink rest API. Process instance continues further when the process ins finished.
I am working now on the example in which flink job at the end sends a signal to the process instance (trough flowable REST API) and process instance will continue in execution (I do not expect any issue there). In that case flink job needs some additional code to send signal to flowable.

What I want to achieve is that there will be something like jobWrapper, which will at the end of wrapped flink job execution send a signal to flowable and process instance will continue. So original flink job does not need any modification and can be easily integrated into process execution.


FlinkJobWrapper
______
|    OriginalFlinkJob
|  ____
|  |
|  |
|  |
|  L___
|  Send signal 
L_____


Question is How to do that?

And that's all. (simulations are the next step)

Thank you in advance for your answer.
Regards
Martin

On 18 January 2018 at 19:30, Maciek Próchniak <[hidden email]> wrote:

Hi Martin,


I did some activiti development so your mail caught my attention :)

I don't think I understand what are you trying to achieve - where is process you're simulating, where is simulation running and where is place for Flink. Do you want to invoke Flink (batch job I suppose?) from Flowable process? Or do you want to run simulations of BPMN process as Flink job?


thanks,

maciek


On 16/01/2018 22:29, Martin Grofčík wrote:
Hi,

I want to implement flowable (BPMN platform  - www.flowable.org) <-> flink integration module. The motivation is to execute process simulations with flink (simple simulation experiment example https://gromar01.wordpress.com/2017/11/07/will-we-meet-our-kpis/). I was able to create 


Flink provides REST API through which I can easily create a job and monitor its execution.


at the end I can encapsulate whole process into one task (e.g. Execute flink job) which will do the same in java code. 
In fact I have no experience with flink that's why I can imagine only process steps to:
1. create flink job
2. monitor its state

Question 1:
Can you propose another useful process steps? (e.g.  to download results, upload datasets, .....)
(Provide me a link how I can proceed with their implementation, please)

Question 2:
The problem with the process is that it is always checking job state. I would prefer to add a hook at the end of flink job execution to call flowable rest API to notify process instance about the job finished (failed....) events.
The way which I have found is to implement rest end point org.apache.flink.runtime.webmonitor.handlers.JarPlanHandler which calls flowable rest api at the end of flink job execution.
What I would prefer is to make something like wrapper around the main class to execute flowable rest call at the end.
Can you provide me a hint how to implement this wrapper please?

Thank you in advance for the answer.

Regards
Martin