mongodb-3.2.8 单机复制集安装

规划:

replSet 复制集名称: rs1

MongoDB数据库安装安装路径为:/usr/local/mongodb/

复制集成员IP与端口:

节点1: localhost:28010   (默认的primary节点)

节点2: localhost:20811

节点3: localhost:28012

复制集各节点的数据文件,日志文件,私钥文件路径:

节点1: /data/data/r0  , /data/log/r0.log , /data/key/r0

节点2: /data/data/r1  , /data/log/r1.log , /data/key/r1

节点3: /data/data/r2  , /data/log/r2.log , /data/key/r2

$ wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-3.2.8.tgz

--2016-07-22 11:17:12--  https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-3.2.8.tgz

Resolving fastdl.mongodb.org (fastdl.mongodb.org)... 54.182.5.247, 54.182.5.9, 54.182.5.45, ...

Connecting to fastdl.mongodb.org (fastdl.mongodb.org)|54.182.5.247|:443... connected.

HTTP request sent, awaiting response... 200 OK

Length: 71943658 (69M) [application/x-gzip]

Saving to: ‘mongodb-linux-x86_64-rhel70-3.2.8.tgz’

100%[===============================================================================>] 71,943,658   116KB/s   in 16m 37s

2016-07-22 11:33:51 (70.5 KB/s) - ‘mongodb-linux-x86_64-rhel70-3.2.8.tgz’ saved [71943658/71943658]

$tar zxvf mongodb-linux-x86_64-rhel70-3.2.8.tgz -C /usr/local/

$mv mongodb-linux-x86_64-rhel70-3.2.8 mongodb

1) 创建数据文件存储路径

[[email protected] mongodb]# mkdir -p /data02/mongors/data/r0

[[email protected] mongodb]# mkdir -p /data02/mongors/data/r1

[[email protected] mongodb]# mkdir -p /data02/mongors/data/r2

2)创建日志文件路径

[[email protected] mongodb]# mkdir -p /data02/mongors/log

3)创建主从key文件

用于标识集群的私钥的完整路径,如果各个实例的key file内容不一致,程序将不能正常使用

[[email protected] mongodb]# mkdir -p /data02/mongors/key

[[email protected] mongodb]# echo "this is rs1  key" > /data02/mongors/key/r0

[[email protected] mongodb]# echo "this is rs1  key" > /data02/mongors/key/r1

[[email protected] mongodb]# echo "this is rs1  key" > /data02/mongors/key/r2

[[email protected] mongodb]# chmod 600 /data02/mongors/key/r*

4)启动3个实例

依次添加启动参数,其中三个MongoDB实例:

[[email protected] mongodb]# /usr/local/mongodb/bin/mongod --replSet rs1 --keyFile /data02/mongors/key/r0 --fork --port 28010 --dbpath /data02/mongors/data/r0 --logpath=/data02/mongors/log/r0.log --logappend

about to fork child process, waiting until server is ready for connections.

forked process: 16629

child process started successfully, parent exiting

[[email protected] mongodb]# /usr/local/mongodb/bin/mongod --replSet rs1 --keyFile /data02/mongors/key/r1 --fork --port 28011 --dbpath /data02/mongors/data/r1 --logpath=/data02/mongors/log/r1.log --logappend

about to fork child process, waiting until server is ready for connections.

forked process: 16666

child process started successfully, parent exiting

[[email protected] mongodb]# /usr/local/mongodb/bin/mongod --replSet rs1 --keyFile /data02/mongors/key/r2 --fork --port 28012 --dbpath /data02/mongors/data/r2 --logpath=/data02/mongors/log/r2.log --logappend

about to fork child process, waiting until server is ready for connections.

forked process: 16703

child process started successfully, parent exiting

[[email protected] mongodb]#

注:启动命令的参数分别为,mongod为主启动命令, replSet指定复制集名称为rs1,keyfile指定公钥文件 ,fork指定启动方式为deamo后台启动;port指定端口号,dbpath指定数据文件目录,logpath指定日志文件,logappend指定错误日志为日志追加模式;

通过进程和端口,验证启动状态

[[email protected] mongodb]# ps -ef|grep mongo

root     16629     1  0 17:36 ?        00:00:00 /usr/local/mongodb/bin/mongod --replSet rs1 --keyFile /data02/mongors/key/r0 --fork --port 28010 --dbpath /data02/mongors/data/r0 --logpath=/data02/mongors/log/r0.log --logappend

root     16666     1  0 17:36 ?        00:00:00 /usr/local/mongodb/bin/mongod --replSet rs1 --keyFile /data02/mongors/key/r1 --fork --port 28011 --dbpath /data02/mongors/data/r1 --logpath=/data02/mongors/log/r1.log --logappend

root     16703     1  0 17:36 ?        00:00:00 /usr/local/mongodb/bin/mongod --replSet rs1 --keyFile /data02/mongors/key/r2 --fork --port 28012 --dbpath /data02/mongors/data/r2 --logpath=/data02/mongors/log/r2.log --logappend

root     16739 12972  0 17:37 pts/1    00:00:00 grep --color=auto mongo

[[email protected] mongodb]# netstat -tunlp |grep mong

tcp        0      0 0.0.0.0:28010           0.0.0.0:*               LISTEN      16629/mongod

tcp        0      0 0.0.0.0:28011           0.0.0.0:*               LISTEN      16666/mongod

tcp        0      0 0.0.0.0:28012           0.0.0.0:*               LISTEN      16703/mongod

[[email protected] mongodb]#

5)配置及初始化 Replica Sets

登录到primary服务器上:

# /usr/local/mongodb/bin/mongo -port 28010

配置复制集:

> config = {_id: ‘rs1‘, members: [

{_id: 0, host: ‘localhost:28010‘,priority:1},

{_id: 1, host: ‘localhost:28011‘},

{_id: 2, host: ‘localhost:28012‘}]

}

初始化配置,使上面的配置生效:

>  rs.initiate(config);

6)查看复制集状态

> rs.status()

在primary节点上查看复制集状态:

> rs.isMaster()

可以再primary节点进行各种添删改查等各种数据操作,其他非master节点不能进行各种数据操作,也不能发起复制集修改命令

过程如下:(securecrt执行时候总是会复制一下回显)

[[email protected] mongodb]#  /usr/local/mongodb/bin/mongo -port 28010

MongoDB shell version: 3.2.8

connecting to: 127.0.0.1:28010/test

> use adminduse admind

switched to db admind

> use adminuse admin

switched to db admin

> config = {_id: ‘rs1‘, members: [config = {_id: ‘rs1‘, members: [

...              {_id: 0, host: ‘localhost:28010‘,priority:1},             {_id: 0, host: ‘localhost:28010‘,priority:1},

...              {_id: 1, host: ‘localhost:28011‘},             {_id: 1, host: ‘localhost:28011‘},

...              {_id: 2, host: ‘localhost:28012‘}]             {_id: 2, host: ‘localhost:28012‘}]

...       }      }

{

"_id" : "rs1",

"members" : [

{

"_id" : 0,

"host" : "localhost:28010",

"priority" : 1

},

{

"_id" : 1,

"host" : "localhost:28011"

},

{

"_id" : 2,

"host" : "localhost:28012"

}

]

}

> rs.initiate(config);rs.initiate(config);

{ "ok" : 1 }

rs1:OTHER>

rs1:SECONDARY>

rs1:SECONDARY> rs.status()rs.status()

{

"set" : "rs1",

"date" : ISODate("2016-07-22T09:40:47.831Z"),

"myState" : 1,

"term" : NumberLong(1),

"heartbeatIntervalMillis" : NumberLong(2000),

"members" : [

{

"_id" : 0,

"name" : "localhost:28010",

"health" : 1,

"state" : 1,

"stateStr" : "PRIMARY",

"uptime" : 266,

"optime" : {

"ts" : Timestamp(1469180428, 2),

"t" : NumberLong(1)

},

"optimeDate" : ISODate("2016-07-22T09:40:28Z"),

"infoMessage" : "could not find member to sync from",

"electionTime" : Timestamp(1469180428, 1),

"electionDate" : ISODate("2016-07-22T09:40:28Z"),

"configVersion" : 1,

"self" : true

},

{

"_id" : 1,

"name" : "localhost:28011",

"health" : 1,

"state" : 2,

"stateStr" : "SECONDARY",

"uptime" : 31,

"optime" : {

"ts" : Timestamp(1469180428, 2),

"t" : NumberLong(1)

},

"optimeDate" : ISODate("2016-07-22T09:40:28Z"),

"lastHeartbeat" : ISODate("2016-07-22T09:40:46.077Z"),

"lastHeartbeatRecv" : ISODate("2016-07-22T09:40:47.815Z"),

"pingMs" : NumberLong(0),

"syncingTo" : "localhost:28010",

"configVersion" : 1

},

{

"_id" : 2,

"name" : "localhost:28012",

"health" : 1,

"state" : 2,

"stateStr" : "SECONDARY",

"uptime" : 31,

"optime" : {

"ts" : Timestamp(1469180428, 2),

"t" : NumberLong(1)

},

"optimeDate" : ISODate("2016-07-22T09:40:28Z"),

"lastHeartbeat" : ISODate("2016-07-22T09:40:46.104Z"),

"lastHeartbeatRecv" : ISODate("2016-07-22T09:40:47.813Z"),

"pingMs" : NumberLong(0),

"syncingTo" : "localhost:28010",

"configVersion" : 1

}

],

"ok" : 1

}

rs1:PRIMARY> rs.isMaster()rs.isMaster()

{

"hosts" : [

"localhost:28010",

"localhost:28011",

"localhost:28012"

],

"setName" : "rs1",

"setVersion" : 1,

"ismaster" : true,

"secondary" : false,

"primary" : "localhost:28010",

"me" : "localhost:28010",

"electionId" : ObjectId("7fffffff0000000000000001"),

"maxBsonObjectSize" : 16777216,

"maxMessageSizeBytes" : 48000000,

"maxWriteBatchSize" : 1000,

"localTime" : ISODate("2016-07-22T09:41:07.987Z"),

"maxWireVersion" : 4,

"minWireVersion" : 0,

"ok" : 1

}

rs1:PRIMARY>

时间: 2024-10-23 21:52:44

mongodb-3.2.8 单机复制集安装的相关文章

mongodb 学习笔记 08 -- replication复制集

官方文档: http://docs.mongodb.org/manual/replication/ replication sets 多台服务器维护相同的数据副本 如何使用复制集 第一步 启动mongod是要指定复制集名字,通过 添加–replSet name 或者 在配置文件中设置replication.replSetName 设置复制集名称 比如: mongod --port 270217 --dbpath /mongo/database --logpath /mongo/log/mongo

centos7部署MongoDB数据库复制集(超详细)

centos7部署MongoDB数据库复制集(超详细)重点:复制集概述:复制集实现原理:复制集的应用案例:一.概述:组成:Mongodb复制集(副本集replica set)由一组Mongod实例(进程)组成,包含一个Primary节点和多个Secondary节点,Mongodb Driver(客户端)的所有数据都写入Primary,Secondary通过oplog来同步Primary的数据,保证主节点和从节点数据的一致性,复制集在完成主从复制的基础上,通过心跳机制,一旦primary节点出现宕

MongoDB 3.2复制集单节点部署(四)

MongoDB在单节点中也可以做复制集,但是仅限于测试实验,最大的好处就是部署方便快速,可以随便添加新节点,节省资源.在这里我使用的是MongoDB 3.2版本进行复制集实验(但MongoDB配置文件使用的是老版本格式),一共使用三个节点,一个是主节点(PRIMARY),一个是从节点(SECONDARY),一个是投票节点(ARBITER).如下图: 一.实验环境 1)节点信息:192.168.60.10 3)节点确保iptables和selinux已关闭 1 2 [root@node1 ~]#

MongoDB 2.6复制集单节点部署(三)

MongoDB在单节点中也可以做复制集,但是仅限于测试实验,最大的好处就是部署方便快速,可以随便添加新节点,节省资源.在这里我使用的是MongoDB 2.6版本进行复制集实验(但MongoDB配置文件使用的是老版本格式),一共使用三个节点,一个是主节点(PRIMARY),一个是从节点(SECONDARY),一个是投票节点(ARBITER).如下图: 一.实验环境 1)节点信息:192.168.60.60 3)节点确保iptables和selinux已关闭 1 2 [root@node1 ~]#

MongoDB复制集技术

第1章 MongoDB复制集简介: 一组MongoDB复制集,就是一组MongoDB进程,这些进程维护同一个数据集合,复制集提供了数据冗余和高等级的可靠性,这是生产部署的基础 1.1 复制集的目的: 保证数据在生产部署是的冗余和可靠性,通过在不同的机器上保存副本来保证数据的不会因为单间损坏而丢失,能够随时应对数据丢失或者机器损坏带来的风险 还可以提高用户读写数据的性能,提高整个系统的负载 1.2 简单介绍: 1.      一组复制集就是一组MongoDB实例掌管同一个数据集,实例可以在不同的机

MongoDB 复制集节点增加移除及节点属性配置

复制集(replica Set)或者副本集是MongoDB的核心高可用特性之一,它基于主节点的oplog日志持续传送到辅助节点,并重放得以实现主从节点一致.再结合心跳机制,当感知到主节点不可访问或宕机的情形下,辅助节点通过选举机制来从剩余的辅助节点中推选一个新的主节点从而实现自动切换.对于一个已经存在的MongoDB Replica Set集群,可以对其进行节点的增加,删除,以及修改节点属性等等.本文即是围绕这些进行描述. 有关MongoDB复制集概念及其搭建,可以参考:MongoDB 复制集(

Spring Boot MongoDB 可复制集的读写分离

最近项目的一个版本刚迭代上去,然后设备也陆续地接入到了系统中. 设备产生的数据经过解析.处理之后落到了 MongoDB 中,但是才 10w 的数据就导致分页查询非常慢,count 操作也是慢的感人. 上午加了索引之后,从 10 多秒降到了 5 秒左右,但是这个速度还是很慢啊,这 TM 的等到设备都接入进来不就炸了. 然后下午就开始排错,查看代码中的慢查询. 最后发现一个现象就是:通过 Navicat 去查询相同的 find 和 count 语句要比在代码中快了好多倍,客户端的查询才是正常现象.

mongodb复制集+分片生产环境实践

三台机器操作系统环境如下: [[email protected] ~]$ cat /etc/issue Red Hat Enterprise Linux Server release 6.6 (Santiago) Kernel \r on an \m [[email protected] ~]$ uname -r 2.6.32-504.el6.x86_64 [[email protected] ~]$ uname -m x86_64 架构如下图: 文字描述:                  

MongoDB复制集

MongoDB目前的高可用架构主要有主从.复制集.以及分片,单纯的主从技术几乎被淘汰,整个稳定性以及可靠性方面复制集要比主从好,所以现在更多的会去使用复制集.在接下来的实践过程中,我们将通过多实例的方法实现复制集.以及会解析搭建过程中遇到的困难问题. 一.基础环境与规划 操作系统:CentOS 6.7 MongoDB版本:3.4.5 实例部署情况: 主机IP 数据目录 日志文件 端口 127.0.0.1 /data/mongoDB/data/m17 /data/mongoDB/logs/mong