A MongoDB-based store for Quartz.
This is a fork of a project originally started by MuleSoft. It supports all Quartz trigger types and tries to be as feature complete as possible.
Maven Artifacts
Artifacts are released to clojars.org.
The Most Recent Release
With Leiningen:
[com.novemberain/quartz-mongodb "1.0.0"]
With Maven:
<dependency>
<groupId>com.novemberain</groupId>
<artifactId>quartz-mongodb</artifactId>
<version>1.0.0</version>
</dependency>
Snapshots
If you are comfortable with using snapshots, snapshot artifacts are released to Clojars every 24 hours.
With Leiningen:
[com.novemberain/quartz-mongodb "1.1.0-SNAPSHOT"]
With Maven:
<dependency>
<groupId>com.novemberain</groupId>
<artifactId>quartz-mongodb</artifactId>
<version>1.1.0-SNAPSHOT</version>
</dependency>
Please note that with minor and major version snapshots, certain backwards-incompatible changes may not match what is in the example below. Documentation always follows the most recent stable release.
Usage
Set your Quartz properties to something like this:
# Use the MongoDB store
org.quartz.jobStore.class=com.mulesoft.quartz.mongo.MongoDBJobStore
# comma separated list of mongodb hosts/replica set seeds
org.quartz.jobStore.addresses=host1,host2
# database name
org.quartz.jobStore.dbName=quartz
# Will be used to create collections like mycol_jobs, mycol_triggers, mycol_calendars, mycol_locks
org.quartz.jobStore.collectionPrefix=mycol
# thread count setting is ignored by the MongoDB store but Quartz requries it
org.quartz.threadPool.threadCount=1
Continuous Integration
CI is hosted by Travis CI
License
FAQ
Why the Fork?
MuleSoft developers did not respond to attempts to submit pull requests for several months. As more and more functionality was added and implementation code refactored, I decided to completely separate this fork form GitHub forks network because the project is now too different from the original one. All changes were made with respect to the Apache Public License 2.0.