mongodb错误tcmalloc: large alloc out of memory, printing stack and exiting解决办法
程序员文章站
2022-09-03 23:39:56
最近mongodb会经常突然挂掉,检查日志发现如下的错误:
复制代码 代码如下:
tcmalloc: large alloc 2061584302080 bytes =...
最近mongodb会经常突然挂掉,检查日志发现如下的错误:
复制代码 代码如下:
tcmalloc: large alloc 2061584302080 bytes == (nil) @
tue nov 26 17:45:04.539 out of memory, printing stack and exiting:
0xdddd81 0x6cfb4e 0x121021d 0xafcc1f 0xaf815f 0xaf8d1d 0xaf8e0f 0xaf52ae 0xaf53c9 0xb1eb11 0x8ab6a2 0x8d78ca 0x8d951d 0x8daa72 0xa80970 0xa8523c 0x9f9079 0x9fa5a3 0x6e8b88 0xdca34e
./mongod(_zn5mongo15printstacktraceerso+0x21) [0xdddd81]
./mongod(_zn5mongo14my_new_handlerev+0x3e) [0x6cfb4e]
./mongod(_znwm+0x6d) [0x121021d]
./mongod(_znst6vectorin5mongo18documentsourcesort9keyanddocesais2_ee7reserveem+0x6f) [0xafcc1f]
./mongod(_zn5mongo18documentsourcesort12populatetopkev+0x6f) [0xaf815f]
./mongod(_zn5mongo18documentsourcesort8populateev+0x2d) [0xaf8d1d]
./mongod(_zn5mongo18documentsourcesort3eofev+0xf) [0xaf8e0f]
./mongod(_zn5mongo18documentsourceskip7skipperev+0x6e) [0xaf52ae]
./mongod(_zn5mongo18documentsourceskip3eofev+0x9) [0xaf53c9]
./mongod(_zn5mongo8pipeline3runerns_14bsonobjbuildererss+0x1b1) [0xb1eb11]
./mongod(_zn5mongo15pipelinecommand3runerkssrns_7bsonobjeirssrns_14bsonobjbuildereb+0x132) [0x8ab6a2]
./mongod(_zn5mongo12_execcommandepns_7commanderkssrns_7bsonobjeirssrns_14bsonobjbuildereb+0x3a) [0x8d78ca]
./mongod(_zn5mongo7command11execcommandeps0_rns_6clienteipkcrns_7bsonobjerns_14bsonobjbuildereb+0x71d) [0x8d951d]
./mongod(_zn5mongo12_runcommandsepkcrns_7bsonobjerns_11_bufbuilderins_16trivialallocatoreeerns_14bsonobjbuilderebi+0x5f2) [0x8daa72]
./mongod(_zn5mongo11runcommandsepkcrns_7bsonobjerns_5curoperns_11_bufbuilderins_16trivialallocatoreeerns_14bsonobjbuilderebi+0x40) [0xa80970]
./mongod(_zn5mongo8runqueryerns_7messageerns_12querymessageerns_5curopes1_+0xd7c) [0xa8523c]
./mongod() [0x9f9079]
./mongod(_zn5mongo16assembleresponseerns_7messageerns_10dbresponseerkns_11hostandporte+0x383) [0x9fa5a3]
./mongod(_zn5mongo16mymessagehandler7processerns_7messageepns_21abstractmessagingportepns_9lasterrore+0x98) [0x6e8b88]
./mongod(_zn5mongo17portmessageserver17handleincomingmsgepv+0x42e) [0xdca34e]
内存溢出了,一开始我以为是有些排序没有加索引,后来一些地方加了索引后还是会出现,细想了下,如果是没加索引的话,是不会让整个mongodb宕机的。
后来在mongodb的issue上查到了这样一条提交的bug清单server-10136(https://jira.mongodb.org/browse/server-10136)。
原来aggregation如果传递一个$skip特别大的值的时候,就会内存溢出。我看到这个bug已经被修复了,不过是在2.5.2版本,最新的稳定版是2.4.8。所以我们需要在自己的应用程序里面控制,让$skip的值不要超出总长。