Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

DOCSP-37046: csot in v2 #375

Merged
merged 7 commits into from
Aug 12, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 3 additions & 1 deletion source/fundamentals/connections.txt
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ Connections
.. toctree::

/fundamentals/connections/connection-guide
/fundamentals/connections/connection-options
/fundamentals/connections/network-compression
/fundamentals/connections/tls
Connect to MongoDB Atlas from AWS Lambda <https://www.mongodb.com/docs/atlas/manage-connections-aws-lambda/>
Expand All @@ -24,11 +25,12 @@ Learn how to use the {+driver-short+} to configure your application's
connection to a MongoDB deployment in the following sections:

- :ref:`golang-connection-guide`
- :ref:`golang-connection-options`
- :ref:`golang-network-compression`
- :ref:`golang-tls`
- :atlas:`Connect to MongoDB Atlas from AWS Lambda </manage-connections-aws-lambda/>`

To learn how to authenticate to MongoDB, see the following pages:

- :ref:`golang-authentication-mechanisms`
- :ref:`golang-enterprise-authentication-mechanisms`
- :ref:`golang-enterprise-authentication-mechanisms`
Binary file removed source/fundamentals/connections/.tls.txt.swp
Binary file not shown.
177 changes: 10 additions & 167 deletions source/fundamentals/connections/connection-guide.txt
Original file line number Diff line number Diff line change
Expand Up @@ -68,7 +68,7 @@ your MongoDB instance.
The last part of the connection string specifies connection and authentication
options. In the example, we set two connection options:
``maxPoolSize=20`` and ``w=majority``. To learn more about connection
options, read the :ref:`golang-connection-options` section of this guide.
options, see the :ref:`golang-connection-options` guide.

Connection Example
~~~~~~~~~~~~~~~~~~
Expand Down Expand Up @@ -172,169 +172,12 @@ When connecting to a replica set, the driver takes the following actions by defa
Direct Connection
`````````````````

To force operations on the host designated in the connection URI, specify the ``directConnection`` option. Direct
connections:

- Don't support SRV strings.
- Fail on writes when the specified host is not the **primary**.
- Require you to :manual:`specify a secondary read preference </core/read-preference/#mongodb-readmode-secondary>`
when the specified host isn't the **primary**.

.. _golang-connection-options:

------------------
Connection Options
------------------

This section explains several common MongoDB connection and authentication
options. You can pass the connection options as parameters of the connection
URI to specify the behavior of the client.

.. list-table::
:header-rows: 1
:widths: 34 10 12 44

* - Option Name
- Type
- Default Value
- Description

* - **timeoutMS**
- integer
- ``null``
- Specifies the number of milliseconds that a single operation run on the
``Client`` can take before returning a timeout error. Operations honor
this setting only if there is no deadline on the operation Context.

* - **connectTimeoutMS**
- integer
- ``30000``
- Specifies the number of milliseconds to wait before timeout on a TCP
connection.

* - **maxPoolSize**
- integer
- ``100``
- Specifies the maximum number of connections that a connection pool may
have at a given time.

* - **replicaSet**
- string
- ``null``
- Specifies the replica set name for the cluster. All nodes in the
replica set must have the same replica set name, or the Client will not
consider them as part of the set.

* - **maxIdleTimeMS**
- integer
- ``0``
- Specifies the maximum amount of time a connection can remain idle
in the connection pool before being removed and closed. The
default is ``0``, meaning a connection can remain unused
indefinitely.

* - **minPoolSize**
- integer
- ``0``
- Specifies the minimum number of connections that the driver maintains
in a single connection pool.

* - **socketTimeoutMS**
- integer
- ``0``
- Specifies the number of milliseconds to wait for a socket read or
write to return before returning a network error. The ``0``
default value indicates that there is no timeout.

* - **serverSelectionTimeoutMS**
- integer
- ``30000``
- Specifies the number of milliseconds to wait to find an available,
suitable server to execute an operation.

* - **heartbeatFrequencyMS**
- integer
- ``10000``
- Specifies the number of milliseconds to wait between periodic
background server checks.

* - **tls**
- boolean
- ``false``
- Specifies whether to establish a Transport Layer Security (TLS)
connection with the instance. This is automatically set to ``true``
when using a DNS seedlist (SRV) in the connection string. You can
override this behavior by setting the value to ``false``.

* - **w**
- string or integer
- ``null``
- Specifies the write concern. To learn more about values, see the
server documentation on
:manual:`Write Concern options </reference/write-concern>`.

* - **directConnection**
- boolean
- ``false``
- Specifies whether to force dispatch **all** operations to the host
specified in the connection URI.

For a full list of connection options, see the `ClientOptions API
documentation
<{+api+}/mongo/options#ClientOptions>`__.

.. _golang-timeout-setting:

Single Timeout Setting
~~~~~~~~~~~~~~~~~~~~~~

You can set a single ``Timeout`` option on your ``Client`` to govern the
amount of time that a single operation can take to execute using the
``SetTimeout()`` method or specifying the ``timeoutMS`` option in your
connection URI string. ``Database``, ``Collection``,
``Session``, ``ChangeStream``, and ``Bucket`` instances elsewhere in
your code inherit the ``Timeout`` option from ``Client`` if you do not set a
Context for operations against the same entity.

If you pass a Context into an operation with a deadline, the driver uses
that Context deadline for the operation. If the context does not have a
deadline, the driver derives a new Context from the given Context using
the ``Timeout`` option set on the ``Client``.

.. note:: Retries under Timeout Specification

With default settings, if you set a ``Timeout`` option on your ``Client``
and your operation requires a retry, the driver retries the operation
as many times as possible before the timeout expires. Once the timeout
expires, the driver returns a timeout error. Versions 1.1 and later
of the {+driver-short+} enable retryable reads and writes by default.
See the Server manual for more information about :ref:`retryable
reads <retryable-reads>` and :manual:`retryable writes </core/retryable-writes/>`.

The following code shows how to set the ``Timeout`` option on a ``Client``
with the ``SetTimeout`` option:

.. code-block:: go

opts := options.Client().SetTimeout(5 * time.Second)

The following example shows how you can set a single timeout with the
URI option and execute an operation that inherits this setting:

.. code-block:: go

uri := "mongodb://user:[email protected]:27017/?timeoutMS=5000"

client, err := mongo.Connect(options.Client().ApplyURI(uri))
coll := client.Database("<db>").Collection("<collection>")

...
coll.InsertOne(context.Background(), doc)

.. important:: Legacy Timeout Options

``SocketTimeout``, ``wTimeout``, ``MaxTime``, and ``MaxCommitTime``
will be deprecated in an upcoming release. The driver ignores ``MaxTime`` and
``MaxCommitTime`` if you set ``Timeout``. The driver still honors
``SocketTimeout`` and ``wTimeout``, but these settings may result in
undefined behavior. Consider using only the single timeout option instead.
To force operations on the host designated in the connection URI,
specify the ``directConnection`` option. Direct connections exhibit the
following behavior:

- They don't support SRV strings.
- They fail on writes when the specified host is not the **primary**.
- They require you to specify a :manual:`secondary read preference
</core/read-preference/#mongodb-readmode-secondary>` when the
specified host isn't the **primary** node.
Loading
Loading