- 1、本文档共4页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
MongoDB 性能优化
查询操作的优化
假设我们按照时间戳查询最近发表的10 篇博客文章:
articles = db.posts.find().sort({ts:-1}); // get blog posts in reverse
time order
for (var i=0; i 10; i++) {
print(articles[i].getSummary());
}
优化#1: 创建索引
在查询条件的字段上,或者排序条件的字段上创建索引,可以显著提高执行效率:
db.posts.ensureIndex({ts:1});
优化#2: 限定返回结果条数
使用limit()限定返回结果集的大小,可以减少database server 的资源消耗,可以减少网络传输
数据量。
articles = db.posts.find().sort({ts:-1}).limit(10); // 10 results
maximum
优化#3: 只查询使用到的字段,而不查询所有字段
The blog post object may be very large, with the post text and comments embedded. Much
better performance will be achieved by selecting only the fields we need:
在本例中,博客日志记录内容可能非常大,而且还包括了评论内容(作为embeded 文档)。所
以只查询使用的字段,比查询所有字段效率更高:
articles = db.posts.find({},
{ts:1,title:1,author:1,abstract:1}).sort({ts:-1}).limit(10);
注意:如果只查询部分字段的话,不能用返回的对象直接更新数据库。下面的代码是错误的:
a_post = db.posts.findOne({}, Post.summaryFields);
a_post.x = 3;
db.posts.save(a_post); // error, exception thrown
Using the Profiler
MongoDB 有一个数据库优化工具Database Profiler,这个工具能检测数据库操作的性能。用个
工具可以发现query 或者write 操作中执行效率低的,从而针对这些操作进行优化。
优化count()查询操作
在count ()操作的查询条件字段上创建索引,可以提高效率。
db.posts.ensureIndex({author:1});
db.posts.find({author:george}).count();
Increment 操作
更新字段的值时,使用Increment 操作效率更高。Increment 操作比先查询出数据,然后修改数
据执行update 操作的效率更高。
Circular Fixed Size Collections
apped Collections 比普通Collections 的读写效率高。Capped Collections 是高效率的Collection
类型,它有如下特点:
固定大小;Capped Collections 必须事先创建,并设置大小:
db.createCollection(mycoll, {capped:true, size:100000})
Capped Collections 可以insert 和update 操作;不能delete 操作。只能用drop ()
方法删除整个Collection。
默认基于Insert 的次序排序的。如果查询时没有排序,则总是按照insert 的顺序返回。
FIFO。如果超过了Collection 的限定大小,则用FIFO 算法,新记录将替代最先insert
的记录。
Server Side Code Execution
Server-Side Processing 类似于SQL 数据库的存储过程,使用Server-Side Processing 可以减
小网络通讯的开销。
Explain
使用explain,MongoDB 显示操作的explain plan 。可以根据explain plan 进行优化。
db.collection.find(query).explain();
provides information such as the follow
您可能关注的文档
- 20121231群体遗传分析.pdf
- 20121203基于多面体描述系统的鲁棒非线性预测控制.pdf
- 20131114-房地产信托业务风控及实务探讨-徐勇平.pdf
- 20140320 李四德 一级建造师 市政公用工程管理与实务 六项全能提高班 桥梁工程结构材料与下部结构施工.pdf
- K线71式图解(黄埔操盘手内部教材).pdf
- L12SJ155 FS外模板现浇混凝土复合保温体系建筑构.pdf
- 20131206_阿朗联手Nextgen顺利完成澳大利亚首个400G数据传输现网测试.pdf
- 20140325 李四德 一级建造师 市政公用工程管理与实务 六项全能班 桥梁上部结构与管涵、箱涵施工.pdf
- 20140320-基于需求看小额信贷市场运作逻辑-何广文.pdf
- labview实时图像采集.pdf
文档评论(0)