delorie.com/archives/browse.cgi   search  
Mail Archives: cygwin/2007/10/03/00:31:23

X-Recipient: archive-cygwin AT delorie DOT com
X-Spam-Check-By: sourceware.org
Date: Wed, 3 Oct 2007 00:31:01 -0400
From: Christopher Faylor <cgf-use-the-mailinglist-please AT cygwin DOT com>
To: cygwin AT cygwin DOT com
Subject: Re: Huge memory leak, probably related to making new processes
Message-ID: <20071003043101.GA2486@ednor.casa.cgf.cx>
Reply-To: cygwin AT cygwin DOT com
Mail-Followup-To: cygwin AT cygwin DOT com
References: <13006193 DOT post AT talk DOT nabble DOT com> <fdudpa$anu$1 AT sea DOT gmane DOT org> <13010714 DOT post AT talk DOT nabble DOT com> <loom DOT 20071003T040816-588 AT post DOT gmane DOT org>
MIME-Version: 1.0
In-Reply-To: <loom.20071003T040816-588@post.gmane.org>
User-Agent: Mutt/1.5.16 (2007-06-09)
Mailing-List: contact cygwin-help AT cygwin DOT com; run by ezmlm
List-Id: <cygwin.cygwin.com>
List-Unsubscribe: <mailto:cygwin-unsubscribe-archive-cygwin=delorie DOT com AT cygwin DOT com>
List-Subscribe: <mailto:cygwin-subscribe AT cygwin DOT com>
List-Archive: <http://sourceware.org/ml/cygwin/>
List-Post: <mailto:cygwin AT cygwin DOT com>
List-Help: <mailto:cygwin-help AT cygwin DOT com>, <http://sourceware.org/ml/#faqs>
Sender: cygwin-owner AT cygwin DOT com
Mail-Followup-To: cygwin AT cygwin DOT com
Delivered-To: mailing list cygwin AT cygwin DOT com

On Wed, Oct 03, 2007 at 04:20:18AM +0000, Lewis Hyatt wrote:
>> Anyway, can I ask you to do this yourself - just do the last test:
>> 
>> COUNTER=1
>> while [ $COUNTER -lt 123456 ]; do (echo $COUNTER); let COUNTER=$COUNTER+1;
>> done 
>> 
>> and wait a little (couple of minutes). If necessary, repeat it until your
>> memory drops to 10-20 MB range and your HDD should start whining. Then close
>> cygwin and wait 10 minutes. The memory is still "occupied". I don't know
>> when Windows would free it, but I did not get that behavior with any other
>> program (e.g. try to open & close Firefox or such - it will show a peak in
>> both directions regarding memory and will do that almost immediately).
>> 
>> Thanks for the note.
>
>I ran it for about 15 minutes, no problem.
>
>In general, you should be wary of what Task Manager is telling you. In this
>example, it doesn't make sense to me that memory could leak, because each of the
>(echo) processes is executing in a subshell, which terminates after completion.
>No matter what a process does in Windows, its memory is always returned when it
>terminates, unless it is doing something very unusual. (But, of course, cygwin's
>fork() does do something unusual...) You could try running some simple c++
>program, after it looks like your memory is exhausted, to allocate 1 GB of
>memory, and see if it succeeds. When it returns, the OS will probably report
>more free memory. This was the basis of some scam-ish "RAM cleaner" programs
>that really didn't do anything other than make Task Manager's output look nicer.
>
>That said, you are also describing some real symptoms of a problem, such as
>exhausting the physical memory and swapping. That should not occur, so there may
>be some problem that's beyond my experience. (In your example, I would have said
>that maybe the disk thrashing you experienced was caused by find itself, but if
>you also see it just from running this subshell loop, that is strange.) I guess
>it could be something going wrong with fork(), etc, that someone else on the
>list might know about. They'll probably ask you to check all the usual suspects
>first... are there any firewalls, AV scanners, etc, running in the background?
>If so, try getting rid of all of them and see if the problem still occurs. There
>are some poorly written ones that have been known to interfere with cygwin. Hope
>that helps...

I've been waiting for someone to make the observation that Cygwin has no
magic powers which allow it to allocate memory and never release it -
even on process exit.  No modern OS allows you to get away with that.

If the OP is really seeing that then either there is something else on his
system which is responsible for the behavior.  The other alternative is
misunderstanding of what is going on.  I'd say that it was probably
50/59 which is the case here.

cgf

--
Unsubscribe info:      http://cygwin.com/ml/#unsubscribe-simple
Problem reports:       http://cygwin.com/problems.html
Documentation:         http://cygwin.com/docs.html
FAQ:                   http://cygwin.com/faq/

- Raw text -


  webmaster     delorie software   privacy  
  Copyright © 2019   by DJ Delorie     Updated Jul 2019