MongoDB性能优化.pdfVIP

  1. 1、本文档共4页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 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

文档评论(0)

wangshirufeng + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档