Skip to main content

MongoDB- Replication

  • Replication is the process of synchronizing data across multiple servers.
  • Provides redundancy and increases data availability with multiple copies of data of different database servers.
  • It is protects a database from the loss of a single server and recover from hardware failure and service interruptions.
  • Replication also allows you to recover from hardware failure and service interruptions. With additional copies of the data, you can dedicate one to disaster recovery, reporting, or backup.
Why we need to use Replication:
1-It is a process to keep your data safe ,
2-high availability of data,
3-disaster recovery ,
3-no down time for maintenance ,
4-read scaling and it is  a transparent to the application.

How replication works in MongoDB

A replica set is a group of MongoDB instances that host the same data set. There is two node first is primary node that receives all write operations and secondary, apply operations from the primary so that they have the same data set. Replica set can have only one primary node.
1. Replica set is the group of nodes generally minimum three nodes are required, one node is primary node and remaining nodes are secondary.
2. At the time of automatic failover or maintenance, election establishes for primary and a new primary node is elected.
3 .After the recovery of failed node, it again join the replica set and works as a secondary node.

A typical diagram of mongodb replication is shown in which client application always interact with primary node and primary node then replicate the data to the secondary nodes.

Replica set features


A cluster of N nodes
Anyone node can be primary
All write operations goes to primary
Automatic failover
Automatic Recovery
Consensus election of primary

Set up a replica set 

In this codefari we will convert standalone mongodb instance to a replica set. To convert to replica set follow the below given steps:
·         Shutdown already running mongodb server.
Now start the mongodb server by specifying --replSet option. Basic syntax of --replSet is given below:


mongod --port "PORT" --dbpath "YOUR_DB_DATA_PATH" --replSet "REPLICA_SET_INSTANCE_NAME"


 Example:


mongod --port 27017 --dbpath "D:\set up\mongodb\data" --replSet rs0


It will start a mongod instance with the name rs0, on port 27017. Now start the command prompt and connect to this mongod instance. In mongo client issue the command rs.initiate() to initiate a new replica set. To check the replica set configuration issue the command rs.conf(). To check the status of replica sete issue the command rs.status().

Add members to replica set


To add members to replica set, start mongod instances on multiple machines. Now start a mongo client and issue a command rs.add().

Syntax:


Basic syntax of rs.add() command is as follows:


>rs.add(HOST_NAME:PORT)

Example:


Suppose your mongod instance name is mongod1.net and it is running on port 27017. To add this instance to replica set issue the command rs.add() in mongo client.


>rs.add("mongod1.net:27017")
> 



You can add mongod instance to replica set only when you are connected to primary node. To check whether you are connected to primary or not issue the command db.isMaster() in mongo client.

Popular posts from this blog

Add day to ISODate in MongoDB

We can use $add operator to add days in ISODate in mongodb, $add is the Arithmetic Aggregation Operator which adds number and date in mongodb.
Syntax:

{ $add: [ <expression1>, <expression2>, ... ] }

Note:  If one of the argument is date $add operator treats to other arguments as milliseconds to add to the date.
Example: Suppose we have a Test collection as below.

{"Title" : "Add day to ISODate in MongoBD","CreatedDate" : ISODate("2016-07-07T08:00:00.000Z")}

Query to add 2 days in CreatedDate

db.Test.aggregate([      { $project: { Title: 1, AddedDate: { $add: [ "$CreatedDate", 2*24*60*60000 ] } } }    ])

Result:

{ "_id" : ObjectId("579a1567ac1b3f3732483de0"), "Title" : "Add day to ISODate in MongoBD", "AddedDate" : ISODate("2016-07-09T08:00:00.000Z") }

Note: As mentioned in above note we have to convert days in millisecond because $add operator treat to other arg…

What is difference between UNION and UNION ALL in SQL Server

We use UNION and UNION ALL operator to combine multiple results set into one result set.
UNION operator is used to combining multiple results set into one result set but removes any duplicate rows. Basically, UNION is used to performing a DISTINCT operation across all columns in the result set. UNION operator has the extra overhead of removing duplicate rows and sorting result.
UNION ALL operator use to combine multiple results set into one result set but it does not remove any duplicate result. Actually, this does not remove duplicate rows so it is faster than the UNION operator. If you want to combine multiple results and without duplicate records then use UNION otherwise UNION ALL is better.
Following some rules for using UNION/UNION ALL operator
1.The number of the column should be the same in the query's when you want to combine them. 2.The column should be of the same data type. 3.ORDER BY clause can be applied to the overall result set not within each result set.
4.Column name of …