mongodb  索引建立问题

1.主从库索引建立不是同步建立:

MONGODB 2.6.6 版本,索引建立并不是同步的,而是主库建立完成后,从库接着建立索引。
    不知是3.0版本是否也一样,以前使用3.0版本也没去监控主从日志情况。这坑太大了。
    5:00开始建立,以为主库完成即OK.

官方说明:
        Background index build (page 491) allowed on secondaries. If you initiate a background index build on a
        primary, the secondaries will replicate the index build in the background.

Automatic rebuild of interrupted index builds after a restart.
        – If a standalone or a primary instance terminates during an index build without a clean shutdown, mongod
        now restarts the index build when the instance restarts. If the instance shuts down cleanly or if a user kills
        the index build, the interrupted index builds do not automatically restart upon the restart of the server.
        – If a secondary instance terminates during an index build, the mongod instance will now restart the interrupted index build when the instance restarts.
        To disable this behavior, use the --noIndexBuildRetry command-line option.

从库建立索引太长时间,如果中断从库建立索引,可以使用 --noIndexBuildRetry  参数重启。
    开始不知还有这个参数,直接在主库中删除前面建立的索引了。

网上看到别人是这样处理的,感觉也不错:

1.首先把 secondary server 停止,在取消 --replSet 参数,并且更改 MongoDB port 之后重新启动 MongoDB,这时候 MongoDB 将进入 standalone 模式;

2.在 standalone 模式下运行命令 ensureIndex 建立索引,建议使用 foreground 方式运行;

3.建立索引完毕之后关闭 secondary server 按正常方式启动;

下面是日志

primary:

2015-12-17T07:46:53.074+0800 [conn5530345]              Index Build(background): 27309700/27314911      99%
    。。。

slave:

2015-12-17T07:46:54.985+0800 [repl index builder 14]     building index in background
        2015-12-17T07:46:55.529+0800 [conn2154798] killcursors  keyUpdates:0 numYields:0 locks(micros) r:73 167ms
        2015-12-17T07:46:58.226+0800 [repl index builder 14]            Index Build(background): 4700/27314911  0%

2.TTL 索引删除数据,不是一次性删除超出日期的数据,而是一点点来的,

也是一样,以前一直以为是索引建立后,TTL 删除数据是一次性操作,那里知道几个小时也没删除完成,导致数据库
    压力一直很高。

后来只好先改名,再建立好新表后把数据插入进去。
    db.WebLog.renameCollection("WebLog_bak");
    db.WebLog.ensureIndex({MallID:1,Mac:1});
    db.WebLog.ensureIndex({CreateTime:-1},{expireAfterSeconds:3600*24*3*30});

var cursor=db.WebLog_bak.find({_id:{$gte:24600000}});
    while (cursor.hasNext()){
      nc=cursor.next();
      db.WebLog.insert(nc);
    };

mongodb 索引建立问题相关推荐

  1. mongodb 索引建立问题

    mongodb  索引建立问题 1.主从库索引建立不是同步建立: MONGODB 2.6.6 版本,索引建立并不是同步的,而是主库建立完成后,从库接着建立索引.     不知是3.0版本是否也一样,以 ...

  2. 使用NOSQL的MongoDB时建立索引需要注意的几点建议和Explain优化分析

    第一,MongoDB索引和MySQL索引非常相似并且对于MySQL的索引优化有很多也适用于MongoDB. 第二,更重要的是,这些索引的建议对你的应用提高也是有限的. 对于应用的最佳索引策略应该基于很 ...

  3. MongoDB · 引擎特性 · MongoDB索引原理

    MongoDB · 引擎特性 · MongoDB索引原理 数据库内核月报 原文链接 http://mysql.taobao.org/monthly/2018/09/06/ 为什么需要索引? 当你抱怨M ...

  4. MongoDB索引实战技巧

    为什么80%的码农都做不了架构师?>>>    本文内容源自Kyle Banker 的 MongoDB In Action一书.主要描述了MongoDB索引相关的一些基础知识和使用技 ...

  5. MongoDB 索引-9

    MongoDB 索引 索引通常能够极大的提高查询的效率,如果没有索引,MongoDB在读取数据时必须扫描集合中的每个文件并选取那些符合查询条件的记录. 这种扫描全集合的查询效率是非常低的,特别在处理大 ...

  6. MongoDB索引原理和具体使用

    1. MongoDB 索引是用来干嘛? 索引通常能够极大的提高查询的效率,如果没有索引,MongoDB在读取数据时必须扫描集合中的每个文件并选取那些符合查询条件的记录. 这种扫描全集合的查询效率是非常 ...

  7. MongoDB索引策略和索引类型

    1. MongoDB索引策略和索引类型–简介 MongoDB是一个开放源代码,面向文档的跨平台数据库,它使用C ++开发,并且是最流行和使用最广泛的NoSQL类型数据库之一. 它可在具有键-值对的类J ...

  8. 学习 | MongoDB 索引和排序

    小小又开始学习了,这次学习的内容是索引和排序. 索引 先给users集合插入两条记录,然后用users集合来进行索引管理的演示: > user1={"name":" ...

  9. MongoDB 索引(一)

    索引支持在MongoDB中高效执行查询.如果没有索引,MongoDB必须执行集合扫描,即扫描集合中的每个文档,以选择那些匹配查询语句的文档.如果查询存在适当的索引,MongoDB可以使用该索引来限制它 ...

最新文章

  1. 设计模式:行为型模式(2)
  2. Android中实现照片滑动时左右进出的动画的xml代码
  3. 透明位图的显示(TransparentBlt函数)
  4. 运算符重载(加减运算符、前置加加(减减)后置加加(减减)运算符、赋值运算符、输入输出运算符、关系运算符、函数调用)
  5. Scala 学习笔记
  6. H5|web移动前端自适应适配布局解决方案
  7. jQuery 拖拽窗体
  8. 送给程序员们的经典电子书大礼包
  9. shell基础之shell相关概念
  10. c语言头文件和函数库,C语言的头文件和库文件(函数库)
  11. 高频变压器漆包线规格的确定
  12. Robo3T操作MongoDB数据库常用命令
  13. Pr入门系列之十一:基本图形(上)
  14. 概念二 python3 中子类继承父类
  15. 何时需要对时间序列进行Log Transformation
  16. 电驴服务器更新的作用,怎样更新eMule(电驴)服务器列表,有什么好处?
  17. Unity各类数据库的基本操作(三)-- JSON
  18. 0103 混蛋罗心得[装*技巧]
  19. 如何使用Java制作网课搜题软件?我来教你,so easy
  20. 8/14 二维高斯函数

热门文章

  1. python网络编程——实现简单聊天
  2. SQLite FTS3/FTS4与一些使用心得
  3. 栈和队列----用栈求解汉诺塔问题
  4. jspservlet初体验——用户登录功能实现
  5. iOS常见问题(5)
  6. Ubuntu 12.10 安装 JDK1.7.0_15
  7. CSS 使网页变灰(文字加动画)
  8. django数据查询之聚合查询和分组查询
  9. SDWebImage 加载Https自签名证书时的图片问题
  10. 建站手册-语义网:语义网