7

Deploy a MongoDB Cluster with Docker

 8 months ago
source link: https://dev.to/mattdark/deploy-a-mongodb-cluster-with-docker-1fal
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.
neoserver,ios ssh client

Percona Backup for MongoDB in a Dev Env With Docker (3 Part Series)

Percona Backup for MongoDB (PBM) is an open-source distributed and low-impact solution for consistent backups of MongoDB sharded clusters and replica sets.

PBM doesn’t work on standalone MongoDB instances, as it requires an oplog (operations log) to guarantee backup consistency. Oplog is only available on nodes with replication enabled.

You can deploy Percona Backup for MongoDB for testing purposes on a single-node replica set. Follow this guide from the MongoDB documentation to learn how to convert a standalone to a replica set.

You can also use Docker to deploy a MongoDB cluster on your personal computer, as well as set up the storage and run PBM. Using Docker can be useful for testing PBM in a development environment before running it in production.

Through this series of blog posts, you will learn how to configure a development environment for PBM, starting with the creation of a three-node replica set, one node set as primary and two secondary nodes. Continuing with the configuration of MinIO to store the backups of your databases, and finally configuring PBM and testing it.

This series includes the following articles:

For deploying a MongoDB cluster, I've followed the instructions from this tutorial, but I will explain the general process to get a cluster with replication enabled and ready to use.

Deploy a MongoDB Cluster

MongoDB Cluster

You can deploy MongoDB clusters in a number of ways

  • Install MongoDB on your computer and deploy a replica set
  • Use Docker to run your cluster
  • Deploy a highly available cluster on Kubernetes

For the purpose of this series, we’re going to work with Docker because it’s easy and a great way to try out the backup methods without additional hardware. These are the steps for creating a MongoDB cluster with Docker:

  1. Create a Docker network.
  2. Start three instances of MongoDB.
  3. Initiate the Replica Set.

Create a Docker Network

First, create a Docker network by running the following command:

$ docker network create mongodbCluster

if the network has been created, you can get its details by running the following command:

$ docker network inspect mongodbCluster

The output of the above command looks like this

[
    {
        "Name": "mongodbCluster",
        "Id": "ebde001d9f02012f803a5914a3b450f6e6092a972ccfd513afb61399cbdca2a4",
        "Created": "2023-02-23T16:02:13.629671156Z",
        "Scope": "local",
        "Driver": "bridge",
        "EnableIPv6": false,
        "IPAM": {
            "Driver": "default",
            "Options": {},
            "Config": [
                {
                    "Subnet": "172.19.0.0/16",
                    "Gateway": "172.19.0.1"
                }
            ]
        },
        "Internal": false,
        "Attachable": false,
        "Ingress": false,
        "ConfigFrom": {
            "Network": ""
        },
        "ConfigOnly": false,
        "Containers": {},
        "Options": {},
        "Labels": {}
    }
]

Start MongoDB Instances

Create your primary node and add it to the network you created before:

$ docker run -d -p 27017:27017 --name mongo1 --network mongodbCluster mongo:6 mongod --replSet myReplicaSet --bind_ip localhost,mongo1

The parameters in the above command are:

  • -d. Running the container in detached mode
  • -p. The port in the host machine that will receive and redirect all the requests to the port in the container
  • --name. Name of the container
  • --network. Name of the network to use
  • mongo:6. Name of the base image used for creating the container

The following command will be run in the initialized container:

mongod --replSet myReplicaSet --bind_ip localhost,mongo1

Where:

  • The --replSet option is used to set a name (myReplicaSet) for your replica set
  • The --bind_ip option is used to ensure that MongoDB listens for connections from applications on configured addresses. In this case, the mongod instance binds to both the localhost and the hostname (mongo1)

Once the primary node is created, you must create the secondary nodes of your replica set:

$ docker run -d -p 27018:27017 --name mongo2 --network mongodbCluster mongo:6 mongod --replSet myReplicaSet --bind_ip localhost,mongo2
$ docker run -d -p 27019:27017 --name mongo3 --network mongodbCluster mongo:6 mongod --replSet myReplicaSet --bind_ip localhost,mongo3

Initiate the Replica Set

After your cluster is created, you must initiate the replica set. Run the rs.initiate() method in the primary node of your cluster:

$ docker exec -it mongo1 mongosh --eval "rs.initiate({
 _id: \"myReplicaSet\",
 members: [
   {_id: 0, host: \"mongo1\"},
   {_id: 1, host: \"mongo2\"},
   {_id: 2, host: \"mongo3\"}
 ]
})"

If the replica set was initiated, you will get the following output:

{ ok: 1 }

Check the status of your replica set by running:

docker exec -it mongo1 mongosh --eval "rs.status()"

Authentication

For authenticating on your MongoDB cluster, create a user with userAdminAnyDatabase and readWriteAnyDatabase roles, following the instructions here.

Log into your MongoDB server:

$ docker exec -it mongo1 mongosh

Switch to the adming database

$ use admin

And add a new user:

db.createUser(
 {
   user: "myUserAdmin",
   pwd: passwordPrompt(), // or cleartext password
   roles: [
     { role: "userAdminAnyDatabase", db: "admin" },
     { role: "readWriteAnyDatabase", db: "admin" }
   ]
 }
)

Replace myUserAdmin with your desired username. With passwordPrompt() you will be asked to write the password you want to assign, or you can write the value there instead of calling that method.

Once the user is created, you can log in from the command line:

$ mongosh --username myUserAdmin --password --host mongo1

It will ask you to type in your password. If you’re accessing from outside the cluster, you must replace mongo1 with the IP address of the primary node of your cluster.

Or you can pass a connection string:

$ mongosh “mongodb://myUserAdmin:password@localhost/mydb”

Replacing password, localhost, and mydb with your authentication details.

Conclusion

Through this blog post, you learned to set up a MongoDB cluster with replication enabled using Docker. This is the first part of a series of blog posts that will guide you through the steps for configuring Percona Backup for MongoDB in a development environment to try this tool before using it in production.


About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK