- Administer Ops Manager >
- Manage Snapshot Storage >
- Manage S3 Oplog Storage
Manage S3 Oplog Storage¶
On this page
Throughout the lifecycle of a backup, MongoDB Agent with Backup enabled tails the oplog of each replica set and sends new oplog entries to Ops Manager. The Agent sends the oplog entries in compressed bundles of approximately 10 MB in size called oplog slices. These oplog slices are stored in one or more MongoDB databases called oplog stores. Every Ops Manager deployment needs at least one oplog store.
When you enable backups, Ops Manager prompts you to create your first oplog store. This can be a local oplog store or an S3 oplog store. Once you create the first oplog store, you manage it separately from your snapshot stores. You can create additional oplog stores.
This tutorial covers creating additional S3 oplog stores to store oplog entries. Like any MongoDB instance, an S3 oplog store can exist on any host running MongoDB and S3 bucket (without subfolders) that the Ops Manager application can access.
Considerations¶
Requires a Dedicated Bucket¶
Ops Manager must be the only manager on the S3 bucket that you use for snapshots. You also need to configure the S3 bucket to avoid using features that Ops Manager does not support.
When configuring the S3 bucket:
- Do not create subfolders in the S3 buckets that you use with Ops Manager. Ops Manager only supports using entire S3 buckets.
- Disable AWS S3 bucket versioning. Versioning is not supported in Ops Manager for the S3 buckets used for snapshots.
- Do not create AWS S3 lifecycle rules. Lifecycle rules that expire or transition current versions of Ops Manager snapshot objects to archives results in incomplete snapshots that you can’t use to restore the configuration.
Can’t Move the S3 Oplog Store¶
After you create an S3 oplog store, you cannot move it to another S3 bucket. If you need to use a different S3 bucket to host your S3 oplog store, you must create a new S3 oplog store in the same S3 bucket. The S3 snapshot bucket must be different than the oplog S3 bucket.
Supports the Storage API¶
MongoDB supports endpoints for:
- AWS S3 API
- IBM Cloud Object Storage API
- Dell EMC Elastic Cloud Storage API.
IBM and Dell EMC support a subset of the full AWS S3 API.
You can use other S3-compatible endpoints. Ops Manager attempts to validate these endpoints when you save the S3 oplog store setup. If validation passes, Ops Manager saves the configuration. If validation fails, Ops Manager displays an error and doesn’t save the configuration.
Prerequisites¶
Metadata Storage Prerequisites¶
- Deploy the dedicated MongoDB instance(s) to serve the S3 oplog store metadata and Oplog Store. Serve these instances on the same hosts as the Ops Manager host, the backing databases, or snapshot stores. Attach one or more storage volumes with enough capacity to store the databases these instances manage.
- Secure the instance that stores your S3 oplog store metadata database
using authentication and
TLS. S3 oplog store metadata databases
support
all authentication mechanisms
.
AWS S3 Storage Prerequisites¶
Make sure you have an IAM user on AWS.
Create your own AWS access keys for your IAM user. This allows you to create S3 buckets and store oplog files in them. MongoDB does not create or issue AWS access keys.
Create your own S3 bucket to store your S3 oplog stores.
Note
The IAM user for which you created the AWS access keys must own the AWS S3 bucket.
IBM Cloud Object Storage Prerequisites¶
- Create an Access Key and Secret Key using IBM credential tools.
- Create your own S3-compatible bucket.
Dell EMC Elastic Cloud Storage Prerequisites¶
- Create an Access Key and Secret Key from your ECS User ID.
- Create your own S3-compatible bucket.
Other S3-Compatible Storage¶
Other S3-compatible endpoints can be used. Ops Manager attempts to validate these endpoints when you save the configuration. If validation passes, the configuration, Ops Manager saves it. If validation fails, Ops Manager displays an error and doesn’t save the configuration.
Procedures¶
The format of the Username and Password depend upon the authentication mechanism. Select one of the following tabs:
- Username and Password
- X.509
- Kerberos
- LDAP
Add One S3 Oplog Store¶
Click Create New S3 Oplog Store.¶
Provide the S3 Oplog Store Details.¶
Field | Necessity | Contents | |||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Name | Required | Enter the label for the S3 oplog store. | |||||||||
S3 Bucket Name | Required | Enter the name of the S3 bucket where you want to host the the S3 oplog store. | |||||||||
Region Override | Conditional | Type the region where your S3 bucket resides. Use this field only if your S3-compatible store’s S3 Endpoint doesn’t support region scoping. Don’t provide a value for this field with AWS S3 buckets. |
|||||||||
S3 Endpoint | Required | Enter the URL for this AWS S3 or S3-compatible bucket. What URL you write depends upon:
Example You created an S3 bucket called
|
|||||||||
S3 Max Connections | Required | Enter a positive integer indicating the maximum number of connections to this AWS S3 or S3-compatible bucket. | |||||||||
Path Style Access | Optional | Select if you want your AWS S3 or S3-compatible bucket
to use a path-style URL endpoint
( To review the S3 bucket URL conventions, see the AWS S3 documentation |
|||||||||
Server Side Encryption | Optional | Select to enable server-side encryption. Clear to disable server-side encryption. | |||||||||
S3 Authorization Mode | Required | Select the method used to authorize access to the S3 bucket specified in S3 Bucket Name.
|
|||||||||
Keys with Custom CA Bundle | Conditional | Click Choose file to add a custom Certificate Authority chain. This chain can validate against a self-signed certificate on the S3 bucket. Ops Manager displays this field when you set S3 Authorization Mode to Keys. |
|||||||||
AWS Access Key | Conditional | Enter your AWS Access Key ID. Ops Manager displays this field when you set S3 Authorization Mode to Keys. |
|||||||||
AWS Secret Key | Conditional | Enter your AWS Secret Access Key. Ops Manager displays this field when you set S3 Authorization Mode to Keys. |
|||||||||
Datastore Type | Required | Select Standalone, Replica Set or Sharded Cluster. This MongoDB database stores the metadata for the blockstore. | |||||||||
MongoDB Host List | Conditional | Enter a comma-separated list of Example
Ops Manager displays this field when you set Datastore Type to Replica Set or Sharded Cluster. Important Ops Manager uses this metadata store as a sync store. Make sure to provision this store with sufficient storage space. |
|||||||||
MongoDB Hostname | Conditional | Enter the hostname of the S3 oplog store metadata database. Ops Manager displays this field when you set Datastore Type to Standalone. Important Ops Manager uses this metadata store as a sync store. Make sure to provision this store with sufficient storage space. |
|||||||||
MongoDB Port | Conditional | Enter the port number of the S3 oplog store metadata database. Ops Manager displays this field when you set Datastore Type to Standalone. |
|||||||||
Username | Optional | If you set this value: Type the name of the user authorized to access the this database. Note If your Ops Manager Application Database uses authentication or TLS, you must have connections configured to the application database. To learn more, see Configure the Connections to the Application Database. To learn more about configuring SCRAM authentication, see SCRAM. Type the RFC 2253-formatted subject from the client certificate of the user authorized to access this database. Note If your Ops Manager Application Database uses authentication or TLS, you must have connections configured to the application database. To learn more, see Configure the Connections to the Application Database. To learn more about configuring x.509 authentication, see x.509. Type the UPN of the user authorized to access this database. Note If your Ops Manager Application Database uses authentication or TLS, you must have connections configured to the application database. To learn more, see Configure the Connections to the Application Database. To learn more about configuring Kerberos authentication, see Kerberos. Type the name of the LDAP user authorized to access this database. Note If your Ops Manager Application Database uses authentication or TLS, you must have connections configured to the application database. To learn more, see Configure the Connections to the Application Database. To learn more about configuring LDAP authentication, see LDAP. |
|||||||||
Password | Optional | If you set this value: Warning If you did not use the credentialstool to encrypt this password, it is stored as plaintext in the database. Type the password associated with the username that can access this database. Note If your Ops Manager Application Database uses authentication or TLS, you must have connections configured to the application database. To learn more, see Configure the Connections to the Application Database. To learn more about configuring SCRAM authentication, see SCRAM. Leave it blank. Note If your Ops Manager Application Database uses authentication or TLS, you must have connections configured to the application database. To learn more, see Configure the Connections to the Application Database. To learn more about configuring x.509 authentication, see x.509. Kerberos retrieves the password from its keytab file. Don’t type a password into this field. Note If your Ops Manager Application Database uses authentication or TLS, you must have connections configured to the application database. To learn more, see Configure the Connections to the Application Database. To learn more about configuring Kerberos authentication, see Kerberos. Type the password of the LDAP user authorized to access this database. Note If your Ops Manager Application Database uses authentication or TLS, you must have connections configured to the application database. To learn more, see Configure the Connections to the Application Database. To learn more about configuring LDAP authentication, see LDAP. |
|||||||||
Connection Options | Optional | Enter any additional configuration file options for the MongoDB instance. This field supports unescaped values only. For proper syntax, see Connection String URI Format in the MongoDB manual. |
|||||||||
Encrypted Credentials | Optional | Select if the credentials for the database were encrypted using the credentialstool. The credentials include the Username, Password, AWS Access Key ID and AWS Secret Key. | |||||||||
Use TLS/SSL | Optional | Select if the S3 oplog store metadata database only accepts connection encrypted using TLS. Beyond this checkbox, to connect this S3 oplog store using TLS, you must enable TLS on the S3 oplog store database. |
|||||||||
New Assignment Enabled | Optional | Select if you want to enable this S3 oplog store after creating it. This is selected by default so the S3 oplog store can be assigned backup jobs. If you clear this checkbox, the S3 oplog store is created but you cannot assign backups to this S3 oplog store. |
Click Create.¶
Edit One Existing S3 Oplog Store¶
Ops Manager lists oplog stores in a table on the Oplog Storage page. Each row contains the settings for each local and S3 oplog store.
Navigate to the Oplog Storage page.¶
- Click the Admin link.
- Click the Backup tab.
- (Optional) If you have not previously set the head directory, set it in the Head Directory box.
- Click the Oplog Storage page.
Go to the row for the S3 oplog store you want to edit.¶
Update any values that need to be changed.¶
In the MongoDB Connection column, update any values that need to be changed in the following fields:
Field | Necessity | Contents | ||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
S3 Bucket Name | Required | Enter the name of the S3 bucket where you want to host the the S3 oplog store. | ||||||||||||||||
Region Override | Conditional | Type the region where your S3 bucket resides. Use this field only if your S3-compatible store’s S3 Endpoint doesn’t support region scoping. Don’t provide a value for this field with AWS S3 buckets. |
||||||||||||||||
S3 Endpoint | Required | Enter the URL for this AWS S3 or S3-compatible bucket. What URL you write depends upon:
Example You created an S3 bucket called
|
||||||||||||||||
S3 Max Connections | Required | Enter a positive integer indicating the maximum number of connections to this AWS S3 or S3-compatible bucket. | ||||||||||||||||
Path Style Access | Optional | Click if you want your AWS S3 or S3-compatible bucket
to use a path-style URL endpoint
( To review the S3 bucket URL conventions, see the AWS S3 documentation |
||||||||||||||||
Server Side Encryption | Optional | Click to enable server-side encryption. Clear to disable server-side encryption. | ||||||||||||||||
S3 Authorization Mode | Required | Select the method used to authorize access to the S3 bucket specified in S3 Bucket Name.
|
||||||||||||||||
Keys with Custom CA Bundle | Conditional | Click Choose file to add a custom Certificate Authority chain. This chain can validate against a self-signed certificate on the S3 bucket. Ops Manager displays this field when you set S3 Authorization Mode to Keys. |
||||||||||||||||
AWS Access Key | Conditional | Enter your AWS Access Key ID. Ops Manager displays this field when you set S3 Authorization Mode to Keys. |
||||||||||||||||
AWS Secret Key | Conditional | Enter your AWS Secret Access Key. Ops Manager displays this field when you set S3 Authorization Mode to Keys. Note Ops Manager doesn’t display the existing Secret Access Key. |
||||||||||||||||
<hostname>:<port> | Required | Enter in one or more hosts that comprise the S3 Snapshot
Store metadata database in the S3 Oplog Hosting Concerns
|
||||||||||||||||
MongoDB Auth Username | Optional | If you set this value: Type the name of the user authorized to access the this database. Note If your Ops Manager Application Database uses authentication or TLS, you must have connections configured to the application database. To learn more, see Configure the Connections to the Application Database. To learn more about configuring SCRAM authentication, see SCRAM. Type the RFC 2253-formatted subject from the client certificate of the user authorized to access this database. Note If your Ops Manager Application Database uses authentication or TLS, you must have connections configured to the application database. To learn more, see Configure the Connections to the Application Database. To learn more about configuring x.509 authentication, see x.509. Type the UPN of the user authorized to access this database. Note If your Ops Manager Application Database uses authentication or TLS, you must have connections configured to the application database. To learn more, see Configure the Connections to the Application Database. To learn more about configuring Kerberos authentication, see Kerberos. Type the name of the LDAP user authorized to access this database. Note If your Ops Manager Application Database uses authentication or TLS, you must have connections configured to the application database. To learn more, see Configure the Connections to the Application Database. To learn more about configuring LDAP authentication, see LDAP. |
||||||||||||||||
MongoDB Auth Password | Optional | If you set this value: Type the password associated with the username that can access this database. Note If your Ops Manager Application Database uses authentication or TLS, you must have connections configured to the application database. To learn more, see Configure the Connections to the Application Database. To learn more about configuring SCRAM authentication, see SCRAM. Leave it blank. Note If your Ops Manager Application Database uses authentication or TLS, you must have connections configured to the application database. To learn more, see Configure the Connections to the Application Database. To learn more about configuring x.509 authentication, see x.509. Kerberos retrieves the password from its keytab file. Don’t type a password into this field. Note If your Ops Manager Application Database uses authentication or TLS, you must have connections configured to the application database. To learn more, see Configure the Connections to the Application Database. To learn more about configuring Kerberos authentication, see Kerberos. Type the password of the LDAP user authorized to access this database. Note If your Ops Manager Application Database uses authentication or TLS, you must have connections configured to the application database. To learn more, see Configure the Connections to the Application Database. To learn more about configuring LDAP authentication, see LDAP. Warning If you did not use the credentialstool to encrypt this password, it is stored as plaintext in the database. Note Ops Manager doesn’t display the existing MongoDB Auth Password. |
||||||||||||||||
Encrypted Credentials | Optional | Select if the credentials for the database were encrypted using the credentialstool. The credentials include the Username, Password, AWS Access Key ID and AWS Secret Key. | ||||||||||||||||
Use TLS/SSL | Optional | Select if the S3 oplog store database only accepts connection encrypted using TLS. Beyond this checkbox, to connect this S3 oplog store using TLS, you must enable TLS on the S3 oplog store database. |
||||||||||||||||
Connection Options | Optional | Enter any additional configuration file options for the MongoDB instance. This field supports unescaped values only. To review the proper syntax, see Connection String URI Format in the MongoDB manual. |
||||||||||||||||
Assignment Labels | Optional | Enter a comma-separated list of labels to assign the S3 oplog stores to specific projects. | ||||||||||||||||
Write Concern | Required | Select your preferred Write Concern:
|
Optional: Set the S3 Oplog Store to Accept Backup Jobs.¶
To enable this S3 oplog store, select Assignment Enabled.
This is selected by default so the S3 oplog store can be assigned backup jobs. If you clear this checkbox, Ops Manager creates the S3 oplog store but you cannot assign backups to it.
Click Save.¶
Optional: Restart Ops Manager Instances If Needed.¶
If you change any connection string values or the Write Concern, restart all the Ops Manager instances including those running Backup Daemons.
Warning
Modifying the connection string values or the Write Concern for an existing S3 oplog store requires you to restart all Ops Manager components, including those only running the Backup Daemon to apply those changes. Connection parameters include:
- <hostname>:<port>
- MongoDB Auth Username
- MongoDB Auth Password
- Encrypted Credentials
- Use TLS/SSL
- Connection Options
- Write Concern
If you change to another S3 oplog store host, Ops Manager doesn’t copy the data on the existing S3 oplog store to the other S3 oplog store.
See also
To learn more about the MongoDB connection string URI, see Connection String URI Format in the MongoDB Manual.
Delete One S3 Oplog Store¶
Navigate to the Oplog Storage page.¶
- Click the Admin link.
- Click the Backup tab.
- (Optional) If you have not previously set the head directory, set it in the Head Directory box.
- Click the Oplog Storage page.
Click the Delete link.¶
Click Delete <oplogstore> beneath the name of the S3 oplog store you want to delete.