Skip to content
The Java driver for MongoDB
Java Groovy
Latest commit 4ba19ea Apr 28, 2016 @rozza rozza Improve Async error logging
A logger is now required when protecting callbacks from errors

JAVA-2177
Failed to load latest commit information.
bson JAVA-2144: Fix @since annotation for BsonTypeCodecMap Apr 18, 2016
config JAVA-2056: Add MongoClient support for encoding instances of Iterable… Apr 8, 2016
docs Asynchronous GridFS Implementation Apr 6, 2016
driver-async Improve Async error logging Apr 28, 2016
driver-core Improve Async error logging Apr 28, 2016
driver Added Codec for GridFSFile Apr 27, 2016
gradle Updated gradle May 18, 2015
mongo-java-driver JAVA-1857, JAVA-1998: Rolling back the changed introduced by JAVA-185… Oct 5, 2015
util Add a new test category for slow tests that either don't need a runni… Nov 4, 2015
.gitattributes Removed special treatment for .bat files Jun 4, 2013
.gitignore Removed first pass at docs site layout Mar 24, 2015
.travis.yml Updated travis.yml build Nov 9, 2015
CONTRIBUTING.md Updated contributing guide to reflect the current best practices on t… May 28, 2015
History.md Release r2.7.3 Jan 30, 2012
Issues.txt Renamed Serializer class to Codec, created two sub-interfaces called … Apr 3, 2013
LICENSE.txt Fix Async Streams timeout behaviour Sep 4, 2015
README.md Updated build instructions Oct 13, 2015
build.gradle Bump to 3.3.0-SNAPSHOT Dec 7, 2015
gradle.properties Created a check in the build to let us turn off running @Slow tests. … Sep 10, 2014
gradlew Added Gradle wrapper support, idea configuration from gradle, and che… Nov 5, 2013
gradlew.bat added gradlew.bat for windows users. Dec 3, 2013
settings.gradle Normalize copyright headers Jul 22, 2015
settings.jar Applied standards across codecase: Oct 9, 2013

README.md

Release Notes

Release notes are available here.

API Documentation:

Javadoc for all major and minor releases is available here.

Support / Feedback

For issues with, questions about, or feedback for the MongoDB Java driver, please look into our support channels. Please do not email any of the Java driver developers directly with issues or questions - you're more likely to get an answer on the mongodb-user list on Google Groups.

At a minimum, please include in your description the exact version of the driver that you are using. If you are having connectivity issues, it's often also useful to paste in the line of code where you construct the MongoClient instance, along with the values of all parameters that you pass to the constructor. You should also check your application logs for any connectivity-related exceptions and post those as well.

Bugs / Feature Requests

Think you’ve found a bug? Want to see a new feature in the Java driver? Please open a case in our issue management tool, JIRA:

Bug reports in JIRA for the driver and the Core Server (i.e. SERVER) project are public.

If you’ve identified a security vulnerability in a driver or any other MongoDB project, please report it according to the instructions here.

Versioning

Major increments (such as 2.x -> 3.x) will occur when break changes are being made to the public API. All methods and classes removed in a major release will have been deprecated in a prior release of the previous major release branch, and/or otherwise called out in the release notes.

Minor 3.x increments (such as 3.1, 3.2, etc) will occur when non-trivial new functionality is added or significant enhancements or bug fixes occur that may have behavioral changes that may affect some edge cases (such as dependence on behavior resulting from a bug). An example of an enhancement is a method or class added to support new functionality added to the MongoDB server. Minor releases will almost always be binary compatible with prior minor releases from the same major release branch, exept as noted below.

Patch 3.x.y increments (such as 3.0.0 -> 3.0.1, 3.1.1 -> 3.1.2, etc) will occur for bug fixes only and will always be binary compitible with prior patch releases of the same minor release branch.

@Beta

APIs marked with the @Beta annotation at the class or method level are subject to change. They can be modified in any way, or even removed, at any time. If your code is a library itself (i.e. it is used on the CLASSPATH of users outside your own control), you should not use beta APIs, unless you repackage them (e.g. by using shading, etc).

@Deprecated

APIs marked with the @Deprecated annotation at the class or method level will remain supported until the next major release but it is recommended to stop using them.

com.mongodb.internal.*

All code inside the com.mongodb.internal.* packages is considered private API and should not be relied upon at all. It can change at any time.

Binaries

Binaries and dependency information for Maven, Gradle, Ivy and others can be found at http://search.maven.org.

Example for Maven:

<dependency>
    <groupId>org.mongodb</groupId>
    <artifactId>mongodb-driver</artifactId>
    <version>x.y.z</version>
</dependency>

For an all-in-one jar (which embeds the core driver and bson):

<dependency>
    <groupId>org.mongodb</groupId>
    <artifactId>mongo-java-driver</artifactId>
    <version>x.y.z</version>
</dependency>

Snapshot builds are also published regulary via Sonatype.

Example for Maven:

    <repositories>
        <repository>
            <id>sonatype-snapshot</id>
            <url>https://oss.sonatype.org/content/repositories/snapshots/</url>
        </repository>
    </repositories>

For binaries containing the asynchronous API, see the driver-async README.

Build

To build and test the driver:

$ git clone https://github.com/mongodb/mongo-java-driver.git
$ cd mongo-java-driver
$ ./gradlew check

The test suite requires mongod to be running with enableTestCommands.

Build status:

Build Status | Build Status

Maintainers

Contributors:

Additional contributors can be found here.

Supporters

YourKit is supporting this open source project with its YourKit Java Profiler.

JetBrains is supporting this open source project with:

Intellij IDEA

Something went wrong with that request. Please try again.