2004-08-16 19:20:53 +00:00
|
|
|
# -*- coding: iso-8859-1 -*-
|
2005-01-19 15:08:02 +00:00
|
|
|
"""
|
|
|
|
|
Copied from the Python Cookbook recipe at
|
|
|
|
|
http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/286222
|
2004-08-16 19:20:53 +00:00
|
|
|
|
2005-01-19 15:08:02 +00:00
|
|
|
To find the memory usage in a particular section of code these
|
2005-01-19 15:56:48 +00:00
|
|
|
functions are typically used as follows::
|
2004-08-16 19:20:53 +00:00
|
|
|
m0 = memory()
|
|
|
|
|
...
|
|
|
|
|
m1 = memory(m0)
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
import os
|
|
|
|
|
|
|
|
|
|
_proc_status = '/proc/%d/status' % os.getpid()
|
|
|
|
|
|
|
|
|
|
_scale = {'kB': 1024.0, 'mB': 1024.0*1024.0,
|
|
|
|
|
'KB': 1024.0, 'MB': 1024.0*1024.0}
|
|
|
|
|
|
|
|
|
|
def _VmB (VmKey):
|
2008-04-27 11:39:21 +00:00
|
|
|
"""Parse /proc/<pid>/status file for given key.
|
2005-01-18 01:00:45 +00:00
|
|
|
|
2005-01-19 15:56:48 +00:00
|
|
|
@return: requested number value of status entry
|
|
|
|
|
@rtype: float
|
2005-01-18 01:00:45 +00:00
|
|
|
"""
|
2004-08-16 19:20:53 +00:00
|
|
|
if os.name != 'posix':
|
|
|
|
|
# not supported
|
|
|
|
|
return 0.0
|
|
|
|
|
global _proc_status, _scale
|
|
|
|
|
# get pseudo file /proc/<pid>/status
|
|
|
|
|
try:
|
|
|
|
|
t = open(_proc_status)
|
|
|
|
|
v = t.read()
|
|
|
|
|
t.close()
|
|
|
|
|
except IOError:
|
|
|
|
|
# unsupported platform (non-Linux?)
|
|
|
|
|
return 0.0
|
|
|
|
|
# get VmKey line e.g. 'VmRSS: 9999 kB\n ...'
|
|
|
|
|
i = v.index(VmKey)
|
|
|
|
|
v = v[i:].split(None, 3) # whitespace
|
|
|
|
|
if len(v) < 3:
|
|
|
|
|
return 0.0 # invalid format?
|
|
|
|
|
# convert Vm value to bytes
|
|
|
|
|
return float(v[1]) * _scale[v[2]]
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def memory (since=0.0):
|
2008-04-27 11:39:21 +00:00
|
|
|
"""Get memory usage.
|
2005-01-18 01:00:45 +00:00
|
|
|
|
|
|
|
|
@return: memory usage in bytes
|
2005-01-19 15:56:48 +00:00
|
|
|
@rtype: float
|
2005-01-18 01:00:45 +00:00
|
|
|
"""
|
2004-08-16 19:20:53 +00:00
|
|
|
return _VmB('VmSize:') - since
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def resident (since=0.0):
|
2008-04-27 11:39:21 +00:00
|
|
|
"""Get resident memory usage.
|
2005-01-18 01:00:45 +00:00
|
|
|
|
|
|
|
|
@return: resident memory usage in bytes
|
2005-01-19 15:56:48 +00:00
|
|
|
@rtype: float
|
2005-01-18 01:00:45 +00:00
|
|
|
"""
|
2004-08-16 19:20:53 +00:00
|
|
|
return _VmB('VmRSS:') - since
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def stacksize (since=0.0):
|
2008-04-27 11:39:21 +00:00
|
|
|
"""Get stack size.
|
2005-01-18 01:00:45 +00:00
|
|
|
|
|
|
|
|
@return: stack size in bytes
|
2005-01-19 15:56:48 +00:00
|
|
|
@rtype: float
|
2005-01-18 01:00:45 +00:00
|
|
|
"""
|
2004-08-16 19:20:53 +00:00
|
|
|
return _VmB('VmStk:') - since
|