Class MongoClientSettings.Builder
- Enclosing class:
- MongoClientSettings
MongoClientSettings so that MongoClientSettings can be immutable, and to support easier construction
 through chaining.- 
Method SummaryModifier and TypeMethodDescriptionaddCommandListener(CommandListener commandListener) Adds the given command listener.applicationName(String applicationName) Sets the logical name of the application using this MongoClient.applyConnectionString(ConnectionString connectionString) Takes the settings from the givenConnectionStringand applies them to the builderApplies theClusterSettings.Builderblock and then sets the clusterSettings.Applies theConnectionPoolSettings.Builderblock and then sets the connectionPoolSettings.Applies theLoggerSettings.Builderblock and then sets the loggerSettings.Applies theServerSettings.Builderblock and then sets the serverSettings.Applies theSocketSettings.Builderblock and then sets the socketSettings.Applies theSslSettings.Builderblock and then sets the sslSettings.autoEncryptionSettings(AutoEncryptionSettings autoEncryptionSettings) Sets the auto-encryption settingsbuild()Build an instance ofMongoClientSettings.codecRegistry(CodecRegistry codecRegistry) Sets the codec registrycommandListenerList(List<CommandListener> commandListeners) Sets the command listenerscompressorList(List<MongoCompressor> compressorList) Sets the compressors to use for compressing messages to the server.contextProvider(ContextProvider contextProvider) Sets the context providercredential(MongoCredential credential) Sets the credential.Sets theDnsClientto use for resolving DNS queries.inetAddressResolver(InetAddressResolver inetAddressResolver) Sets theInetAddressResolverto use for looking up theInetAddressinstances for each host.readConcern(ReadConcern readConcern) Sets the read concern.readPreference(ReadPreference readPreference) Sets the read preference.retryReads(boolean retryReads) Sets whether reads should be retried if they fail due to a network error.retryWrites(boolean retryWrites) Sets whether writes should be retried if they fail due to a network error.Sets the server API to use when sending commands to the server.transportSettings(TransportSettings transportSettings) Sets theTransportSettingsto apply.uuidRepresentation(UuidRepresentation uuidRepresentation) Sets the UUID representation to use when encoding instances ofUUIDand when decoding BSON binary values with subtype of 3.writeConcern(WriteConcern writeConcern) Sets the write concern.
- 
Method Details- 
applyConnectionStringTakes the settings from the givenConnectionStringand applies them to the builder- Parameters:
- connectionString- the connection string containing details of how to connect to MongoDB
- Returns:
- this
 
- 
applyToLoggerSettingsApplies theLoggerSettings.Builderblock and then sets the loggerSettings.- Parameters:
- block- the block to apply to the LoggerSettings.
- Returns:
- this
- Since:
- 4.9
- See Also:
 
- 
applyToClusterSettingsApplies theClusterSettings.Builderblock and then sets the clusterSettings.- Parameters:
- block- the block to apply to the ClusterSettings.
- Returns:
- this
- See Also:
 
- 
applyToSocketSettingsApplies theSocketSettings.Builderblock and then sets the socketSettings.- Parameters:
- block- the block to apply to the SocketSettings.
- Returns:
- this
- See Also:
 
- 
applyToConnectionPoolSettingspublic MongoClientSettings.Builder applyToConnectionPoolSettings(Block<ConnectionPoolSettings.Builder> block) Applies theConnectionPoolSettings.Builderblock and then sets the connectionPoolSettings.- Parameters:
- block- the block to apply to the ConnectionPoolSettings.
- Returns:
- this
- See Also:
 
- 
applyToServerSettingsApplies theServerSettings.Builderblock and then sets the serverSettings.- Parameters:
- block- the block to apply to the ServerSettings.
- Returns:
- this
- See Also:
 
- 
applyToSslSettingsApplies theSslSettings.Builderblock and then sets the sslSettings.- Parameters:
- block- the block to apply to the SslSettings.
- Returns:
- this
- See Also:
 
- 
readPreferenceSets the read preference.- Parameters:
- readPreference- read preference
- Returns:
- this
- See Also:
 
- 
writeConcernSets the write concern.- Parameters:
- writeConcern- the write concern
- Returns:
- this
- See Also:
 
- 
retryWritesSets whether writes should be retried if they fail due to a network error.Starting with the 3.11.0 release, the default value is true - Parameters:
- retryWrites- sets if writes should be retried if they fail due to a network error.
- Returns:
- this
- See Also:
- Since server release
- 3.6
 
- 
retryReadsSets whether reads should be retried if they fail due to a network error.- Parameters:
- retryReads- sets if reads should be retried if they fail due to a network error.
- Returns:
- this
- Since:
- 3.11
- See Also:
- Since server release
- 3.6
 
- 
readConcernSets the read concern.- Parameters:
- readConcern- the read concern
- Returns:
- this
- MongoDB documentation
- Read Concern
- Since server release
- 3.2
 
- 
credentialSets the credential.- Parameters:
- credential- the credential
- Returns:
- this
 
- 
codecRegistrySets the codec registryThe CodecRegistryconfigured by this method is effectively treated by the driver as an instance ofCodecProvider, whichCodecRegistryextends. So there is no benefit to defining a class that implementsCodecRegistry. Rather, an application should always createCodecRegistryinstances using the factory methods inCodecRegistries.- Parameters:
- codecRegistry- the codec registry
- Returns:
- this
- See Also:
 
- 
transportSettingsSets theTransportSettingsto apply.- Parameters:
- transportSettings- the transport settings
- Returns:
- this
- See Also:
 
- 
addCommandListenerAdds the given command listener.- Parameters:
- commandListener- the command listener
- Returns:
- this
 
- 
commandListenerListSets the command listeners- Parameters:
- commandListeners- the list of command listeners
- Returns:
- this
 
- 
applicationNameSets the logical name of the application using this MongoClient. The application name may be used by the client to identify the application to the server, for use in server logs, slow query logs, and profile collection.- Parameters:
- applicationName- the logical name of the application using this MongoClient. It may be null. The UTF-8 encoding may not exceed 128 bytes.
- Returns:
- this
- See Also:
- Since server release
- 3.4
 
- 
compressorListSets the compressors to use for compressing messages to the server. The driver will use the first compressor in the list that the server is configured to support.- Parameters:
- compressorList- the list of compressors to request
- Returns:
- this
- See Also:
- Since server release
- 3.4
 
- 
uuidRepresentationSets the UUID representation to use when encoding instances ofUUIDand when decoding BSON binary values with subtype of 3.See MongoClientSettings.getUuidRepresentation()for recommendations on settings this value- Parameters:
- uuidRepresentation- the UUID representation, which may not be null
- Returns:
- this
- Since:
- 3.12
 
- 
serverApiSets the server API to use when sending commands to the server.This is required for some MongoDB deployments. - Parameters:
- serverApi- the server API, which may not be null
- Returns:
- this
- Since:
- 4.3
 
- 
autoEncryptionSettingspublic MongoClientSettings.Builder autoEncryptionSettings(@Nullable AutoEncryptionSettings autoEncryptionSettings) Sets the auto-encryption settingsA separate, internal MongoClientis created if any of the following are true:- AutoEncryptionSettings.keyVaultClientis not passed
- AutoEncryptionSettings.bypassAutomaticEncryptionis- false
 MongoClientis created, it is configured with the same options as the parentMongoClientexceptminPoolSizeis set to0andAutoEncryptionSettingsis omitted.- Parameters:
- autoEncryptionSettings- the auto-encryption settings
- Returns:
- this
- Since:
- 3.11
- See Also:
 
- 
contextProviderSets the context providerWhen used with the synchronous driver, this must be an instance of com.mongodb.client.SynchronousContextProvider. When used with the reactive streams driver, this must be an instance ofcom.mongodb.reactivestreams.client.ReactiveContextProvider.- Parameters:
- contextProvider- the context provider
- Returns:
- this
- Since:
- 4.4
 
- 
dnsClientSets theDnsClientto use for resolving DNS queries.If set, it will be used to resolve SRV and TXT records for mongodb+srv connections. Otherwise, implementation of DnsClientProviderwill be discovered viaServiceLoaderand used to create an instance ofDnsClient. If no implementation is discovered, thencom.sun.jndi.dns.DnsContextFactorywill be used to resolve these records.If applying a connection string to these settings, care must be taken to also pass the same DnsClientas an argument to theConnectionStringconstructor.- Parameters:
- dnsClient- the DNS client
- Returns:
- the DNS client
- Since:
- 4.10
- See Also:
 
- 
inetAddressResolverpublic MongoClientSettings.Builder inetAddressResolver(@Nullable InetAddressResolver inetAddressResolver) Sets theInetAddressResolverto use for looking up theInetAddressinstances for each host.If set, it will be used to look up the InetAddressfor each host, viaInetAddressResolver.lookupByName(String). Otherwise, an implementation ofInetAddressResolverProviderwill be discovered viaServiceLoaderand used to create an instance ofInetAddressResolver. If no implementation is discovered,InetAddress.getAllByName(String)will be used to lookup theInetAddressinstances for a host.- Parameters:
- inetAddressResolver- the InetAddress provider
- Returns:
- the InetAddressresolver
- Since:
- 4.10
 
- 
buildBuild an instance ofMongoClientSettings.- Returns:
- the settings from this builder
 
 
-