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副本集搭建是有:常规节点.数据副本.仲裁节点组成,也就是需要三台服务器组建.常规节点即数据的主存储节点,数据副本是主存储节点的从属节点,它定期去主节点获取更新日志来更新自己.仲 ...
随机推荐
- 笔记||Python3进阶之装饰器
# 装饰器# 特征: 是用一个@开头的字符串# 装饰器通常用来装饰函数.或者类的方法# 被装饰后的函数,通常是在原有的函数基础上,会多出增加一点功能# 一般来说装饰器本身也是一个函数## def te ...
- python 网络爬虫(二)
一.编写第一个网络爬虫 为了抓取网站,我们需要下载含有感兴趣的网页,该过程一般被称为爬取(crawling).爬取一个网站有多种方法,而选择哪种方法更加合适,则取决于目标网站的结构. 首先探讨如何安全 ...
- cookie、sessionStorage和localStorage的区别
cookie.sessionStorage.localStorage 都是用于本地存储的技术:其中 cookie 出现最早,但是存储容量较小,仅有4KB:sessionStorage.localSto ...
- 吴裕雄 Bootstrap 前端框架开发——Bootstrap 表格:上下文类
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- request-html
目录 基本使用 获取链接( links 与 absolute_links ) CSS 选择器与 XPATH 支持 JavaScript 自定义 User-Agent 模拟表单提交(POST) asyn ...
- 【剑指Offer面试编程题】题目1511:从尾到头打印链表--九度OJ
题目描述: 输入一个链表,从尾到头打印链表每个节点的值. 输入: 每个输入文件仅包含一组测试样例. 每一组测试案例包含多行,每行一个大于0的整数,代表一个链表的节点.第一行是链表第一个节点的值,依次类 ...
- PHP 获取一周的时间
$date = array( 'Monday' => array(date('Y-m-d H:i:s',strtotime("Monday")),date('Y-m-d H: ...
- python 开启http服务并下载文件
Python <= 2.3python -c "import SimpleHTTPServer as s; s.test();" 8000 Python >= 2.4p ...
- Day1-Luogu-2085
题目描述 有n个函数,分别为F1,F2,...,Fn.定义Fi(x)=Ai*x^2+Bi*x+Ci (x∈N*).给定这些Ai.Bi和Ci,请求出所有函数的所有函数值中最小的m个(如有重复的要输出多个 ...
- Springboot项目的接口防刷(实例)
技术要点:springboot的基本知识,redis基本操作, 首先是写一个注解类: import java.lang.annotation.Retention; import java.lang.a ...