Monger is an idiomatic Clojure MongoDB driver for a more civilized age.
It has batteries included, offers powerful expressive query DSL, strives to support modern MongoDB features and have the "look and feel" and flexibility of the MongoDB shell.
Monger is built from for modern Clojure versions and sits on top of the official MongoDB Java driver.
There is one MongoDB client for Clojure that has been around since 2009. So, why create another one? Monger authors wanted a client that would
Monger is not a young project: started in July 2011, it is over 7 years old with active production use from week 1.
Monger artifacts are released to
Clojars. If you are using
Maven, add the following repository definition to your pom.xml
:
<repository>
<id>clojars.org</id>
<url>http://clojars.org/repo</url>
</repository>
With Leiningen:
[com.novemberain/monger "3.5.0"]
With Maven:
<dependency>
<groupId>com.novemberain</groupId>
<artifactId>monger</artifactId>
<version>3.5.0</version>
</dependency>
Please refer to our Getting Started guide. Don't hesitate to join our mailing list and ask questions, too!
Please see our documentation guides site and API reference.
Our test suite also has many code examples.
Monger has a mailing list. Feel free to join it and ask any questions you may have.
To subscribe for announcements of releases, important changes and so on, please follow @ClojureWerkz on Twitter.
Monger requires Clojure 1.8+. The most recent stable release is highly recommended.
Monger is part of the group of Clojure libraries known as ClojureWerkz, together with Cassaforte, Langohr, Elastisch, Quartzite and several others.
Monger uses Leiningen 2. Make sure you have it installed and then run tests against supported Clojure versions using
./bin/ci/before_script.sh
lein all do clean, javac, test
Or, if you don't have mongodb installed, you can use docker
docker-compose up
./bin/ci/before_script_docker.sh
lein all do clean, javac, test
Then create a branch and make your changes on it. Once you are done with your changes and all tests pass, submit a pull request on Github.
Copyright (C) 2011-2018 Michael S. Klishin, Alex Petrov, and the ClojureWerkz team.
Double licensed under the Eclipse Public License (the same as Clojure) or the Apache Public License 2.0.
Can you improve this documentation? These fine people already did:
Michael S. Klishin, Michael Klishin, Daniel Fitzpatrick, Bitdeli Chef, Ethan McCue, Oleksandr Petrov, Anton Podviaznikov, 冯忠孝, Andrei Biasprozvanny & Toby HedeEdit on GitHub
cljdoc is a website building & hosting documentation for Clojure/Script libraries
× close