【NoSql】MongoDb

一. 文档

1. 官网

2. C# Driver

3. C# 开发文档

二. 命令

1. --config "C:\mongodb\mongod.cfg" 设置 config 文件, 推荐通过设置配置文件来启动mongod

三. 可视化管理工具

1. robomongo 源码

四. 注意点(与 Sql Server 的不同点)

1. _id Mongo 的主键,建议自己维护该字段(可用自增或Guid),查询条件已该字段为主以提供性能。

2. Mongo 是区分大小写的,这个要格外注意

3. 修改字段时,如果字段不存在则会新增字段

五. 适用场景

1. 插入

2. 完全命中索引的查询,更新,删除

3. 不适用 全文索引

六. 性能测试

1. 环境 : 系统 Win10, CPU i5-5257U 2.70GHz, 内存 8G, 硬盘 APPLE SSD SM0128G

2. 插入:

  a. 数据准备:实体 包含6个字段,_id 自增,4个string类型内容30个随机中文,一个随机int

  b. 每次插入10w条,单线程循环100次

  c. 结果 : 平均耗时:3.887秒

         IO占用:11M(注没有跑满)

         内存占用 : 3.8G(注没有跑满,不过增长不是线性的,内部应该有内存控制)

         CPU : 占用不多

         硬件资源没有跑满,多线程下总耗时会下降但单个耗时会上升

3. 查询总量:

  a. 单线程循环100次

  b. 结果 :平均耗时 : 1毫秒

        应该插入和删除时内部有字段来标志总数,所以查询时不需要全表扫描,直接返回标志

4. 查询按 _id :

  a. 随机生成1000w以内的数字,以此为条件查询,单线程循环100次

b. 结果 :平均耗时 : 1毫秒

5. 查询分页(Skip+Limit)

  a. 以 _id 排序,随机生成页数,每页100条数据,单线程循环100次

  b. 结果 :页数越大,耗时越高

        页数 10 : 平均耗时 5 毫秒

        页数 100: 平均耗时 28 毫秒

        页数 1000: 平均耗时 225 毫秒

        页数 10000: 平均耗时 1965 毫秒

6. 查询分页(Maxid+Limit)

  a. 以 _id 排序,随机生成 Maxid ,以此为判断条件,每页100条数据,单线程循环100次

  b. 结果 :平均耗时 2 毫秒

        比 (Skip + Limit)的性能高非常多,且耗时不会随着页数增大而增大

        不过需要把上一次查询的最大 _id 作为条件且 _id 为 int 类型

7. 删除

  a. 随机生成_id ,以此为判断条件,单线程循环100次

  b. 结果 : 平均耗时 1 毫秒

8. 更新

  a. 随机生成实体,以此实体的 _id 为判断条件,单线程循环100次

  b. 结果 : 平均耗时 1 毫秒

9. 结论 :

  a. 完全命中 _id 索引的操作都是非常快的,都在毫秒级

  b. 对硬件的要求, 对 CPU 要求不高, 硬盘 10M 写入以上, 内存 越高越好

      

【NoSql】MongoDb的更多相关文章

  1. 【转】MongoDB资料汇总专题

    1.MongoDB是什么 MongoDB介绍PPT分享 MongoDB GridFS介绍PPT两则 初识 MongoDB GridFS MongoDB GridFS 介绍 一个NoSQL与MongoD ...

  2. 【NoSql】Redis

    [NoSql]Redis 一. 文档 1. 官网 2. Windows 安装包 3. C# Driver a. ServiceStack.Redis 最新版本是收费的 b. StackExchange ...

  3. 【vue】MongoDB+Nodejs+express+Vue后台管理项目Demo

    ¶项目分析 一个完整的网站服务架构,包括:   1.web frame ---这里应用express框架   2.web server ---这里应用nodejs   3.Database ---这里 ...

  4. 【八】MongoDB管理之分片集群实践

    MongoDB中集群有三种:主从复制.副本集.分片集群.目前副本集已经替代主从复制架构,成为官方建议采用的架构,而分片集群相较于前两种,更加复杂. 下面是生产环境中常用的分片集群架构: 我们知道,分片 ...

  5. 【七】MongoDB管理之分片集群介绍

    分片是横跨多台主机存储数据记录的过程,它是MongoDB针对日益增长的数据需求而采用的解决方案.随着数据的快速增长,单台服务器已经无法满足读写高吞吐量的需求.分片通过水平扩展的方式解决了这个问题.通过 ...

  6. 【四】MongoDB索引管理

    一.索引介绍 在mongodb中,索引用来支持高效查询.如果没有索引,mongodb必须在整个集合中扫描每个文档来查找匹配的文档.但是如果建立合适的索引,mongodb就可以通过索引来限制检查的文档数 ...

  7. 【原创】MongoDB安装配置详解(标注两个坑)

    1.下载安装 3.4正式版([坑]不要最新版,有可能进度卡在这个位置不动,等了半个小时也没什么反映,) http://downloads.mongodb.org/win32/mongodb-win32 ...

  8. 【转】PHP操作MongoDB【NoSQL】

    原文:http://blog.sina.com.cn/s/blog_4b67d3240101519b.html 一.MongoDB简介 MongoDB (名称来自"humongous&quo ...

  9. 【翻译】MongoDB指南/聚合——聚合管道

    [原文地址]https://docs.mongodb.com/manual/ 聚合 聚合操作处理数据记录并返回计算后的结果.聚合操作将多个文档分组,并能对已分组的数据执行一系列操作而返回单一结果.Mo ...

随机推荐

  1. cocos2dx day 3 - Chapter5 Scene

    写在前面 越来越懒了,才3天,主要是cocos2dx官网的文章写的还是不是太完美,发现一段代码有个笔误,还有好几处写得不是很清楚的,所以有点泄气,不想继续读下去,不过为了我的第一款手游,一切困难都要先 ...

  2. C语言获得文件一行

    C语言获得一行的数据还是比较麻烦的,这里讲一下几种曾经用过的方法. 第一种,是最笨的方法,就是一个一个字符的读取,也是最容易想到的方法.具体实现如下:void   read_line(char   l ...

  3. php-工厂模式(Factory Method)解析

    关于工厂模式,首先要了解的就是多态这个概念:“多态是指在面向对象中能够根据使用类的上下文来重新定义或改变类的性质和行为”,这句话是我在其他博客看到,他已经概括的很好了,我就直接抄袭了.哈哈 通常简单工 ...

  4. shell return value

  5. swiper

    <!DOCTYPE html><html lang="en"><head> <meta charset="utf-8" ...

  6. OpenGL ES 中的模板测试

    模板测试的主要功能是丢弃一部分片元,相对于深度检测来说,模板测试提出的片元数量相对较少.模板测试发生在剪裁测试之后,深度测试之前. 使用模板测试时很重要的代码提示: 1.glClear( GL_STE ...

  7. Java日志——2016年5月30日

    1. 局部变量必须初始化,可以定义的同时初始化,也可以定义完成之后进行初始化. 2. Java7新特性:数字之间可以使用"_"连接,eg:23_44_5 = 23445,0B110 ...

  8. iOS原型模式

    原型模式:大部分重复,只有一小部分不同的情况下,为了代码清晰和避免麻烦,用原型模式,会更方便一点 // 学生1 StudentModel *stu1 = [[StudentModel alloc] i ...

  9. NRF51822之IIC(MEMS_LIS2DH12)

    在上篇介绍了OLED的II以写操作为主,没有进行读取操作.所以在现再补充读取的操作. 我在此以LIS2DH为例子 uint8_t temp; lis2dh_read_registers(LIS2DH_ ...

  10. openssl生成rsa密钥对和密钥格式转换

    首先要下载安装好openssl,下载地址:https://www.openssl.org/source/,安装完成后可以进到命令行运行以下命令: 1. 生成私钥: openssl genrsa -ou ...