Mongodb学习----主从数据库

在企业应用中,肯定不希望数据库做单点部署,如果碰到服务器宕机或者硬件毁灭性故障,将有不可挽回的损失。

主从数据库的架构优势:

<1>数据备份

<2>数据恢复

<3>读写分离

主从数据库搭建过程:

<1>mongodb --dbpath='XXX' --master【主数据库】

<2>mongod --dbpath=xxxx --port=8888 --slave --source=127.0.0.1:27017【从数据库】

当主数据库更新数据的时候,从数据库也相应的更新。

如果还想增加一台从数据库,而且希望是后期指定而不是启动时指定:

主数据库或者从数据库中都有一个叫做local的集合,主要用于存放内部复制信息。


读写分离:

mongoDB默认情况下不支持数据的读取,但是在驱动中提供了一个叫做"slaveokay"来让我们可以经过从数据库读取数据来减轻主数据库的压力。

副本集【重要内容】

副本集特性:

<1>改集群没有特定主数据库

<2>如果哪个主数据库down掉了,集群会马上推选一个服务器作为主数据库。这就是传说中的自动修复功能。

副本集建立步骤:

<1>首先,需要建立一个集群名称--liumengyang,然后通过--replSet属性让服务器知道liumengyang这个集群下面还有其他的服务器。具体命令如下:

mongod --dbpath:*****   --port  端口号   ---replSet   clusterName/ipaddress:portnum

当把几个服务器全部开启的时候,仍然不好用,需要做以下初始化操作:

> db.runCommand({"replSetInitiate":{
... "_id":"liumengyang",
... "members":[
... {
... "_id":1,
... "host":"127.0.0.1:2222"
... },
... {
... "_id":2,
... "host":"127.0.0.1:3333"
... }
... ]}})
仲裁服务器和状态查看命令:

liumengyang:PRIMARY> rs.addArb("127.0.0.1:4444")
{ "ok" : 1 }
liumengyang:PRIMARY>
liumengyang:PRIMARY>
liumengyang:PRIMARY>
liumengyang:PRIMARY>
liumengyang:PRIMARY> rs.status();
{
        "set" : "liumengyang",
        "date" : ISODate("2015-09-10T02:42:12.901Z"),
        "myState" : 1,
        "members" : [
                {
                        "_id" : 1,
                        "name" : "127.0.0.1:2222",
                        "health" : 1,
                        "state" : 1,
                        "stateStr" : "PRIMARY",
                        "uptime" : 1729,
                        "optime" : Timestamp(1441852921, 1),
                        "optimeDate" : ISODate("2015-09-10T02:42:01Z"),
                        "electionTime" : Timestamp(1441852277, 1),
                        "electionDate" : ISODate("2015-09-10T02:31:17Z"),
                        "configVersion" : 2,
                        "self" : true
                },
                {
                        "_id" : 2,
                        "name" : "127.0.0.1:3333",
                        "health" : 1,
                        "state" : 2,
                        "stateStr" : "SECONDARY",
                        "uptime" : 747,
                        "optime" : Timestamp(1441852921, 1),
                        "optimeDate" : ISODate("2015-09-10T02:42:01Z"),
                        "lastHeartbeat" : ISODate("2015-09-10T02:42:11.712Z"),
                        "lastHeartbeatRecv" : ISODate("2015-09-10T02:42:11.337Z"
),
                        "pingMs" : 0,
                        "syncingTo" : "127.0.0.1:2222",
                        "configVersion" : 2
                },
                {
                        "_id" : 3,
                        "name" : "127.0.0.1:4444",
                        "health" : 1,
                        "state" : 7,
                        "stateStr" : "ARBITER",
                        "uptime" : 11,
                        "lastHeartbeat" : ISODate("2015-09-10T02:42:11.713Z"),
                        "lastHeartbeatRecv" : ISODate("2015-09-10T02:42:11.364Z"
),
                        "pingMs" : 0,
                        "configVersion" : 2
                }
        ],
        "ok" : 1
}
liumengyang:PRIMARY> rs.status;
function () { return db._adminCommand("replSetGetStatus"); }
liumengyang:PRIMARY> rs.status();
{
        "set" : "liumengyang",
        "date" : ISODate("2015-09-10T02:54:20.273Z"),
        "myState" : 1,
        "members" : [
                {
                        "_id" : 1,
                        "name" : "127.0.0.1:2222",
                        "health" : 1,
                        "state" : 1,
                        "stateStr" : "PRIMARY",
                        "uptime" : 2457,
                        "optime" : Timestamp(1441852921, 1),
                        "optimeDate" : ISODate("2015-09-10T02:42:01Z"),
                        "electionTime" : Timestamp(1441852277, 1),
                        "electionDate" : ISODate("2015-09-10T02:31:17Z"),
                        "configVersion" : 2,
                        "self" : true
                },
                {
                        "_id" : 2,
                        "name" : "127.0.0.1:3333",
                        "health" : 1,
                        "state" : 2,
                        "stateStr" : "SECONDARY",
                        "uptime" : 1475,
                        "optime" : Timestamp(1441852921, 1),
                        "optimeDate" : ISODate("2015-09-10T02:42:01Z"),
                        "lastHeartbeat" : ISODate("2015-09-10T02:54:19.834Z"),
                        "lastHeartbeatRecv" : ISODate("2015-09-10T02:54:19.467Z"
),
                        "pingMs" : 0,
                        "syncingTo" : "127.0.0.1:2222",
                        "configVersion" : 2
                },
                {
                        "_id" : 3,
                        "name" : "127.0.0.1:4444",
                        "health" : 1,
                        "state" : 7,
                        "stateStr" : "ARBITER",
                        "uptime" : 738,
                        "lastHeartbeat" : ISODate("2015-09-10T02:54:19.849Z"),
                        "lastHeartbeatRecv" : ISODate("2015-09-10T02:54:19.468Z"
),
                        "pingMs" : 0,
                        "configVersion" : 2
                }
        ],
        "ok" : 1
}






  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Mongodb主从数据库是一种数据同步和备份的配置模式。在这种模式下,Mongodb将数据复制到一个或多个从数据库(slaves),以实现数据的冗余备份和读写分离。为了配置主从模式,您需要进行以下步骤: 1. 准备环境:确保您的系统已经安装了Mongodb,并且您知道数据库(master)和从数据库(slave)的IP地址和端口号。 2. 配置数据库:在数据库上,您需要启动Mongodb并指定角色为(master)。您可以使用命令行或配置文件来设置。 3. 配置从数据库:在从数据库上,您需要启动Mongodb并指定角色为从(slave),同时指定数据源地址为数据库的地址和端口号。您可以使用命令行来设置。 具体的配置过程和命令如下: 1. 启动数据库(master):在命令行中输入以下命令来启动数据库: mongod --dbpath=/path/to/data --replSet=[name] --port=[port] 其中,/path/to/data是数据库的数据存储路径,[name]是数据库的名称,[port]是数据库的端口号。 2. 初始化数据库(master):在命令行中输入以下命令来初始化数据库: mongo --port=[port] 在mongo shell中,执行以下命令: rs.initiate() 这将初始化数据库并设置复制集。 3. 启动从数据库(slave):在命令行中输入以下命令来启动从数据库: mongod --dbpath=/path/to/data --replSet=[name] --port=[port] --slave --source=[master_ip:port] 其中,/path/to/data是从数据库的数据存储路径,[name]是从数据库的名称,[port]是从数据库的端口号,[master_ip:port]是数据库的IP地址和端口号。 4. 验证配置:在命令行中输入以下命令来验证主从配置: mongo --port=[port] 在mongo shell中,执行以下命令: rs.status() 如果配置正确,您将看到数据库和从数据库的状态信息。 通过配置主从模式,您可以实现Mongodb数据的同步和备份,以及读写分离,提高数据库的可靠性和性能。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [详解mongodb 主从配置](https://download.csdn.net/download/weixin_38607971/12832213)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Mongodb配置主从模式,进行数据的同步与备份](https://blog.csdn.net/zwq912318834/article/details/78971029)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值