MongoDB 副本集搭建
搭建mongodb副本集
[root@ mongodb]# cd /u02
[root@ u02]# mkdir -p mongodb/data_2777
[root@ u02]# mkdir -p mongodb/data_3777
[root@ u02]# mkdir -p mongodb/data_4777
[root@ mongodb]# tar mongodb-linux-x86_64-3.2..tgz
[root@ mongodb]# mv mongodb-linux-x86_64-3.2. mongodb
[root@ mongodb]# mkdir -p
[root@ ]# mkdir {conf,log,keys,pid}
[root@ ]# mkdir {conf,log,keys,pid}
[root@ ]# mkdir {conf,log,keys,pid}
创建配置文件
[root@ conf]# vi mongodb_2777.conf
systemLog:
destination: file
logAppend: true
path: /u02/mongodb/mongodb//log/shard1.log
storage:
dbPath: /u02/mongodb/data_2777
journal:
enabled: true
directoryPerDB: true
engine: wiredTiger
wiredTiger:
engineConfig:
cacheSizeGB: # the maximum of half of physical RAM or gigabyte
directoryForIndexes: true # mongod stores indexes and collections in separate subdirectories under the data (i.e. storage.dbPath) directory
collectionConfig:
blockCompressor: snappy # The default type of compression to use to compress collection data
processManagement:
fork: true # fork and run in background
pidFilePath: /u02/mongodb/mongodb//pid/mongodb_2777.pid # location of pidfile
net:
bindIp: 0.0.0.0
port:
operationProfiling:
slowOpThresholdMs:
mode: slowOp
replication:
replSetName: shard1 #副本集的名称,副本集以此名称来识别是否属于同一个集群中
oplogSizeMB:
#auditLog:
# destination: file
# format: JSON
# path: /u02/mongodb/mongodb//log/audit_log/audit.json
#
启动mongodb
/u02/mongodb/mongodb/bin/mongod -f /u02/mongodb/mongodb//conf/mongodb_2777.conf
/u02/mongodb/mongodb/bin/mongod -f /u02/mongodb/mongodb//conf/mongodb_3777.conf
/u02/mongodb/mongodb/bin/mongod -f /u02/mongodb/mongodb//conf/mongodb_4777.conf
登录2777端口mongodb
[root@ conf]# /u02/mongodb/mongodb/bin/mongo --port
MongoDB shell version: 3.2.
connecting to: 127.0.0.1:/test
Server has startup warnings:
--08T19::35.621+ I CONTROL [initandlisten] ** WARNING: You are running this process as the root user, which is not recommended.
--08T19::35.621+ I CONTROL [initandlisten]
--08T19::35.622+ I CONTROL [initandlisten]
--08T19::35.622+ I CONTROL [initandlisten] ** WARNING: You are running on a NUMA machine.
--08T19::35.622+ I CONTROL [initandlisten] ** We suggest launching mongod like this to avoid performance problems:
--08T19::35.622+ I CONTROL [initandlisten] ** numactl --interleave=all mongod [other options]
--08T19::35.622+ I CONTROL [initandlisten]
--08T19::35.622+ I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always'.
--08T19::35.622+ I CONTROL [initandlisten] ** We suggest setting it to 'never'
--08T19::35.622+ I CONTROL [initandlisten]
--08T19::35.622+ I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always'.
--08T19::35.622+ I CONTROL [initandlisten] ** We suggest setting it to 'never'
--08T19::35.622+ I CONTROL [initandlisten]
shard1:PRIMARY>
shard1:PRIMARY>conf = {_id:"shard1",members:[{_id:,host:"127.0.0.1:2777"}]};
shard1:PRIMARY>rs.initiate(conf) ;
会显示出你的当前数据库服务实例已经加到副本集中,并且是master
shard1:PRIMARY> db.isMaster()
{
"hosts" : [
"127.0.0.1:2777",
"127.0.0.1:3777",
"127.0.0.1:4777"
],
"setName" : "shard1",
"setVersion" : ,
"ismaster" : true,
"secondary" : false,
"primary" : "127.0.0.1:2777",
"me" : "127.0.0.1:2777",
"electionId" : ObjectId("7fffffff0000000000000001"),
"maxBsonObjectSize" : ,
"maxMessageSizeBytes" : ,
"maxWriteBatchSize" : ,
"localTime" : ISODate("2019-10-08T12:12:35.869Z"),
"maxWireVersion" : ,
"minWireVersion" : ,
"ok" :
}
接着添加刚刚那2个服务实例到副本集中
shard1:PRIMARY>rs.add("127.0.0.1:3777");
shard1:PRIMARY>rs.add("127.0.0.1:4777");
查看副本集:
shard1:PRIMARY> rs.status()
{
"set" : "shard1",
"date" : ISODate("2019-10-08T12:14:04.786Z"),
"myState" : ,
"term" : NumberLong(),
"heartbeatIntervalMillis" : NumberLong(),
"members" : [
{
"_id" : ,
"name" : "127.0.0.1:2777",
"health" : ,
"state" : ,
"stateStr" : "PRIMARY",
"uptime" : ,
"optime" : {
"ts" : Timestamp(, ),
"t" : NumberLong()
},
"optimeDate" : ISODate("2019-10-08T12:02:26Z"),
"electionTime" : Timestamp(, ),
"electionDate" : ISODate("2019-10-08T12:01:02Z"),
"configVersion" : ,
"self" : true
},
{
"_id" : ,
"name" : "127.0.0.1:3777",
"health" : ,
"state" : ,
"stateStr" : "SECONDARY",
"uptime" : ,
"optime" : {
"ts" : Timestamp(, ),
"t" : NumberLong()
},
"optimeDate" : ISODate("2019-10-08T12:02:26Z"),
"lastHeartbeat" : ISODate("2019-10-08T12:14:04.654Z"),
"lastHeartbeatRecv" : ISODate("2019-10-08T12:14:03.533Z"),
"pingMs" : NumberLong(),
"syncingTo" : "127.0.0.1:2777",
"configVersion" :
},
{
"_id" : ,
"name" : "127.0.0.1:4777",
"health" : ,
"state" : ,
"stateStr" : "SECONDARY",
"uptime" : ,
"optime" : {
"ts" : Timestamp(, ),
"t" : NumberLong()
},
"optimeDate" : ISODate("2019-10-08T12:02:26Z"),
"lastHeartbeat" : ISODate("2019-10-08T12:14:04.654Z"),
"lastHeartbeatRecv" : ISODate("2019-10-08T12:14:03.414Z"),
"pingMs" : NumberLong(),
"configVersion" :
}
],
"ok" :
}
rs.status()
"health" : 1, #代表机器正常
"stateStr" : "PRIMARY", #代表是主节点,可读写,其中有以下几下状态
1. STARTUP:刚加入到复制集中,配置还未加载
2. STARTUP2:配置已加载完,初始化;
3. RECOVERING:正在恢复,不适用读
4. ARBITER: 仲裁者
5. DOWN:节点不可到达
6. UNKNOWN:未获取其他节点状态而不知是什么状态,一般发生在只有两个成员的架构
7. REMOVED:移除复制集
8. ROLLBACK:数据回滚,在回滚结束时,转移到RECOVERING或SECONDARY状态
9. FATAL:出错。查看日志grep “replSet FATAL”找出错原因,重新做同步
10. PRIMARY:主节点
11. SECONDARY:备份节点
创建数据库:
shard1:PRIMARY> use yoon
查看当前数据库:
shard1:PRIMARY> db
yoon
插入数据:
shard1:PRIMARY> db.movie.insert({"name":"hank"});
WriteResult({ "nInserted" : })
查看当前库下的表:
shard1:PRIMARY> show collections
movie
查看表中数据:
shard1:PRIMARY> db.movie.find()
{ "_id" : ObjectId("5d9c7ee9d7a8df8fd023d6ed"), "name" : "hank" }
登录3777端口查看表movie:
[root@ conf]# /u02/mongodb/mongodb/bin/mongo --port
注意:新建的slave是不能读和写的,当在从服务器上读时会出现errmsg:not master and slaveOk=flase code: 错误,需要执行:rs.slaveOk()来开启读功能
shard1:SECONDARY> rs.slaveOk() shard1:SECONDARY> show dbs
local .000GB
yoon .000GB
shard1:SECONDARY> use yoon
switched to db yoon
shard1:SECONDARY> show collections
movie
shard1:SECONDARY> db.movie.find()
{ "_id" : ObjectId("5d9c7ee9d7a8df8fd023d6ed"), "name" : "hank" }
MongoDB 副本集搭建的更多相关文章
- MongoDB副本集搭建及备份恢复
一.MongoDB副本集(repl set)介绍 早起版本使用master-slave,一主一从和MySQL类似,但slave在此架构中为只读,当主库宕机后,从库不能自动切换为主: 目前已经淘汰了ma ...
- mongodb副本集搭建过程中的问题和解决技巧
在我以往的认知中,一个系统一旦正式上线,多半不会轻易的迁移服务器,尤其是那种涉及到多个关联应用,涉及到多台硬件服务器的系统,因为这种迁移将是牵一发而动全身的. 但是,却仍然有这种情况存在,就如我这几天 ...
- windows版本 MongoDB副本集搭建及开启身份验证
------------恢复内容开始------------ ------------恢复内容开始------------ MongoDB副本集搭建 我搭建的是一个主节点,两个副节点 构建目录结构如下 ...
- Mongodb副本集搭建经验
一.环境配置经验 1.一般安装的副本集的时候,主实例可以有数据库和用户:从实例不能.仲裁机不能有任何数据库包括用户 2.搭建副本集的时候Host使用外网IP,否则使用Mongodb VUE 1.6.9 ...
- MongoDB 副本集搭建 & 副本集扩容
副本集的搭建 创建多实例目录 [root@redis03 ~]# mkdir /server/mongodb/2801{7,8,9}/{conf,logs,pid,data} -p 编辑多实例配置文件 ...
- mongodb副本集搭建
1.创建目录 mkdir -p /data/r1 /data/r2 /data/r3 2.启动: bin/mongod --config ../mongod.conf --replSet r1 b ...
- 在centos7上搭建mongodb副本集
1.安装副本集介绍 副本集(Replica Set)是一组MongoDB实例组成的集群,由一个主(Primary)服务器和多个备份(Secondary)服务器构成.通过Replication,将数据的 ...
- mongodb 4.0副本集搭建
近期有同学问mongodb副本集难不难部署,我的回答是不难,很快,几分钟搞定,比mysql MHA简单的不止一点半点. 那么到底如何部署呢?请看下文. 1. 准备工作 1.1 下载软件 选择版本并下 ...
- mongo副本集搭建及服务器复用方案
比较常见的mongodb副本集搭建是有:常规节点.数据副本.仲裁节点组成,也就是需要三台服务器组建.常规节点即数据的主存储节点,数据副本是主存储节点的从属节点,它定期去主节点获取更新日志来更新自己.仲 ...
随机推荐
- 个人相关API - 行驶方向判断函数
calculateDrivingDirection(newCoordinates,oldCoordinates){ let o = { direction: '', deviation:null, i ...
- Android Studio的HAXM不支持虚拟机
因为我的计算机是服务器,不支持虚拟机,所以报这个错了. 解决方式是直接连接物理手机,打开USB调试,安装驱动,运行项目即可.
- Day11 - O - Coin Game HDU - 3951
题目链接 思路:考虑第一个人取的方式: 1.每次能取的次数>= n, 一次取完 first win 2.每次能取1个,n是奇数 first win 3.一次取不完,这种情况下也分2种情况 1)s ...
- 「BJOI2018」求和
「BJOI2018」求和 传送门 观察到 \(k\) 很小而且模数不会变,所以我们直接预处理 \(k\) 取所有值时树上前缀答案,查询的时候差分一下即可. 参考代码: #include <alg ...
- 「NOIP2017」逛公园
传送门 Luogu 解题思路 考虑 \(\text{DP}\). 设 \(f[u][k]\) 表示从 \(u\) 到 \(n\) 走过不超过 \(Mindis(u, n) + k\) 距离的方案数. ...
- Ajax请求回调地狱及解决方案(promise、async和await)
谈及回调地狱发生得情况和解决办法,就必须追溯到原生ajax请求. 先列出服务器提供的数据接口: // 服务器端接口 app.get('/data1', (req, res) => { res.s ...
- 吴裕雄--天生自然HADOOP学习笔记:基本环境配置
实验目的 学习安装Java 学习配置环境变量 学习设置免密码登陆的方法 掌握Linux环境下时间同步的配置 实验原理 1.Java的安装 java是大数据的黄金语言,这和java跨平台的特性是密不可分 ...
- JuJu Beta Postmortem
JuJu demo demo 项目github地址 JuJu 设想和目标 我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? 完成基于Julia语言的NER mod ...
- Linux --xrandr command
Source: https://www.x.org/archive/current/doc/man/man1/xrandr.1.xhtml https://blog.csdn.net/syh_486_ ...
- 检测皮肤PH值、感知你的便意,健康是可穿戴设备的新风口?
在经历最初的喧嚣与疯狂后,可穿戴设备近年来有些低调和沉寂.换句话说,虽然可穿戴设备销量在持续走高,但从形态和功能上,呈现出高度一致性.这似乎也在证明着,可穿戴设备已成为寻常可见的普通产品而已.不过在迈 ...