mongodb笔记(一) 分片 &&文档连接
版本:mongodb3.4 ;
分片:
工作顺序:router=>config=>shards
一,配置config:
3.4中config必须为replSet。下面配置两个config。
mongod --configsvr -dbpath= .. -logpath=.. replSet=myConfig -port=3001 --fork;
mongod --configsvr -dbpath=.. -logpaht=.. replSet=myConfig -port=3002 --fork;
进入config,mongo --port 3001,配置副本集:
var config={
_id:'myConfig',
configsvr:true,
memeber:[{_id:0,host:155.155.1.104:3001}, {_id:0,host:155.155.1.104:3002}]
}
rs.initiate(config);
官方建议三个,我们这里只有两个。host,不能为127.0.0.1,或者localhost。所以我配置为局域网的地址了。
二,配置shard:
mongod --shardsvr dbpath=.. -logpath=.. -port=4001 -nojournal --fork
mongod --shardsvr dbpath=.. -logpath=.. -port=4002 -nojournal --fork
生存环境下建议shard为replSet,这里姑且就为mongod吧
三,配置router:
mongos -configdb=myConfig/155.155.1.104:3001,155.155.1.104:3002 -port=3000
将config副本集写进去
四,定义shard:
进入mongos :
mongo -host=155.155.1.104 -port=3000
use admin;
添加分片:
sh.addShard( '155.155.1.104:4001'); sh.addShard('155.155.1.104:4002');
激活一个db:
sh.enableSharding('test');
为该db中的collection添加规则:
sh.shardCollection('test.collection1',{_id:'hashed'})
文档连接:
文档引用
官方使用的方法,将一个document 的field指向另一个document的_id。
树形结构:
子定义一个parent。父定义一个children。将子父的一个filed放入其中。可以建立索引。更遥远的可以定义ancestor。
树形路径:
定义document的一个filed为string型 ',path,path1,path2'。根据树形结构,写放路径。
二叉树路径:
每个document,拥有一个left,right为number型。根据left,right和二叉树结构,可以遍历其子document。
数据引用:
将document的一个filed定义为DBRef,其结构如下:
creator:{
$ref: //指向collection; =》namespace //在node.js中获得DBRef时,所对应的属性。
$db: //指向db; =》db
$id: //指向collection.document._id; =》 oid
}
mongodb does not support joins。
介绍下mongoose population:
连接两个文档,并通过父文档find子文档的属性:
var parentSchema=new Schema({
name:String,
children:{type:Schema.Types.ObjectId, ref:'children'}
})
var childSchema=new Schema({
name:String
})
// 在父schema中定义children,指向子document的_id,使用ref指向该collection。
//下面是创建这两个document,分别在parent和children这两个collection中。
var parentModel=mongoose.model('parent',parentSchema);
var childrenModel=mongoose.model('children',childSchema);
var childOne=new ChildrenModel({ name : ' B' });
childOne.save(val=>{
(new parentModel({
name:' A',
children:childOne._id
})) .save();
})
//这样就将两个document分别写入其各自的collection 中了。
//下面是使用他们;
parentModel.findOne({name:'A'}).populate('children') //populate 中的值为parentSchema的children属性.
.exec((err,doc)=>{
console.log(doc.children.name); //show 'B'
})
update:
parentModel.findOne({name:'A'}).populate('children')
.exec((err,doc)=>{
doc.children= ...; //重新指定一个document。可以是document._id。也可以直接传递document
doc.save(callback);
})
很遗憾的是不能通过doc.children.name='';doc.save();这种方式来更改children document内的属性。
动态连接:
var parentSchem=new Schema({
name:String,
children:[ {
kind:String,
item:{type:ObjectId , refPath: 'children.kind '} } ]
})
//refPath指向children.kind。通过kind的值,来定义类似之前ref的值;
//使用:
parentMode.findOne({name:'A'}).populate('children.item').exec()
ref的值是不能直接更改的。所以通过更改kind的值,可以更改连接的子文档。
mongodb笔记(一) 分片 &&文档连接的更多相关文章
- MongoDB改动、删除文档的域属性实例
MongoDB改动.删除文档的域属性实例 在站点的开发中,可能最初的设计不合理.或者后期业务的变更,会造成文档结构会有些无用的属性.须要去删除或改动.因为MongoDB 是无 Schema 的,不像关 ...
- MongoDB,无模式文档型数据库简介
MongoDB的名字源自一个形容词humongous(巨大无比的),在向上扩展和快速处理大数据量方面,它会损失一些精度,在旧金山举行的MondoDB大会上,Merriman说:“你不适宜用它来处理复杂 ...
- mongodb查询内嵌文档
mongodb查询内嵌文档 假设有这样一个文档: db.XXX.remove(); db.XXX.insert({"id":1, "members":[{& ...
- Spring Data MongoDB 四:基本文档改动(update)(一)
Spring Data MongoDB 三:基本文档查询(Query.BasicQuery)(一) 学习MongoDB 二:MongoDB加入.删除.改动 一.简单介绍 Spring Data Mo ...
- Spring Data MongoDB 五:进阶文档查询(分页、Morphia)(二)
Spring Data MongoDB 三:基本文档查询(Query.BasicQuery)(一) 学习MongoDB 六: MongoDB查询(游标操作.游标信息)(三) 一.简单介绍 Spring ...
- MongoDB和Redis-NoSQL数据库-文档型-内存型
1NoSQL简述 CAP(Consistency,Availabiity,Partitiontolerance)理论告诉我们,一个分布式系统不可能满足一致性,可用性和分区容错性这三个需求,最多只能同时 ...
- Mongodb 笔记07 分片、配置分片、选择片键、分片管理
分片 1. 分片(sharding)是指将数据拆分,将其分散存放在不同的机器上的过程.有时也用分区(partitioning)来表示这个概念.将数据分散到不同的机器上,不需要功能强大的大型计算机就可以 ...
- MongoDB学习(查找文档和其他数据查找操作)
理解Cursor对象和查询运算符 cursor对象 cursor对象相当于一个指针,可通过迭代它来访问MongdoDB数据库中的一组对象. 在使用 find() 方法查询时,返回的并非实际文档,而是一 ...
- Spring Data MongoDB 三:基本文档查询(Query、BasicQuery)(一)
一.简单介绍 Spring Data MongoDB提供了org.springframework.data.mongodb.core.MongoTemplate对MongoDB的CRUD的操作,上一 ...
随机推荐
- 12.php中无比坑爹的构造函数。
当你在php类中,写一个构造方法时,记得,一定要用__这是两个下划线,而不是一个.......... <?php class Car { // function _construct() { / ...
- buffer/interger overflow /return-to-libc攻击实验
buffer/interger overflow /return-to-libc攻击实验 http://blog.sina.com.cn/s/blog_70dd16910100rdgn.html ht ...
- wget -d --header
wget -d --header="Host:www.sina.com" http://202.108.33.84 domain differ ip 防止Wget递归下载 假设Ng ...
- Redis的Python客户端redis-py说明文档(转)
add by zhj: 对Publish / Subscribe,LUA Scripting,Sentinel support,Scan Iterators等部分没有翻译,需要的用户参见英文原文吧.另 ...
- Python生成器是什么
生成器是 Python 初级开发者最难理解的概念之一,虽被认为是 Python 编程中的高级技能,但在各种项目中可以随处见到生成器的身影,你得去理解它.使用它.甚至爱上它. 提到生成器,总不可避免地要 ...
- exp导出一个表中符合查询条件的数据
原文地址:exp导出一个表中符合查询条件的数据 作者:charsi 导出一个表中的部分数据,使用QUERY参数,如下导出select * from test where object_id>50 ...
- python中decorator的用法及原理(一)
0. 概念 什么叫装饰器,其实也可以叫做包装器.即对于一个既有的函数func(args),在调用它之前和之后,我们希望都做一些事情,把这个函数包装起来. Python中的装饰器分为两类:函数装饰器和类 ...
- 爬虫任务一:使用httpclient去爬取百度新闻首页的新闻标题和url,编码是utf-8
第一个入手的爬虫小任务: maven工程 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi=" ...
- 简明python教程二-----对象
物理行:是你在编写程序时所看见的. 逻辑行:是Python看见的单个语句. 默认的,python希望每行都只使用一个语句,这样使得代码更加易读. 如果你想要在一个物理行中使用多于一个逻辑行,用分号“: ...
- oradebug工具使用(转载)
在之前的HangAnalyze 中有使用oradebug命令,在这篇文章里,我们主要是重点看一下这个oradebug命令: Oracle HANGANALYZE 功能诊断 DB hanging htt ...