V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐工具
RoboMongo
推荐书目
50 Tips and Tricks for MongoDB Developers
Related Blogs
Snail in a Turtleneck
gkiwi
V2EX  ›  MongoDB

mongodb 又"卡"死了,该如何下手找问题呢?

  •  
  •   gkiwi · 2014-07-12 14:24:23 +08:00 · 5611 次点击
    这是一个创建于 3787 天前的主题,其中的信息可能已经有所发展或是发生改变。
    自己机子上有个mongo,平时拿来练习,但是今天又"卡"死了,之前有过一次,重启就解决了.但是这次很想知道原因;
    相关配置(其他都是默认了):
    ####
    dbpath = /var/mongodata/db
    logpath = /var/mongodata/mongodb.log
    port = 27017
    logappend = true

    其他都是默认的,top看,mongo使用正常.看了下mongodb.log,最近关闭的是第#13个连接(因为是今早上刚启动的,所以也不大可能是链接数量到达最大),mongo和mongostat连接都"卡"住,并没有报错.

    请教各位,我该如何定位和解决这个问题呢?
    ####
    mongod verson: v2.6.1
    os: osx10.9.2
    7 条回复    2014-07-14 05:16:56 +08:00
    pbys2004
        1
    pbys2004  
       2014-07-12 15:55:44 +08:00 via iPhone   ❤️ 1
    mongo的库多大,有可能是在没有索引的属性上进行了扫表查询。建一个索引试试
    gkiwi
        2
    gkiwi  
    OP
       2014-07-12 16:13:38 +08:00
    @pbys2004 才几十兆,应该不是索引之类的问题,因为数据也就是自己抓了点网页,数据很少~
    darklowly
        3
    darklowly  
       2014-07-12 20:33:10 +08:00
    机器时间对么?
    dalang
        4
    dalang  
       2014-07-12 22:59:12 +08:00   ❤️ 1
    有个比较常见的坑是mongodb使用数据库级的锁,在写数据的时候要快,否则很容易把其他mongodb的请求阻塞。你可以尝试在mongodb起来的时候是就开起mongostat,然后查看locked%和qr|qw列的值是否出现异常,飙升。
    还有如果collection中记录很多的话,一定要建立索引。你可以直接在mongo shell下验证你的查询是否有用到索引,我记得mongo语句后跟explain()可以显示索引是否起作用的。
    gkiwi
        5
    gkiwi  
    OP
       2014-07-13 02:01:17 +08:00
    @darklowly 时间对的,都是本地的时间.而且时间应该不会有这些影响把...
    gkiwi
        6
    gkiwi  
    OP
       2014-07-13 02:02:30 +08:00
    @dalang 谢谢,学习了.下次我开个事先就开个mongostat试试.
    darklowly
        7
    darklowly  
       2014-07-14 05:16:56 +08:00   ❤️ 1
    @gkiwi 我之前遇到过一台电脑,主板电池没有了,重启后,时间不对,然后会卡死,这个时候mongod进程的CPU会很高
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1058 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 19:19 · PVG 03:19 · LAX 11:19 · JFK 14:19
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.