On Monday, 14 November 2011 04:42:16 Max Barry wrote: > Here is the result: > > http://pastebin.com/YDbmq84w > > This shows me: > * running the Apache benchmarking utility to generate lots of requests > * identifying a process hung in 'futex_wait' (11447) > * killing it with SEGV > * obtaining a stack trace
Thanks Max. It really seems to be a modperl problem. I think there is either something fishy with modperl_tipool_putback_base() or someone writes to a location that it doesn't own. Many of your threads block in modperl_tipool_pop() waiting for an interpreter to become available: /* block until an item becomes available */ modperl_tipool_wait(tipool); In src/modules/perl/modperl_tipool.c in function modperl_tipool_putback_base() you find these lines: if (!listp) { /* XXX: Attempt to putback something that was never there */ modperl_tipool_unlock(tipool); return; } I think the code should not return here but call abort() and dump core because if it enters the if-block it tries to push back an interpreter that was not taken from the pool. But why would someone call modperl_tipool_putback_base if not to release an interpreter. Hence the interpreter is lost. The other part of the function seems quite reasonable. So, I think modperl_tipool_putback_base() is sometimes called with a wrong data pointer and thus leaks interpreters. Can you install the symbol tables for your modperl and perhaps check the values of *tipool in the core? I think it is tipool->size == tipool->in_use == tipool->cfg->max That would explain the behavior. BTW, there are IMHO many points about the tipool implementation that can be improved. Why do we use these lists? Wouldn't it be better to allocated an array of tipool->cfg->max pointers? Or perhaps an apr_hash_t in pconf? Torsten Förtsch -- Need professional modperl support? Hire me! (http://foertsch.name) Like fantasy? http://kabatinte.net