【NoSql】MongoDb
【NoSql】MongoDb
一. 文档
1. 官网
2. C# Driver
3. C# 开发文档
二. 命令
1. --config "C:\mongodb\mongod.cfg" 设置 config 文件, 推荐通过设置配置文件来启动mongod
三. 可视化管理工具
四. 注意点(与 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的更多相关文章
- 【转】MongoDB资料汇总专题
1.MongoDB是什么 MongoDB介绍PPT分享 MongoDB GridFS介绍PPT两则 初识 MongoDB GridFS MongoDB GridFS 介绍 一个NoSQL与MongoD ...
- 【NoSql】Redis
[NoSql]Redis 一. 文档 1. 官网 2. Windows 安装包 3. C# Driver a. ServiceStack.Redis 最新版本是收费的 b. StackExchange ...
- 【vue】MongoDB+Nodejs+express+Vue后台管理项目Demo
¶项目分析 一个完整的网站服务架构,包括: 1.web frame ---这里应用express框架 2.web server ---这里应用nodejs 3.Database ---这里 ...
- 【八】MongoDB管理之分片集群实践
MongoDB中集群有三种:主从复制.副本集.分片集群.目前副本集已经替代主从复制架构,成为官方建议采用的架构,而分片集群相较于前两种,更加复杂. 下面是生产环境中常用的分片集群架构: 我们知道,分片 ...
- 【七】MongoDB管理之分片集群介绍
分片是横跨多台主机存储数据记录的过程,它是MongoDB针对日益增长的数据需求而采用的解决方案.随着数据的快速增长,单台服务器已经无法满足读写高吞吐量的需求.分片通过水平扩展的方式解决了这个问题.通过 ...
- 【四】MongoDB索引管理
一.索引介绍 在mongodb中,索引用来支持高效查询.如果没有索引,mongodb必须在整个集合中扫描每个文档来查找匹配的文档.但是如果建立合适的索引,mongodb就可以通过索引来限制检查的文档数 ...
- 【原创】MongoDB安装配置详解(标注两个坑)
1.下载安装 3.4正式版([坑]不要最新版,有可能进度卡在这个位置不动,等了半个小时也没什么反映,) http://downloads.mongodb.org/win32/mongodb-win32 ...
- 【转】PHP操作MongoDB【NoSQL】
原文:http://blog.sina.com.cn/s/blog_4b67d3240101519b.html 一.MongoDB简介 MongoDB (名称来自"humongous&quo ...
- 【翻译】MongoDB指南/聚合——聚合管道
[原文地址]https://docs.mongodb.com/manual/ 聚合 聚合操作处理数据记录并返回计算后的结果.聚合操作将多个文档分组,并能对已分组的数据执行一系列操作而返回单一结果.Mo ...
随机推荐
- git的基础介绍和使用
git工作原理 git的工作原理还是比较简单的,当我们创建了本地代码仓库后,会在本地代码仓库的根目录中生成一个.git的隐藏文件. .git为一个文件目录,又叫做版本库.在本地代码仓库文件夹中,除.g ...
- New Begin--工作一年所思所感小记
有段日子没有更新Blog了,这段时间过得有些散漫,今天看完了两本书,感触颇多,让我繁杂的心绪又重归平静,想写一些什么,遂有了这篇文章. 所谓的一年是从13年7月9日我正是入职算起,到现在为止一年有余, ...
- 【HEVC】4、HM-16.7编码一个CU(帧内部分) 3.帧内预测各种模式实现
HEVC中一共定义了35中帧内编码预测模式,编号分别以0-34定义.其中模式0定义为平面模式(INTRA_PLANAR),模式1定义为均值模式(INTRA_DC),模式2~34定义为角度预测模式(IN ...
- openscales实现漂亮的冒泡效果
使用的时候openscales 默认的冒泡效果确实有点简陋,想实现那种看着比较舒服的效果,只能自己定义了.参考现有的openscales实现的方式,它是通过控件的状态实现的,每个状态中使用Path绘制 ...
- Android的各种Drawable 讲解 大全
Android把可绘制的对象抽象为Drawable,不同的图形图像资源就代表着不同的drawable类型.Android FrameWork提供了一些具体的Drawable实现,通常在代码中都不会直接 ...
- Android自动化学习笔记之MonkeyRunner:用Eclipse执行MonkeyRunner脚本
Info: 初步学习,难免会有疏漏,以后我会不断修改补全,直到完美.转载请注明出处,谢谢. 2014-10-11: 初版 2014-10-16: 完善 ------------------------ ...
- CSS3按钮鼠标悬浮光圈效果
1 .HTML相关知识点 HTML(超文本标记语言)是网页的核心.首先你要学会,不要害怕,HTML很容易学习的,刚开始多记多练,但是到最后还是要自己深入专研,简单的入门是很快,但学好HTML是成为W ...
- 原生js事件和jquery事件的执行顺序问题
场景:近日,写前端页面时候,在针对输入框input操作时,用到了jquery的插件,插件中使用了jquery的focus()和blur()方法.但是同时,又需要在插件之外再针对输入框的获取焦点和失去焦 ...
- Docker Day1 & 2
1. Docker Basic 安装docker(在/etc/selinux/config文件中设置selinux=disabled,否则安装时会报错) curl -ssL http://get.do ...
- 冲刺一 (Day 3)
冲刺一 (Day 3) 用户表 uid int 8 用户ID username varchar 20 用户名 password varchar 20 密码 email varchar 30 邮箱 ph ...