六:架构管理





mongodb的主从集群分为两种:

1:master-Slave 复制(主从)    --从server不会主动变成主server,须要设置才行

2:replica Sets 复制(副本集)  --假设主server挂掉,会选举出一台从server当主server



一:主从复制

mongodb支持在多个机器中通过异步复制达到故障转移和实现冗余。

  多机器中统一时刻仅仅有一台是用于写操作。正是因为这个情况,为mongodb提供了数据一致性的保障。

  担当primary角色的机器能把读操作分发给slave。

一主一从     一主多从方式

  

仅仅须要在某一个server启动时加上-master參数,而另外一个server加上-slave与-source參数,就可以实现同步。

mongodb的最新版本号已不推荐使用这样的方法 。

 

 開始模拟(直接开玩得,没实用户验证):

1:打开2个终端(安装2台mongodb数据库)

*--你能够再你同一台电脑上模拟。可是把dbpath logpath,相应的文件夹建上即可

mongodb/   下创建文件就(仅仅须要打开2个终端链接即可,不用安装多个mongodb数据库)

bin(mongodb自带的文件)  data1 data2 dblog1 dblog2    --1是主服务用的文件   2是从server用的文件

2:主(设置一台主server)

./mongod --master --dbpath=/usr/local/mongodb/data1/ --logpath=/usr/local/mongodb/dblog1 --fork --port 20001       (port开启一个相应的端口)

   

3:从  --source表示“源” ,链接那台server和port                

./mongod --slave --source 127.0.0.100:20001 --dbpath=/usr/local/mongodb/data2/ --logpath=/usr/local/mongodb/dblog2 --fork --port 20002       



  从:./mongo --port 20002



4: 主:./mongo --port 20001

  db.c1.insert({name:"user1"});

  db.c1.insert({name:"user2"});

5:从:会发现主创建的c1集合已经过来了

db.c1.find();

db.c1.insert({name:"user3"});   --在从server是插不进去的,会报错“not master”



为了降低主server的压力备份什么的能够再从server完毕(比方数据较大,一备份就是几十分钟明显增大主server的压力):

./mongodump --port 20002 -d test    备份test数据库



  **这样增删改的时候能够操作主server。读的时候链接从server

 

  

 

二:Replica Sets复制(副本集)

mongodb在1.6版本号中开发了replica set,主要是添加了故障自己主动切换和自己主动修复成员节点。各个DB之间

数据全然一致。最为显著的差别在于。副本集没有固定的主节点,它是整个集群选举出得到的一个主节点,当

其不工作是变更其它节点强烈推荐使用。

(主挂掉后会自己主动在从中选取出一个作为主server)



部署Replica Sets:

1):创建相应的文件  mongodb/(建立key 、 data 、 log目录)  --key是存同一个会议的小组成员,为选举主server用的

bin  key(建立钥匙文件:touch key1 、 touch key2)  data(下创建目录data1 、data2)   log(下创建目录dblog1 、 dblog2)



2): 在key文件夹下导入2个秘钥(linux的命令这个。win下的话能够自己手动建立)

echo "123456" >key1

echo "123456" >key2



chmod 600 *     --记住:这2把钥匙一定要设置成600 (key文件下操作)



3):准备完成。启动开玩(开启2个mongodb服务)

rs1 :表示定义一个小组,小组组号叫rs1,开会用的

./mongod --replSet rs1 --keyFile=/usr/local/mongodb/key/key1 --port 20001 --dbpath=/usr/local/mongodb/data/data1/ --logpath=/local/mongodb/log/dblog1 --fork



能后在启动一个:

./mongod --replSet rs1 --keyFile=/usr/local/mongodb/key/key2 --port 20002 --dbpath=/usr/local/mongodb/data/data2/ --logpath=/local/mongodb/log/dblog2 --fork





*副本集就已经启动了



4):2个成员会自己主动开会,如今建立下会议室的配置

./mongo --port 20001      ------>(20002也行,哪台机器都能够) 

 

配置建立副本集(小组清单):

config_rs1={  

_id:"rs1",

members:['

{_id:0,host:"localhost:20001",priority:1},     --表示优先级,数字越大优先级就越高,选举主server就更大

{_id:1,host:"localhost:20002",priority:2},

']

}   --回车,   config_rs1能够直接回车查看



初始化副本集配置(小组清单):

rs.initiate(config_rs1);   --回车 在回车,你会发现mongodb的  ">" 符号 变成 "SECONDARY>"(从)  或者  "PRIMARY>"(主)



为什么会变符号呢?(mongodb的  ">" 符号 变成 "SECONDARY>"(从)  或者  "PRIMARY>"(主)):

以为当你初始化副本集的时候,他们就在开会能后把localhost:20002选举为主server(priority数字越大优先级越高),

  所以localhost:20002被选举为主server"PRIMARY>"



5):数据測试

./mongo --port 20002   (主)

db.c1.insert({name:"user1"});

db.c1.insert({name:"user2"});

db.c1.find();

rs.status();   --查看副本集的状态



在登录从server(从server同步是的增删改的数据):

./mongo --port 20001

show tables;   --假设报错,说明你没权限,能后你敲下以下的命令

rs.slaveOk();  --副本集主从里面,从要想有主的读权限的时候敲下该命令,来确认你的身份是从server

show tables;   --就好使

db.c1.find();  --主的数据就能读到了

db.c1.insert({name:"user2"}); --副本集的主从也一样,不能再从里面插入数据,由于不是主server





故障转移:

要2台以上的mongodbserver哦。

副本集比传统的master-salve有改进的地方是它能够进行故障的自己主动转移

假设我们停掉复制集中的一个成员。那么剩下的成员就会自己主动选举出一个新的成员,做为主数据库

MongoDB 集群搭建(主从复制、副本及)(五)的更多相关文章

  1. MongoDB集群搭建之副本集模仿主从模式的行为

    #模拟主节点异常中断 [root@ba3b27d855f6 bin]# kill -9 199 [root@ba3b27d855f6 bin]#   #连接到其中一台备份节点 [root@ba3b27 ...

  2. MongoDB集群搭建-副本集

    MongoDB集群搭建-副本集 概念性的知识,可以参考本人博客地址: 一.Master-Slave方案: 主从: 二.Replica Set方案: 副本集: 步骤:(只要按步骤操作,100%成功) 1 ...

  3. mongodb集群搭建过程记录

    mongodb集群搭建花费比较长的时间,在此记录下过程,方便以后使用 一 软件环境 系统:ubuntu 18.04,mongodb 社区版4.2 https://docs.mongodb.com/ma ...

  4. Mongodb 集群搭建以及常见错误

    Mongodb 集群搭建以及常见错误 1 关于Replica Sets +Sharding(主从复制加分片)搭建,不这详细去说,网上有很多,大部分的例子就三台服务器之间做主从复制,分2个shard,架 ...

  5. Mongodb集群搭建之 Replica Set

    Mongodb集群搭建之 Replica Set Replica Set 中文翻译叫做副本集,不过我并不喜欢把英文翻译成中文,总是感觉怪怪的.其实简单来说就是集群当中包含了多份数据,保证主节点挂掉了, ...

  6. MongoDB集群搭建-分片

    MongoDB集群搭建-分片 一.场景: 1,机器的磁盘不够用了.使用分片解决磁盘空间的问题. 2,单个mongod已经不能满足写数据的性能要求.通过分片让写压力分散到各个分片上面,使用分片服务器自身 ...

  7. MongoDB 3.6.9 集群搭建 - 切片+副本集

    1. 环境准备 在Mongo的官网下载Linux版本安装包,然后解压到对应的目录下:由于资源有限,我们采用Replica Sets + Sharding方式来配置高可用.结构图如下所示: 这里我说明下 ...

  8. mongodb集群搭建(分片+副本)

    原文地址:https://www.cnblogs.com/ityouknow/p/7344005.html 相关概念 先来看一张图: 从图中可以看到有四个组件:mongos.config server ...

  9. mongodb集群搭建(分片+副本)开启安全认证

    关于安全认证得总结: 这个讲述的步骤也是先创建超管用户,关闭服务,然后生成密钥文件,开启安全认证,启动服务 相关概念 先来看一张图: 从图中可以看到有四个组件:mongos.config server ...

  10. mongodb3.6集群搭建:分片+副本集

    mongodb是最常用的noSql数据库,在数据库排名中已经上升到了前五.这篇文章介绍如何搭建高可用的mongodb(分片+副本)集群. 在搭建集群之前,需要首先了解几个概念:路由,分片.副本集.配置 ...

随机推荐

  1. POJ 1364 King (差分约束)

    King Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 8660   Accepted: 3263 Description ...

  2. js Circle类

    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/stri ...

  3. Socket详解-Linux Socket编程(不限Linux)

    “一切皆Socket!” 话虽些许夸张,但是事实也是,现在的网络编程几乎都是用的socket. ——有感于实际编程和开源项目研究. 我们深谙信息交流的价值,那网络中进程之间如何通信,如我们每天打开浏览 ...

  4. 转: Python中的os.path.dirname(__file__)

     (1).当"print os.path.dirname(__file__)"所在脚本是以完整路径被运行的, 那么将输出该脚本所在的完整路径,比如:                 ...

  5. Accounting_会计基础知识

    作为企业的财务人员,必须拥有一些技能和财务方面的知识,本文就所讲述的是财务岗位必须掌握的知识总结,仅供参考. 1.账面价值.账面余额和账面净值 账面价值是指某科目(通常是资产类科目)的账面余额减去相关 ...

  6. 内存管理算法--Buddy伙伴算法【转】

    转自:http://blog.csdn.net/orange_os/article/details/7392986 Buddy算法的优缺点: 1)尽管伙伴内存算法在内存碎片问题上已经做的相当出色,但是 ...

  7. js实现多物体运动框架并兼容各浏览器

    首先,我们须要知道在js中获取对象的宽度如offsetWidth等.可能会存在一些小小的bug.原因之中的一个在于offsetWidth只不过获取盒子模型中内容的部分宽度.并不包括内边距,边框和外边距 ...

  8. 在Nodejs中贯彻单元测试

    在团队合作中,你写好了一个函数,供队友使用,跑去跟你的队友说,你传个A值进去,他就会返回B结果了.过了一会,你队友跑过来说,我传个A值却返回C结果,怎么回事?你丫的有没有测试过啊? 大家一起写个项目, ...

  9. 分享九:php易混淆的语法

    一:php后期静态绑定 从php5.3开始,php增加了一个叫后期绑定的功能,用于在继承范围内引用静态调用的类 该功能从语言内部角度考虑北命名为“后期静态绑定”:“后期绑定”意思说:static::不 ...

  10. Python文件遍历二种方法

    分享下有关Python文件遍历的两种方法,使用的OS模块的os.walk和os.listdir实现. 关于Python的文件遍历,大概有两种方法,一种是较为便利的os.walk(),还有一种是利用os ...