[IronPython] Memory Leak in IronPython 2.6 RC3
Dino Viehland
dinov at microsoft.com
Mon Nov 30 20:26:50 CET 2009
Glad that worked, I've opened this bug to track fixing this:
http://ironpython.codeplex.com/WorkItem/View.aspx?WorkItemId=25478
> -----Original Message-----
> From: users-bounces at lists.ironpython.com [mailto:users-
> bounces at lists.ironpython.com] On Behalf Of Jonathan Howard
> Sent: Wednesday, November 25, 2009 9:45 AM
> To: users at lists.ironpython.com
> Subject: Re: [IronPython] Memory Leak in IronPython 2.6 RC3
>
> That looks like it's removing that memory leak. I'm not positive
> that's the one we're having in our production code, but it certainly
> can't hurt.
>
> On Nov 25, 5:37 am, Dino Viehland <di... at microsoft.com> wrote:
> > My guess here (I'm on vacation so I haven't tried this) is that some
> exception info
> > is not getting cleared -
> >
> > ExceptionHelpers.DynamicStackFrames = null;
> >
> > In the catch block will probably fix it although we should probably
> > do this ourselves.
> >
> >
> >
> >
> >
> > > -----Original Message-----
> > > From: users-boun... at lists.ironpython.com [mailto:users-
> > > boun... at lists.ironpython.com] On Behalf Of Jonathan Howard
> > > Sent: Tuesday, November 24, 2009 4:45 PM
> > > To: us... at lists.ironpython.com
> > > Cc: jfelk... at drawloop.com
> > > Subject: [IronPython] Memory Leak in IronPython 2.6 RC3
> >
> > > I'm trying to track down a memory leak in our hosted IronPython
> > > application as we upgrade to 2.6 from 1.1.2. I saw a post at
> > > stackoverflow (http://stackoverflow.com/questions/1664567/embedded-
> > > ironpython-memory-leak
> > > ) showing how to set up the environment to avoid leaking memory, but
> > > we're still having a memory leak. If I take our identical setup code,
> > > and use it on very simple code, there's no problem, but we have
> > > thousands of lines of Python at this point.
> >
> > > Below is a minimum way to introduce a memory leak inside a hosted
> > > IronPython application. I don't know if it's the only way, or if it's
> > > what's affecting us, but it does cause a leak: (Obviously it needs
> > > the appropriate DLLs etc.)
> >
> > > #############################################
> >
> > > using System;
> > > using System.Threading;
> > > using IronPython.Hosting;
> > > using IronPython.Runtime;
> > > using IronPython.Compiler;
> > > using System.Collections.Generic;
> > > using Microsoft.Scripting.Hosting;
> >
> > > namespace IPyTest
> > > {
> > > class Program
> > > {
> > > static void Main(string[] args)
> > > {
> > > bool cont = true;
> > > while (cont)
> > > {
> > > var ipy = new IPy();
> > > try
> > > {
> > > // Set the below boolean to "false" to run without
> > > a memory leak
> > > // Set it to "true" to run with a memory leak.
> > > ipy.run(true);
> > > }
> > > catch { }
> > > }
> > > }
> > > }
> >
> > > class IPy
> > > {
> > > private string scriptWithoutLeak = "import random;
> > > random.randint(1,10)";
> > > private string scriptWithLeak = "raise Exception(), 'error'";
> >
> > > public IPy()
> > > {
> > > }
> >
> > > public void run(bool withLeak)
> > > {
> > > //set up script environment
> > > Dictionary<String, Object> options = new
> > > Dictionary<string, object>();
> > > options["LightweightScopes"] = true;
> > > ScriptEngine engine = Python.CreateEngine(options);
> > > PythonCompilerOptions pco = (PythonCompilerOptions)
> > > engine.GetCompilerOptions();
> > > pco.Module &= ~ModuleOptions.Optimized;
> > > engine.SetSearchPaths(new string[]{
> > > @"C:\Program Files\IronPython 2.6\Lib"
> > > });
> > > ScriptRuntime runtime = engine.Runtime;
> > > ScriptScope scope = runtime.CreateScope();
> > > var source = engine.CreateScriptSourceFromString(
> > > withLeak ? scriptWithLeak : scriptWithoutLeak
> > > );
> > > var comped = source.Compile();
> > > comped.Execute(scope);
> > > runtime.Shutdown();
> > > }
> > > }
> > > }
> > > _______________________________________________
> > > Users mailing list
> > > Us... at lists.ironpython.com
> > >http://lists.ironpython.com/listinfo.cgi/users-ironpython.com
> >
> > _______________________________________________
> > Users mailing list
> > Us... at lists.ironpython.comhttp://lists.ironpython.com/listinfo.cgi/users-
> ironpython.com
> _______________________________________________
> Users mailing list
> Users at lists.ironpython.com
> http://lists.ironpython.com/listinfo.cgi/users-ironpython.com
More information about the Ironpython-users
mailing list