[Kamailio-Devel] [ openser-Bugs-2050115 ] pkg memory management

SourceForge.net noreply at sourceforge.net
Wed Dec 3 11:16:39 CET 2008


Bugs item #2050115, was opened at 2008-08-13 21:17
Message generated for change (Comment added) made by spgle
You can respond by visiting: 
https://sourceforge.net/tracker/?func=detail&atid=743020&aid=2050115&group_id=139143

Please note that this message will contain a full copy of the comment thread,
including the initial issue submission, for this request,
not just the latest update.
Category: core
Group: ver 1.3.x
Status: Open
Resolution: None
Priority: 5
Private: No
Submitted By: Antanas Masevicius (zoltran)
Assigned to: Nobody/Anonymous (nobody)
Summary: pkg memory management

Initial Comment:
performing contact dumps from in memory with such commands as:

# openserctl ul show
or
# openserctl online

produces error:

> Aug 11 17:25:06 test /usr/sbin/openser[15267]: DBG:mi_fifo:mi_parse_node:
end of input tree
> Aug 11 17:25:06 test /usr/sbin/openser[15267]:
DBG:mi_fifo:mi_fifo_server: done parsing the mi tree
> Aug 11 17:25:06 test /usr/sbin/openser[15267]: ERROR:core:add_mi_attr: no
more pkg mem (24)
> Aug 11 17:25:06 test /usr/sbin/openser[15267]:
ERROR:mi_fifo:mi_fifo_server: command (ul_dump) processing failed

this comes out after 20 days of openser-1.3.2 operation with couple of
thausands of contacts.

--
Antanas Masevicius
email: antanas.masevicius at ntt.lt

----------------------------------------------------------------------

Comment By: Laurent Glayal (spgle)
Date: 2008-12-03 11:16

Message:
We are facing the same problem on an old openser-1.2.0 with compile options
:
Makefile.defs :
 DEFS+= $(extra_defs) \
         -DNAME='"$(MAIN_NAME)"' -DVERSION='"$(RELEASE)"'
-DARCH='"$(ARCH)"' \
         -DOS='"$(OS)"' -DCOMPILER='"$(CC_VER)"' -D__CPU_$(ARCH)
-D__OS_$(OS) \
         -D__SMP_$(ISSMP) -DCFG_DIR='"$(cfg-target)"'\
         -DPKG_MALLOC \
         -DSHM_MEM  -DSHM_MMAP \
         -DUSE_IPV6 \
         -DUSE_MCAST \
         -DUSE_TCP \
         -DDISABLE_NAGLE \
         -DHAVE_RESOLV_RES \
         -DSTATISTICS \
         -DF_MALLOC \
         #-DDBG_QM_MALLOC \
         #-DDBG_F_MALLOC \
         #-DNO_DEBUG \
         #-DNO_LOG \
         #-DVQ_MALLOC  \
         #-DDBG_LOCK \
         #-DNOSMP \
         #-DEXTRA_DEBUG \
         #-DUSE_SHM_MEM

And config.h :
/*used only if PKG_MALLOC is defined*/
#define PKG_MEM_POOL_SIZE 1024*1024

/*used if SH_MEM is defined*/
#define SHM_MEM_SIZE 32

If it can give a clue ....

----------------------------------------------------------------------

Comment By: Nobody/Anonymous (nobody)
Date: 2008-10-29 22:30

Message:
Hi, 

after compiling with -DQM_JOIN_FREE and running for a month or so i
started getting the same errors as noted in my original submission. I guess
not much improvement here. Still, ill try running latest 1.4.2 after i test
it in my testbed and post results then. Are there (in 1.4.2) any changes
related to this problem, or should i try disabling  PKG_MALLOC before
trying?



----------------------------------------------------------------------

Comment By: Nobody/Anonymous (nobody)
Date: 2008-09-12 12:16

Message:
Hi henningw,

still monitoring situation. I was still not able to recompile with that
flag, because of production system uptime requiremts, but im still planning
to do that. I'll post results as soon as i will be able to determine
outcome. 


Antanas
NTT 


----------------------------------------------------------------------

Comment By: Henning Westerholt (henningw)
Date: 2008-09-12 11:24

Message:
Hi Antanas,

any updates on this? Thanks,

Henning

----------------------------------------------------------------------

Comment By: Henning Westerholt (henningw)
Date: 2008-09-02 17:12

Message:
Logged In: YES 
user_id=337916
Originator: NO

Hi Antanas,

any updates for this bug, does the recompile with the QM_JOIN_FREE helped
you?

BTW, If you're really adventurous (and have a good QA process) then you
could also try to recompile without PKG_MALLOC defined. The server will
then be use the system malloc instead of the fixed size pool (you need to
use a recent branch for this, i did a fix for this case). Performance will
probably be somewhat worse, but you if you then still problems with
fragmentation, you need to blame the linux kernel/ glibc. :-)

Henning

----------------------------------------------------------------------

Comment By: Daniel-Constantin Mierla (miconda)
Date: 2008-08-14 08:47

Message:
Logged In: YES 
user_id=1246013
Originator: NO

Try compile with -DQM_JOIN_FREE and see if you run in same situation. You
can add that define in Makefile.defs, there is a section where the defines
are listed.

----------------------------------------------------------------------

Comment By: Nobody/Anonymous (nobody)
Date: 2008-08-14 08:39

Message:
Logged In: NO 

hello miconda,

i've been running "openserctl online | wc" pretty frequently. Lets say
from 50 to 100 times in that pediod. 

--
Antanas Masevicius
email: antanas.masevicius at ntt.lt

----------------------------------------------------------------------

Comment By: Henning Westerholt (henningw)
Date: 2008-08-14 00:26

Message:
Logged In: YES 
user_id=337916
Originator: NO

Hi,

if i remember correctly, Dan also reported this problem some times ago on
the devel list. Perhaps we really should investigate to get rid of this
pkg_mem pool, and replace it with plain malloc.. 

In the meantime its probably possible to work around/ delay this problem
by increasing the pkg memory pool size, or i'm wrong? 

Henning

----------------------------------------------------------------------

Comment By: Daniel-Constantin Mierla (miconda)
Date: 2008-08-13 23:46

Message:
Logged In: YES 
user_id=1246013
Originator: NO

this might be memory fragmentation. How many times you run openserctl ul
show in this period?

----------------------------------------------------------------------

You can respond by visiting: 
https://sourceforge.net/tracker/?func=detail&atid=743020&aid=2050115&group_id=139143



More information about the Devel mailing list