Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to prevent concurrent execution of a job in Grails?

I have a quartz job in grails, that needs to be executed in every 5s, but I need this sequentially. In some situations the execution of the job exceeds this 5s, in this case I dont't want to be executed while the previouse exection is not finished. How to configure this in grails?

(Of course the whole magic could be done with a static volatile flag, but is not a very elegant way to do this) (Also how can I configure for the job to be singleton?)

thx

like image 277
csviri Avatar asked Jun 23 '11 12:06

csviri


3 Answers

Assuming that you're using the grails quartz plugin, you should just be able to set the concurrent property of your job class to false.

From the Quartz Plugin Documentation:

"By default Jobs are executed in concurrent fashion, so new Job execution can start even if previous execution of the same Job is still running. If you want to override this behavior you can use 'concurrent' property, in this case Quartz's StatefulJob will be used"

In more recent versions of the quartz plugin (version 2.0.13 for Grails 3.3.*), that would look like this:

class MyJob {

    static concurrent = false

    void execute() {
        println "Job run!"
    }
}

For older versions of grails/quartz, it would look similar, exception that properties were set with def instead of static:

class MyJob {

    def concurrent = false

    void execute() {
        println "Job run!"
    }
}
like image 138
Jon Quarfoth Avatar answered Sep 24 '22 00:09

Jon Quarfoth


Make your job class implement StatefulJob instead of Job

like image 39
Dónal Avatar answered Sep 24 '22 00:09

Dónal


For Quartz-based jobs concurrency is achieved using

static concurrent = false

in the job class.

Note the static in the definition, this is needed instead of def concurrent = false at least since version 2.0.12. See the Quartz documentation.

like image 36
andysh Avatar answered Sep 26 '22 00:09

andysh