On Mittwoch, 20. Mai 2009, Christian Koch wrote:
> [..]
> After solving all the performance issues with syslog we now made a
> stress test with memdebug enabled. Now kamailio terminates itself
> (perhaps because memory is corrupted?).


Hi Christian,


yes, this looks like the memory is corrupt, as it aparently crashes in a core function (added content from the log file), which normally should be pretty stable:


May 20 15:31:55 AmbriaSip1 /usr/local/sbin/kamailio[27684]: params (0x81677e0, 15), called from proxy.c: hostent_cpy(148)
May 20 15:31:55 AmbriaSip1 /usr/local/sbin/kamailio[27684]: params (0x81677e0, 16), returns address 0x8265b20 frag. 0x8265b08 (size=32) on 1 -th hit
May 20 15:31:55 AmbriaSip1 /usr/local/sbin/kamailio[27684]: params (0x81677e0, 4), called from proxy.c: hostent_cpy(159)
May 20 15:31:55 AmbriaSip1 /usr/local/sbin/kamailio[27684]: params (0x81677e0, 4), returns address 0x81bcbe8 frag. 0x81bcbd0 (size=4) on 1 -th hit
May 20 15:31:55 AmbriaSip1 /usr/local/sbin/kamailio[27684]: params (0x81677e0, 8), called from proxy.c: hostent_cpy(182)
May 20 15:31:55 AmbriaSip1 /usr/local/sbin/kamailio[27684]: params(0x81677e0, 0x8265b20), called from proxy.c: hostent_cpy(185)
May 20 15:31:55 AmbriaSip1 /usr/local/sbin/kamailio[27684]: freeing frag. 0x8265b08 alloc'ed from proxy.c: hostent_cpy(148)
May 20 15:31:55 AmbriaSip1 /usr/local/sbin/kamailio[27684]: params(0x81677e0, (nil)), called from proxy.c: hostent_cpy(187)
> May 20 15:31:55 AmbriaSip1 /usr/local/sbin/kamailio[27684]:
> CRITICAL:core:qm_free: bad pointer (nil) (out of memory block!) - aborting
> May 20 15:31:55 AmbriaSip1 /usr/local/sbin/kamailio[27697]:
> CRITICAL:core:receive_fd: EOF on 12
> May 20 15:31:55 AmbriaSip1 /usr/local/sbin/kamailio[27679]:
> INFO:core:handle_sigs: child process 27684 exited by a signal 6
> May 20 15:31:55 AmbriaSip1 /usr/local/sbin/kamailio[27679]:
> INFO:core:handle_sigs: core was not generated


Can you configure the kamailio server that it generates a core file? Then take a look to the backtrace where the invalid memory access was done, to verify if its really crashed in the core function, or perhaps some other parts has a problem here. Further informations: http://www.kamailio.org/dokuwiki/doku.php/troubleshooting:corefiles


> May 20 15:31:55 AmbriaSip1 /usr/local/sbin/kamailio[27679]:
> INFO:core:handle_sigs: terminating due to SIGCHLD
> May 20 15:31:55 AmbriaSip1 /usr/local/sbin/kamailio[27681]:
> INFO:core:sig_usr: signal 15 received
> May 20 15:31:55 AmbriaSip1 /usr/local/sbin/kamailio[27681]: Memory
> status (pkg):
> May 20 15:31:55 AmbriaSip1 /usr/local/sbin/kamailio[27681]: qm_status
> (0x81677e0):
> May 20 15:31:55 AmbriaSip1 /usr/local/sbin/kamailio[27681]: heap size=
> 1048576
>
> The complete output of the memory status is available here:
> https://rcpt.yousendit.com/690295962/7b39d332264f086b1bf0f134c026fad3


From the logs it seems that indeed a log of memory was allocated from the pv core. One of the main callers is pv_parse_ht_name, which is from the htable module. Not sure if this is a valid condition that it allocates that much pkg_mem, Daniel, can you perhaps take a look?


Cheers,
Henning