Docs 菜单
Docs 主页
/ /

升级驱动程序版本

在本节中,您可以确定必须对应用程序进行哪些更改才能将驱动程序升级到新版本。

升级前,请执行以下操作:

  • 确保新的驾驶员版本与应用程序连接到的MongoDB Server版本以及应用程序运行所在的Java运行时环境 (JRE) 兼容。要查看兼容性信息,请参阅 兼容性页面。

  • 破坏性变更部分解决应用程序使用的驱动程序的当前版本与计划升级版本之间发生的任何破坏性变更。要了解有关 MongoDB Server 版本兼容性更改的更多信息,请参阅服务器版本兼容性更改部分。

提示

为了最大限度地减少将来升级驾驶员版本时应用程序可能需要的更改次数,请使用 Stable API。

破坏性变更 (breaking change) 是对特定版本驱动程序中的约定或行为的修改,如果在升级前未解决,可能会阻止应用程序正常工作。

本节中的破坏性变更按引入它们的驱动程序版本进行分类。升级驱动程序版本时,请解决当前版本和升级版本之间的所有破坏性变更。示例,如果您要将驱动程序从 v5.0 升级到 v5.5,解决v5.0 之后版本的所有破坏性变更包括为 v5.5 列出的任何内容。

此驱动程序版本引入了以下破坏性变更 (breaking change):

  • 删除对MongoDB Server v3.6 的支持。 要学习;了解有关此更改的更多信息,请参阅驱动程序版本 5.2服务器支持更改部分。

  • 修改mongodb-crypt依赖项版本控制以匹配Java虚拟机(JVM)驱动程序的版本控制。未来版本的 mongodb-crypt 将与驱动程序一起发布,并共享相同的版本号。您必须将 mongodb-crypt 依赖项升级到 v5。2。0在为此发布升级驱动程序时。

此驱动程序版本引入了以下破坏性变更 (breaking change):

  • 使用 MONGODB-OIDC身份验证机制时,不能在 authMechanismProperties连接字符串值中包含逗号字符。 如果 authMechanismProperties 值包含逗号,请将该值作为连接选项传递到 MongoClientSettings实例中。

此驱动程序版本引入了以下破坏性变更 (breaking change):

  • ConnectionId 类进行了以下更改:

    • ConnectionId构造函数现在接受类型为long的值而不是类型为int的值作为其第二个参数。 同样,构造函数现在接受类型为Long的值作为其第三个参数,而不是类型为Integer的值。 由于此更改破坏了二进制兼容性,因此请重新编译调用ConnectionId构造函数的任何现有代码。

    • withServerValue() 方法现在接受类型为 long 而不是 int 的参数。 由于此更改破坏了二进制兼容性,因此您必须重新编译调用 withServerValue() 方法的所有代码。

    • getServerValue()方法现在返回类型为Long的值,而不是类型为Integer的值。 同样, getLocalValue()方法返回类型为long的值,而不是类型为int的值。 由于此更改会破坏二进制文件和源代码的兼容性,因此请更新使用这些方法的所有源代码并重新构建二进制文件。

  • org.bson.codecs.record.annotations包中的以下记录注解替换为org.bson.codecs.pojo.annotations包中的同名注解:

    • BsonId

    • BsonProperty

    • BsonRepresentation

  • 更改 SocketSettings.Builder.connectTimeout()SocketSettings.Builder.readTimeout() 方法的 connectTimeout 超时持续时间参数的数据类型。 此参数的数据类型现在是 long,而不是 int

    在早期版本中,对于这两种方法,此参数的类型均为int 。 此更改破坏了二进制兼容性,需要重新编译,但不需要更改代码。

  • 删除了在 Beta 中独家发布的 Filters.eqFull() 方法,该方法允许您在执行向量搜索时构造相等过滤。 相反,您可以在实例化 VectorSearchOptions 类型时使用 Filters.eq() 方法,如以下代码所示:

    val opts = vectorSearchOptions().filter(eq("x", 8))
  • 更改 ClusterSettings 计算 ClusterConnectionMode 设置的方式,通过使用指定的副本集名称使其更加一致,而无论其配置如何。以前,驱动程序仅在连接字符串中设立副本集名称。

    示例,以下两个代码示例均会返回值 ClusterConnectionMode.MULTIPLE。 此前,第二个示例会返回 ClusterConnectionMode.SINGLE

    ClusterSettings.builder()
    .applyConnectionString(ConnectionString("mongodb://127.0.0.1:27017/?replicaSet=replset"))
    .build()
    .mode
    ClusterSettings.builder()
    .hosts(listOf(ServerAddress("127.0.0.1", 27017)))
    .requiredReplicaSetName("replset")
    .build()
    .mode
  • BsonDecimal128 值响应方法调用的方式与 Decimal128 值相同。 BsonDecimal128.isNumber() 现在会返回 true,而 BsonDecimal128.asNumber() 会返回等效的 BsonNumber

  • 删除 ServerAddress 方法 getSocketAddress()getSocketAddresses()

    使用 java.net.InetAddressgetByName() 实例方法,而不是 getSocketAddress()

    使用 java.net.InetAddressgetAllByName() 实例方法,而不是 getSocketAddresses()

  • 删除 UnixServerAddress 方法 getSocketAddress()getUnixSocketAddress()

    使用 java.net.InetAddressgetByName() 实例方法,而不是 getSocketAddress()

    构造一个 jnr.unixsocket.UnixSocketAddress实例,而不是 getUnixSocketAddress()。将 UNIX 套接字文件的完整路径传递给构造函数。默认下, MongoDB会创建位于 "/tmp/mongodb-27017.sock" 的 UNIX 套接字文件。要学习;了解有关 UnixSocketAddress 类的更多信息,请参阅 UnixSocketAddress API文档。

  • 删除Parameterizable接口。 如果编解码器适用于参数化类型,请重写编解码器的CodecProvider上的CodecProvider.get()方法,而不是在自定义Codec类型上实现此接口。

  • ReadPreferenceTaggableReadPreference类中删除isSlaveOk()方法。 要检查读取偏好是否允许从副本集的从节点读取,请改用这些类中的isSecondaryOk()方法。

  • 移除 collStats 命令的 DBCollection.getStats()DBCollection.isCapped() 辅助方法。您可以使用 $collStats 聚合管道阶段来代替这些方法。

  • 删除MapCodecIterableCodec类。 MapCodec使用MapCodecProvider ,而不是 。对于不是IterableCodec Collection类型的Iterable类型,请使用CollectionCodecProviderIterableCodecProvider ,而不是 。

  • MapReducePublisherMapReduceIterable类中删除sharded()nonAtomic()方法。

  • 删除了以下与geoHaystack索引一起使用的方法:

    • Indexes.geoHaystack()

    • IndexOptions.getBucketSize()

    • IndexOptions.bucketSize()

    相反,您可以在 2d 索引上使用 $geoNear 聚合管道阶段或地理空间查询操作符。有关更多信息,请参阅 MongoDB Server 手册中的“地理空间查询”页面

  • 从查找操作中删除 oplogReplay 选项。 以下 oplogReplay 方法不再可用:

    • DBCursor.oplogReplay()

    • DBCollectionFindOptions.isOplogReplay()

    • DBCollectionFindOptions.oplogReplay()

    • FindPublisher.oplogReplay()

    • FindIterable.oplogReplay()

  • 删除以下Exception构造函数:

    • MongoBulkWriteException(BulkWriteResult, List<BulkWriteError>, WriteConcernError, ServerAddress)

    • MongoCursorNotFoundException(long, ServerAddress)

    • MongoQueryException(ServerAddress, int, String)

    • MongoQueryException(ServerAddress, int, String, String)

    • MongoQueryException(MongoCommandException)

  • 删除BulkWriteResult.acknowledged()方法的以下重载:

    • acknowledged(Type, int, List<BulkWriteUpsert>)

    • acknowledged(Type, int, Integer, List<BulkWriteUpsert>)

    • acknowledged(int, int, int, Integer, List<BulkWriteUpsert>)

  • 删除以下ChangeStreamDocument构造函数:

    • ChangeStreamDocument(String, BsonDocument, BsonDocument, BsonDocument, TDocument, TDocument, BsonDocument, ...)

    • ChangeStreamDocument(String, BsonDocument, BsonDocument, BsonDocument, TDocument, BsonDocument, BsonTimestamp, ...)

    • ChangeStreamDocument(OperationType, BsonDocument, BsonDocument, BsonDocument, TDocument, BsonDocument, BsonTimestamp, ...)

  • 删除事件的以下构造函数:

    • CommandEvent(RequestContext, int, ConnectionDescription, String)

    • CommandEvent(int, ConnectionDescription, String)

    • CommandEvent(RequestContext, long, int, ConnectionDescription, String)

    • CommandFailedEvent(RequestContext, int, ConnectionDescription, String, long, Throwable)

    • CommandFailedEvent(int, ConnectionDescription, String, long, Throwable)

    • CommandStartedEvent(RequestContext, int, ConnectionDescription, String, String, BsonDocument)

    • CommandStartedEvent(int, ConnectionDescription, String, String, BsonDocument)

    • CommandSucceededEvent(RequestContext, int, ConnectionDescription, String, BsonDocument, long)

    • CommandSucceededEvent(int, ConnectionDescription, String, BsonDocument, long)

    • ConnectionCheckedInEvent(ConnectionId)

    • ConnectionCheckedOutEvent(ConnectionId, long)

    • ConnectionCheckedOutEvent(ConnectionId)

    • ConnectionCheckOutFailedEvent(ServerId, long, Reason)

    • ConnectionCheckOutFailedEvent(ServerId, Reason)

    • ConnectionCheckOutStartedEvent(ServerId)

    • ConnectionReadyEvent(ConnectionId)

    • ServerHeartbeatFailedEvent(ConnectionId, long, Throwable)

    • ServerHeartbeatSucceededEvent(ConnectionId, BsonDocument, long)

  • WriteConcernError类中删除errorLabels选项。 其中包括addLabel()getErrorLabels()方法以及包含errorLabels参数的构造函数。 相反,您可以使用包含WriteConcernErrorMongoException对象中包含的错误标签。

  • com.mongodb.event包中删除以下类:

    • ConnectionAddedEvent

    • ConnectionPoolOpenedEvent

    • ConnectionRemovedEvent

    • ClusterListenerAdapter

    • ConnectionPoolListenerAdapter

    • ServerListenerAdapter

    • ServerMonitorListenerAdapter

    该驱动程序还会从 ConnectionPoolListener 接口中删除以下相关方法:

    • connectionAdded()

    • connectionPoolOpened()

    • connectionRemoved()

    有关 com.mongodb.event包的更多信息,请参阅API文档。

  • listCollections 命令添加 authorizedCollection 选项。 这在 MongoDatabase.listCollectionNames() 方法中引入了重大二进制更改。 此更改不需要对源代码进行任何更改,但您必须重新编译使用此方法的任何代码。

  • 删除与接口相关的以下方法和类型:

    • MongoClientSettings.Builder.streamFactoryFactory() 方法。 请改用 MongoClientSettings.Builder.transportSettings() 方法。

    • MongoClientSettings.getStreamFactoryFactory() 方法。 请改用 MongoClientSettings.getTransportSettings() 方法。

    • NettyStreamFactoryFactory 类。 而是调用 TransportSettings.nettyBuilder() 方法来创建 NettyTransportSettings对象。 然后,调用 MongoClientSettings.Builder.transportSettings() 方法以应用设置。

    • NettyStreamFactory 类。

    • AsynchronousSocketChannelStreamFactory 类。

    • AsynchronousSocketChannelStreamFactoryFactory 类。

    • BufferProvider 接口。

    • SocketStreamFactory 类。

    • Stream 接口。

    • StreamFactory 接口。

    • StreamFactoryFactory 接口。

    • TlsChannelStreamFactoryFactory 类。

提示

要查看早期驱动程序版本的破坏性变更,请参阅 mongo-java-driverGitHub 存储库中的发布说明。

服务器发布兼容性更改是对Kotlin同步驱动程序的修改,停止支持一设立MongoDB Server版本。

该驱动程序在 MongoDB Server 版本的生命周期结束 (EOL) 后将停止支持。

要了解有关 MongoDB 支持 EOL 产品的更多信息,请参阅旧版支持政策

您无法使用 3.x 版本的Kotlin 同步驱动程序连接到运行MongoDB Server v8.1 或更高版本的MongoDB 部署。从MongoDB Server v8.1 开始,buildinfo 命令需要身份验证,从而导致与 v3.x驱动程序。

v5.5驱动程序删除对MongoDB Server 4.0的支持。要使用 v5.5驱动程序,您必须连接到MongoDB Server 4.2 或更高版本。要学习;了解如何升级MongoDB Server部署,请参阅MongoDB Server手册中的发布说明

v5.2驱动程序删除对MongoDB Server 3.6的支持。要使用 v5.2驱动程序,您必须连接到MongoDB Server 4.0 或更高版本。要学习;了解如何升级MongoDB Server部署,请参阅MongoDB Server手册中的发布说明

v4.8驱动程序删除对MongoDB Server 3.4 及更早版本的支持。要使用 v4.8驱动程序,您必须连接到MongoDB Server 3.6 或更高版本。要学习;了解如何升级MongoDB Server部署,请参阅MongoDB Server手册中的发布说明

后退

版本说明

在此页面上