[ 
https://issues.apache.org/jira/browse/OOZIE-2394?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Purshotam Shah updated OOZIE-2394:
----------------------------------
    Description: 
To speedup job submission ( not the the forked actions) we create workflow 
actions synchronously. We call ActionStartXCommand from SignalXCommand by 
setting isSynchronous = true. This will bypass lock acquiring, which is Ok, 
SignalXCommand will have the job lock.

If there is transient error. Same command is requeued which will have 
isSynchronous flag set to true.

Requeued command will wake-up and started executing without acquiring lock. If 
the job submission takes more than 2 min, then we might have issue.

Action recovery is set to 2 min ( default), Recovery service will run and 
submitted new the command. since the first command didn't acquire any lock. 
Recovery will be able to run the new command.

We will have two same command running parallely.

All our commands are reentrant, we don't have to have set synchronized flag to 
run multiple command from same thread.
Because of reentrant, command running in same thread should be able to acquire 
same lock.


> Oozie can execute command without holding lock
> ----------------------------------------------
>
>                 Key: OOZIE-2394
>                 URL: https://issues.apache.org/jira/browse/OOZIE-2394
>             Project: Oozie
>          Issue Type: Bug
>            Reporter: Purshotam Shah
>            Priority: Critical
>
> To speedup job submission ( not the the forked actions) we create workflow 
> actions synchronously. We call ActionStartXCommand from SignalXCommand by 
> setting isSynchronous = true. This will bypass lock acquiring, which is Ok, 
> SignalXCommand will have the job lock.
> If there is transient error. Same command is requeued which will have 
> isSynchronous flag set to true.
> Requeued command will wake-up and started executing without acquiring lock. 
> If the job submission takes more than 2 min, then we might have issue.
> Action recovery is set to 2 min ( default), Recovery service will run and 
> submitted new the command. since the first command didn't acquire any lock. 
> Recovery will be able to run the new command.
> We will have two same command running parallely.
> All our commands are reentrant, we don't have to have set synchronized flag 
> to run multiple command from same thread.
> Because of reentrant, command running in same thread should be able to 
> acquire same lock.



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

Reply via email to