Hi Daniel,After apply your patch i noticed the following situations:When i restart my external application kamailio prints the following logs:Then when kamailio starts sending/receiving events to/from external application it breaks(stops) and prints the following logs:edge-sip-proxy[13581]: INFO: ESP_LOG: 123: [evapi:connection-closed] EVAPI 127.0.0.1:52906 connection has been closed
edge-sip-proxy[13581]: CRITICAL: ESP_LOG: 123: <core> [core/mem/q_malloc.c:514]: qm_free(): BUG: freeing already freed pointer (0x7f0ab9914a88), called from core: core/parser/parse_via.c: free_via_list(2738), first free core: core/parser/parse_via.c: free_via_list(2738) - ignoring
edge-sip-proxy[13581]: CRITICAL: ESP_LOG: 123: <core> [core/mem/q_malloc.c:514]: qm_free(): BUG: freeing already freed pointer (0x7f0ab99103c0), called from core: core/parser/hf.c: free_hdr_field_lst(217), first free core: core/parser/hf.c: free_hdr_field_lst(217) - ignoring
edge-sip-proxy[13581]: INFO: ESP_LOG: 123: evapi [evapi_dispatch.c:381]: evapi_recv_client(): client closing connection - pos [0] addr [127.0.0.1:52906]
edge-sip-proxy[13581]: INFO: ESP_LOG: 123: [evapi:connection-new] New EVAPI connection from 127.0.0.1:52980
edge-sip-proxy[13581]: CRITICAL: ESP_LOG: 123: <core> [core/mem/q_malloc.c:514]: qm_free(): BUG: freeing already freed pointer (0x7f0ab9914a88), called from core: core/parser/parse_via.c: free_via_list(2738), first free core: core/parser/parse_via.c: free_via_list(2738) - ignoring
edge-sip-proxy[13581]: CRITICAL: ESP_LOG: 123: <core> [core/mem/q_malloc.c:514]: qm_free(): BUG: freeing already freed pointer (0x7f0ab99103c0), called from core: core/parser/hf.c: free_hdr_field_lst(217), first free core: core/parser/hf.c: free_hdr_field_lst(217) - ignoring
edge-sip-proxy[13571]: INFO: ESP_LOG: 7-32554@10.225.121.206: FUZECI1-x1006 registered
edge-sip-proxy[13581]: INFO: ESP_LOG: 123: [evapi:connection-received] EVAPI msg received -> {"aor":"sip:FUZECI1-x1000@uc.fuze.domain","contact":"<sip:FUZECI1-x1000@10.225.121.206:5060;transport=UDP>;expires=172800"}
edge-sip-proxy[13581]: CRITICAL: ESP_LOG: 123: <core> [core/parser/hf.c:200]: clean_hdr_field(): BUG: unknown header type 1885958972
kernel: traps: edge-sip-proxy[13581] general protection ip:6a8dac sp:7ffdebb1a8b0 error:0 in kamailio[400000+460000]
edge-sip-proxy[13589]: CRITICAL: <core> [core/pass_fd.c:277]: receive_fd(): EOF on 27
edge-sip-proxy[13567]: ALERT: <core> [main.c:756]: handle_sigs(): child process 13581 exited by a signal 11
edge-sip-proxy[13567]: ALERT: <core> [main.c:759]: handle_sigs(): core was not generated
edge-sip-proxy[13567]: INFO: <core> [main.c:781]: handle_sigs(): terminating due to SIGCHLD
edge-sip-proxy[13573]: INFO: ESP_LOG: 317f64550726afacb315390fd37ece05: <core> [main.c:836]: sig_usr(): signal 15 received
edge-sip-proxy[13568]: INFO: <core> [main.c:836]: sig_usr(): signal 15 received
edge-sip-proxy[13576]: INFO: <core> [main.c:836]: sig_usr(): signal 15 received
edge-sip-proxy[13571]: INFO: <core> [main.c:836]: sig_usr(): signal 15 received
edge-sip-proxy[13577]: INFO: <core> [main.c:836]: sig_usr(): signal 15 received
edge-sip-proxy[13579]: INFO: ESP_LOG: 123: <core> [main.c:836]: sig_usr(): signal 15 received
edge-sip-proxy[13572]: INFO: ESP_LOG: 0dcb5707418c4142-13572@10.225.121.128: <core> [main.c:836]: sig_usr(): signal 15 received
edge-sip-proxy[13575]: INFO: <core> [main.c:836]: sig_usr(): signal 15 received
edge-sip-proxy[13582]: INFO: <core> [main.c:836]: sig_usr(): signal 15 received
edge-sip-proxy[13583]: INFO: <core> [main.c:836]: sig_usr(): signal 15 received
edge-sip-proxy[13578]: INFO: ESP_LOG: 123: <core> [main.c:836]: sig_usr(): signal 15 received
edge-sip-proxy[13580]: INFO: ESP_LOG: 123: <core> [main.c:836]: sig_usr(): signal 15 received
edge-sip-proxy[13586]: INFO: <core> [main.c:836]: sig_usr(): signal 15 received
edge-sip-proxy[13584]: INFO: <core> [main.c:836]: sig_usr(): signal 15 received
edge-sip-proxy[13585]: INFO: <core> [main.c:836]: sig_usr(): signal 15 received
edge-sip-proxy[13570]: INFO: <core> [main.c:836]: sig_usr(): signal 15 received
edge-sip-proxy[13587]: INFO: <core> [main.c:836]: sig_usr(): signal 15 received
edge-sip-proxy[13569]: INFO: <core> [main.c:836]: sig_usr(): signal 15 received
edge-sip-proxy[13588]: INFO: <core> [main.c:836]: sig_usr(): signal 15 received
edge-sip-proxy[13574]: INFO: <core> [main.c:836]: sig_usr(): signal 15 received
edge-sip-proxy[13589]: INFO: <core> [main.c:836]: sig_usr(): signal 15 received
edge-sip-proxy[13567]: INFO: <core> [core/sctp_core.c:53]: sctp_core_destroy(): SCTP API not initialized
Best RegardsJosé SeabraDaniel-Constantin Mierla <miconda@gmail.com> escreveu no dia quinta, 15/08/2019 à(s) 07:36:Hello,
can you try with master branch? The issue should be fixed by the commit:
* https://github.com/kamailio/kamailio/commit/d36a4b00c6becd42cfcec4fc7eb398371e1cc812
If works ok, then I will backport to stable branches.
Cheers,
Daniel
On 14.08.19 12:19, José Seabra wrote:
Hello,Please find out the logs in the following link:Let me know if you need something else.
Cheers
José Seabra
Daniel-Constantin Mierla <miconda@gmail.com> escreveu no dia quarta, 14/08/2019 à(s) 10:59:
Hello,
that's memory status, printing details for each allocated chunk. I could spot a lot of chunks from the parser and get header field functions, but to be sure there is nothing else, can you set global parameter:
mem_summary=12
and then reproduce again. The logs printed in syslog should have smaller size, giving the summary of allocated chunks - how many times and the size for each location in the code.
Cheers,
Daniel
On 14.08.19 11:51, José Seabra wrote:
Hello Daniel,Please find out the attached zip file with the output pkg_summary.
Let me know if you need something else.
Thank you for your support
CheersJosé Seabra
Daniel-Constantin Mierla <miconda@gmail.com> escreveu no dia quarta, 14/08/2019 à(s) 10:03:
Hello,
can you enable pkg summary and generate it once the out of memory happens?
Set memlog to lower value than debug, when the memory happens, do:
https://www.kamailio.org/docs/modules/devel/modules/corex.html#corex.rpc.pkg_summary
Then send some traffic to that process and watch the syslog.
Alternative, enable memory summary via core parameter and stop kamailio when the errors happen, but you will get summary for all processes, so it might be harder to extract those log messages related the evapi process.
Cheers,
Daniel
On 14.08.19 10:37, José Seabra wrote:
Hello there,I'm using kamailio 5.2.1 with evapi module to send and receive events from an external application.During my stress tests to kamailio i have been noticing that at some point kamailio is getting out of memory:
edge-sip-proxy[20565]ERROR: ESP_LOG: <null>: <core> [core/mem/q_malloc.c:291]: qm_find_free(): qm_find_free(0x7fb8730b6010, 64); Free fragment not found!
edge-sip-proxy[20565]: ERROR: ESP_LOG: <null>: <core> [core/mem/q_malloc.c:425]: qm_malloc(): qm_malloc(0x7fb8730b6010, 64) called from core: core/parser/msg_parser.c: parse_headers(325), module: core; Free fragment not found!
edge-sip-proxy[20565]: ERROR: ESP_LOG: <null>: <core> [core/parser/msg_parser.c:328]: parse_headers(): memory allocation error
edge-sip-proxy[20565]: ERROR: ESP_LOG: <null>: pv [pv_core.c:704]: pv_get_callid(): cannot parse Call-Id header
edge-sip-proxy[20565]: INFO: ESP_LOG: <null>: [evapi:connection-received] EVAPI msg received -> {"aor":"sip:FUZECI1-x1516@uc.fuze.domain","contact":"<sip:FUZECI1-x1516@10.225.121.206:5060;transport=UDP>"}
edge-sip-proxy[20565]: ERROR: ESP_LOG: <null>: <core> [core/mem/q_malloc.c:291]: qm_find_free(): qm_find_free(0x7fb8730b6010, 64); Free fragment not found!
edge-sip-proxy[20565]: ERROR: ESP_LOG: <null>: <core> [core/mem/q_malloc.c:425]: qm_malloc(): qm_malloc(0x7fb8730b6010, 64) called from core: core/parser/msg_parser.c: parse_headers(325), module: core; Free fragment not found!
The process id 20565 is running out of memory as you can see bellow:
output of kamcmd pkg.stats
entry: 14
pid:
rank: -2
used: 6058696
free: 824
real_used: 8387784
total_size: 8388608
total_frags: 30
This process ID is related with Evapi Dispatcher
kamcmd ps | grep 20565
20565 EvAPI Dispatcher
After stop the sipp that was generating traffic to kamailio the evapi process still have all the memory consumed
Can it be some memory leak in Evapi module?
Best RegardsJosé Seabra--
CumprimentosJosé Seabra
_______________________________________________ Kamailio (SER) - Users Mailing List sr-users@lists.kamailio.org https://lists.kamailio.org/cgi-bin/mailman/listinfo/sr-users-- Daniel-Constantin Mierla -- www.asipto.com www.twitter.com/miconda -- www.linkedin.com/in/miconda
--
CumprimentosJosé Seabra-- Daniel-Constantin Mierla -- www.asipto.com www.twitter.com/miconda -- www.linkedin.com/in/miconda
--
CumprimentosJosé Seabra-- Daniel-Constantin Mierla -- www.asipto.com www.twitter.com/miconda -- www.linkedin.com/in/miconda--CumprimentosJosé Seabra