萌新最近在对付MongoDB,因此每天都在翻官方文档,这里随便做点笔记

ReplSet 与 Sharding

ReplSet 是副本集,也就是主从集合。可以用来做负载均衡,数据热备份。副本集的配置相对简单,数据库的角色就只有主机和从机两个概念(加上仲裁机)

Sharding 是数据分片,用来做海量数据的分布式管理,也可以起到负载均衡的效果。数据分片需要配置分片服务器(3台以上sharding),路由服务器(mongos),配置服务器(config)。通常配合副本集使用做数据库集群

  • 连接副本集: mongodb://db1.example.com:27017,db1.example.com:27017,db1.example.com:27017/dbname?replicaSet=rs0&username=abc&password=123&dataSource=admin
  • 连接分片库: mongodb://mongos.example.com:27017/dbname?username=abc&password=123&dataSource=admin
  • ReadConcern WriteConcern: 用来配置从集群读写策略,根据不同场景使用来平衡集群的实用性和可靠性
  • Read Preference:配置副本集的读取策略,跟 Read Concern有区别。

Security 用户认证

创建用户必须指定角色,和用来认证这个用户的库。

db.createUser({
user: "username",
pwd: "pwd123",
roles: [
{role: "readWriteAnyDatabase", db: "admin"}
]
});

添加时指定了哪个db,在认证时必须指定这个db。一般来说全局的角色都指定到admin中,除非是单一数据库用户才指定为某个db。

在连接的时候就可以指定用户名密码和认证数据库,这样连接成功后直接可以访问需要的数据库。

Aggregation 聚合

mongodb的聚合可以达到类似mysql的分组,排序,连接等效果,主要通过管道Pipeline命令集来实现

MONGODB MANUAL - Aggregation

简单介绍几个管道操作集合命令

  • $group 最常用的分组,内容是一个json文档指定分组后的各个字段,必须提供_id字段告诉mongodb来按哪个字段分组,比如按 a,b 字段分组,c求和,d计数,那么$group应该是这样
{
aggregate: 'table',
pipeline: [
{$group: {
_id: {a:1, b:1},
total: {$sum: "$c"},
count: {$sum: 1}
}}
]
}
// 结果
// [{_id: {a: "a", b: "b"}, total: 10, count: 2}, {_id: {a: "a", b: "c"}, total: 20, count: 3}]
  • $addFields, $project 组合字段

    $addFields 可以自定义新字段,如果要在$project中使用,需要带上$
// {_id: 1, name: "aa", class:"bbb", num: [2,5,3]}
{
aggregate: 'table',
pipeline: [
{$addFields: {
totalNum: {$sum: "$num"}
}},
{$project: {
name: 1, "$totalNum": 1 // 此处需要加$
}}
]
}
// 结果
// [{_id: 1, name: "aa", totalNum: 10}]
  • $match,$limit,$skip,$count,$sort 不多介绍,看名字就知道什么意思
  • $unwind 展开

    这是个很有意思的命令,配合数组字段使用,按数组元素的每一项展开,其他字段保留。效果看起来相当于其他字段组成一个表 left join 这个数组字段
// { "_id" : 1, "item" : "ABC1", sizes: [ "S", "M", "L"] }
{
aggregate: 'table',
pipeline: [
{$unwind: "$size"}
]
}
// 结果
[
{ "_id" : 1, "item" : "ABC1", "sizes" : "S" }
{ "_id" : 1, "item" : "ABC1", "sizes" : "M" }
{ "_id" : 1, "item" : "ABC1", "sizes" : "L" }
]

可以通过配置参数达到left join , inner join , ifNull 等效果

另外,pipeline还有很多表达式操作符,可以很方便的组合使用来计算生成想要创建的新字段,随便举些例子:

  • 数学函数 $add,$abs,$log,$sqrt
  • 数组操作 $slice, $isArray
  • 数值比较 $eq, $lt
  • 非常实用的日期操作 $dateToString, $dateFromString

初用聚合格外注意

pipeline选项是一个数组

pipeline选项是一个数组

pipeline选项是一个数组

// db.aggregate()
db.collection.aggregate({
$match: {status: "1"},
$group: {_id: "$group", count: {$sum: 1}}
});// error
db.collection.aggregate([
{
$match: {status: "1"},
},{
$group: {_id: "$group", count: {$sum: 1}}
}
]);// 注意区别, $match 和 $group 是不同数组元素里的键,其他同理 db.runCommand({
aggregate: "tbname",
pipeline: [
{
$match: {status: "1"},
},{
$group: {_id: "$group", count: {$sum: 1}}
}
]
});

Command

其实mongodb的所有操作都可以通过构造一个 command document, 然后传给 runCommand 来实现

这与mongodb的设计也很一致,一切皆document.

MongoDB 深入学习 -- ReplSet,Sharding,Security,Aggregation,Command的更多相关文章

  1. NoSQL之【MongoDB】学习(三):配置文件说明

    摘要: 继上一篇NoSQL之[MongoDB]学习(一):安装说明 之后,知道了如何安装和启动MongoDB,现在对启动时指定的配置文件(mongodb.conf)进行说明,详情请见官方. 启动Mon ...

  2. Mongodb分片 学习小结

    前一篇 https://www.cnblogs.com/frx9527/p/mongodb.html 学会搭建复制集Replication之后,就可以学习分片Sharding了. 教程建议看官方文档: ...

  3. [转载]MongoDB开发学习(2)索引的基本操作

    索引能够极大的提高查询的效率.在数据库中简历索引必不可少. 在MongoDB中可以很轻松的创建索引. 默认索引_id_ 开启MongoDB服务器,创建数据库cnblogs,创建集合Users .(关于 ...

  4. 双刃剑MongoDB的学习和避坑

    双刃剑MongoDB的学习和避坑 MongoDB 是一把双刃剑,它对数据结构的要求并不高.数据通过key-value的形式存储,而value的值可以是字符串,也可以是文档.所以我们在使用的过程中非常方 ...

  5. MongoDB的学习--索引类型和属性(转)

    原文链接:MongoDB的学习--索引类型和属性 索引类型 MongDB的索引分为以下几种类型:单键索引.复合索引.多键索引.地理空间索引.全文本索引和哈希索引 单键索引(Single Field I ...

  6. MongoDB 自动分片 auto sharding

    MongoDB部署实验系列文章 MongoDB做为NoSQL数据库,最近几年持续升温,越来越多的企业都开始尝试用MongoDB代替原有Database做一些事情.MongoDB也在集群,分片,复制上也 ...

  7. mongodb数据库学习【安装及简单增删改查】

    //@desn:mongodb数据库学习 //@desn:码字不宜,转载请注明出处 //@author:张慧源  <turing_zhy@163.com> //@date:2018/08/ ...

  8. 转】MongoDB 自动分片 auto sharding

    原博文出自于: http://blog.fens.me/category/%E6%95%B0%E6%8D%AE%E5%BA%93/page/4/ 感谢! MongoDB 自动分片 auto shard ...

  9. Mongodb基础 学习小结

    MongoDB是一个基于分布式文件存储的数据库.由C++语言编写.旨在为WEB应用提供可扩展的高性能数据存储解决方案.MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能 ...

随机推荐

  1. 什么是闭包?在js中的作用是什么?

    闭包就是讲函数内部生成的变量保存到内存中,进行下次调用:也可以说函数外不可以调用函数内部的变量: 当函数内部返回一个函数时,闭包搭建了方法内部与方法外部的桥梁,使得外部也可以任意的获取到方法内部的资源 ...

  2. Linux - apache 服务

    暂时关闭 iptables 防火墙 [root@sch01ar ~]# systemctl stop iptables.service 暂时关闭 firewall 防火墙 [root@sch01ar ...

  3. Node.js实用知识点

    本文介绍如何使用nodejs 简单的HttpServer 调试nodejs 基础路由 nodejs配置开发和生产环境 nodejs核心模块一览 express用法 文件I/O nodejs模块 nod ...

  4. ECommon.Dapper 轻量级的dapper扩展

    我们都知道Dapper这个orm框架,但是我们也知道他的扩展目前没有特别好的,今天我就推荐一个轻量级的很方便使用的一个扩展叫做 ECommon.Dapper,它是ECommon的一个类库,关于ECom ...

  5. java8新特性-lambda表达式和stream API的简单使用

    一.为什么使用lambda Lambda 是一个 匿名函数,我们可以把 Lambda表达式理解为是 一段可以传递的代码(将代码像数据一样进行传递).可以写出更简洁.更灵活的代码.作为一种更紧凑的代码风 ...

  6. 对于现代开发来说,JavaScript就是一种垃圾语言(转)

    伯乐在线导读:昨天 Reddit/Programming 频道的头条热帖是一篇来自 julik live 博主的技术吐槽文,最初的英文标题是"For modern development J ...

  7. S3C6410移植u-boot

    1.首先下载u-boot(ftp://ftp.denx.de/pub/u-boot) wget ftp://ftp.denx.de/pub/u-boot/u-boot-latest.tar.bz2 2 ...

  8. 值得一做》关于数学与递推 BZOJ1002 (BZOJ第一页计划)(normal+)

    什么都不说先甩题目 Description 轮状病毒有很多变种,所有轮状病毒的变种都是从一个轮状基产生的.一个N轮状基由圆环上N个不同的基原子和圆心处一个核原子构成的,2个原子之间的边表示这2个原子之 ...

  9. Luogu 2868 [USACO07DEC]观光奶牛Sightseeing Cows

    01分数规划复习. 这东西有一个名字叫做最优比率环. 首先这个答案具有单调性,我们考虑如何检验. 设$\frac{\sum_{i = 1}^{n}F_i}{\sum_{i = 1}^{n}T_i} = ...

  10. dev 官网

    https://www.devexpress.com/Support/Center/Example/Details/E1343 <%@ Page Language="C#" ...