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

2014-07-12 14:24:23 +08:00
 gkiwi
自己机子上有个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
5526 次点击
所在节点    MongoDB
7 条回复
pbys2004
2014-07-12 15:55:44 +08:00
mongo的库多大,有可能是在没有索引的属性上进行了扫表查询。建一个索引试试
gkiwi
2014-07-12 16:13:38 +08:00
@pbys2004 才几十兆,应该不是索引之类的问题,因为数据也就是自己抓了点网页,数据很少~
darklowly
2014-07-12 20:33:10 +08:00
机器时间对么?
dalang
2014-07-12 22:59:12 +08:00
有个比较常见的坑是mongodb使用数据库级的锁,在写数据的时候要快,否则很容易把其他mongodb的请求阻塞。你可以尝试在mongodb起来的时候是就开起mongostat,然后查看locked%和qr|qw列的值是否出现异常,飙升。
还有如果collection中记录很多的话,一定要建立索引。你可以直接在mongo shell下验证你的查询是否有用到索引,我记得mongo语句后跟explain()可以显示索引是否起作用的。
gkiwi
2014-07-13 02:01:17 +08:00
@darklowly 时间对的,都是本地的时间.而且时间应该不会有这些影响把...
gkiwi
2014-07-13 02:02:30 +08:00
@dalang 谢谢,学习了.下次我开个事先就开个mongostat试试.
darklowly
2014-07-14 05:16:56 +08:00
@gkiwi 我之前遇到过一台电脑,主板电池没有了,重启后,时间不对,然后会卡死,这个时候mongod进程的CPU会很高

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/122292

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX