Created: (MODPYTHON-57) mem_cleanup throws "dictionary changed size during iterat
Web Server forum
Back To The Forum Home!Search!Private Messaging System

Web Server Talk Web Server Talk > Web Servers reviews > Apache Server configuration support > Apache Mod-Python > Created: (MODPYTHON-57) mem_cleanup throws "dictionary changed size during iterat




  Last Thread   Next Thread Next
  Show Printable Version Email this Page Subscribe to this Thread      Post New Thread    Post A Reply      

    Created: (MODPYTHON-57) mem_cleanup throws "dictionary changed size during iterat  
Shack Toms (JIRA)


View Ip Address Report This Message To A Moderator Edit/Delete Message


 
05-27-05 10:46 PM

mem_cleanup throws "dictionary changed size during iteration"
-------------------------------------------------------------

Key: MODPYTHON-57
URL: http://issues.apache.org/jira/browse/MODPYTHON-57
Project: mod_python
Type: Bug
Components: core
Versions: 3.1.4
Environment: We are running under Windows, but the problem is likely not O/S
 dependent.
Reporter: Shack Toms
Priority: Minor


The mem_cleanup routine, in Session.py, appears to have a bug that causes
python to throw "dictionary changed size during iteration".

The current code is.

def mem_cleanup(sdict):
for sid in sdict:
dict = sdict[sid]
if (time.time() - dict["_accessed"]) > dict["_timeout"]:
del sdict[sid]

The for statement should be changed to
for sid in sdict.keys():

This will first generate a list of the keys of the sdict, and will avoid the
complaint about the dictionary changing on the "del sdict[sid]" statemen
t.

The dbm_cleanup code has another approach, to use one iteration to gather
the keys to be deleted, and then have a second iteration over the gathered
keys which does the del.   Using that approach, mem_cleanup should become...

def mem_cleanup(sdict):
old = []
for sid in sdict:
dict = sdict[sid]
if (time.time() - dict["_accessed"]) > dict["_timeout"]:
old.append(sid)
for sid in old:
del sdict[sid]

This is more efficient if the number of sessions is large compared to the
number of sessions to be deleted.







[ Post a follow-up to this message ]



    Sponsored Links  




 





   All times are GMT. The time now is 06:39 PM.      Post New Thread    Post A Reply      
  Last Thread   Next Thread Next


Most Popular forums 

Forum Jump:
Rate This Thread:

Forum Rules:
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts
HTML code is OFF
vB code is ON
Smilies are ON
[IMG] code is OFF
 
Medical and Health forum | Computer Games Reviews | Graphics design forum

Back To The Top
Home | Usercp | Faq | Register