Hi
SITUATION - On a production APP Server having about 4000 Concurrent application
processes ,
the memory allocated does NOT seem to be getting freed even though the application
program is issuing the respective call to Free the memory .
Qs Any /etc/system parameters , OS patches which should help ?
Qs Is our approach of using the pmap command Correct ?
else what Command to find the "Private" memory taken up by a process would be
advisable ?
Qs How to find the Total Amount of Swap Consumed ?
[ We probably do NOT know how to interpret the vmstat output Correctly ,
top/swap -s commands show an output Differing greatly from df -k output for /tmp
filesystem ]
Qs Any Body has encountered such as situation before ?
Configuration -
Solaris 2.8
Patch - Generic 108528-16 patch
Machine SF15K
CPUs = 36
RAM = 96 GB
We created a Small Sample C program which allocates & FREEs memory but found that even
after
FREEing , the memory does NOT show as Freed in the pmap output . Is the following
approach correct ?
DETAILS :-
@@@@@@@@@@@@@@@@@ SAMPLE C PROGRAM @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
#include <stdio.h>
main()
{
char *abc = NULL ;
int i = 0 ;
for (i = 1; i < 10; i++){
printf("allocating [%d] bytes\n", 10*1024*(i+1));
abc = (char *)malloc(10*1024*(i+1));
memset(abc, '\0', 10*1024*(i+1));
getchar();
free(abc);
printf("Freeing [%d]\n", i);
getchar();
}
exit() ;
}
@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
RUN Output :-
STEP 1 - allocating [20480] bytes
pmap -x <PID of Above program process>
Address Kbytes Resident Shared Private Permissions Mapped File
00010000 8 8 8 - read/exec a.out
00020000 8 8 - 8 read/write/exec a.out
00022000 24 24 - 24 read/write/exec [ heap ]
FF280000 688 688 688 - read/exec libc.so.1
FF33C000 32 32 - 32 read/write/exec libc.so.1
FF370000 16 16 16 - read/exec libc_psr.so.1
FF390000 8 8 8 - read/exec libdl.so.1
FF3A0000 8 8 - 8 read/write/exec [ anon ]
FF3B0000 152 152 152 - read/exec ld.so.1
FF3E6000 8 8 - 8 read/write/exec ld.so.1
FFBEC000 16 16 - 16 read/write/exec [ stack ]
-------- ------ ------ ------ ------
total Kb 968 968 872 96
THE "Private" memory allocated by the [ heap ] is 24 K
STEP 2 - Freeing the memory allocated in the above Step
Freeing [1]
pmap -x <PID of Above program process>
Address Kbytes Resident Shared Private Permissions Mapped File
00022000 24 24 - 24 read/write/exec [ heap ]
RESULT - THE "Private" memory allocated previously does NOT get Freed &
[ heap ] continues to be 24 K
STEP 3 -
allocating [30720] bytes
pmap -x <PID of Above Program process>
Address Kbytes Resident Shared Private Permissions Mapped File
00022000 32 32 - 32 read/write/exec [ heap ]
STEP 4 - Freeing the memory allocated in the above Step
Freeing [2]
pmap -x <PID of Above program process>
Address Kbytes Resident Shared Private Permissions Mapped File
00022000 32 32 - 32 read/write/exec [ heap ]
RESULT - THE "Private" memory allocated previously in Step 3 does NOT get Freed &
[ heap ] continues to be 32 K
Thanks
--
Please see the official ORACLE-L FAQ: http://www.orafaq.net
--
Author: VIVEK_SHARMA
INET: [EMAIL PROTECTED]
Fat City Network Services -- 858-538-5051 http://www.fatcity.com
San Diego, California -- Mailing list and web hosting services
---------------------------------------------------------------------
To REMOVE yourself from this mailing list, send an E-Mail message
to: [EMAIL PROTECTED] (note EXACT spelling of 'ListGuru') and in
the message BODY, include a line containing: UNSUB ORACLE-L
(or the name of mailing list you want to be removed from). You may
also send the HELP command for other information (like subscribing).