# Copyright 2011-2015 Lars Wirzenius # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program. If not, see <http://www.gnu.org/licenses/>. # # =*= License: GPL-3+ =*= import gc import logging import os import platform import time class MemoryProfileDumper(object): def __init__(self, settings): self.settings = settings self.last_memory_dump = 0 self.memory_dump_counter = 0 self.started = time.time() def dump_memory_profile(self, msg): '''Log memory profiling information. Get the memory profiling method from the dump-memory-profile setting, and log the results at DEBUG level. ``msg`` is a message the caller provides to identify at what point the profiling happens. ''' kind = self.settings['dump-memory-profile'] interval = self.settings['memory-dump-interval'] if kind == 'none': return now = time.time() if self.last_memory_dump + interval > now: return self.last_memory_dump = now # Log wall clock and CPU times for self, children. utime, stime, cutime, cstime, elapsed_time = os.times() duration = elapsed_time - self.started logging.debug('process duration: %s s', duration) logging.debug('CPU time, in process: %s s', utime) logging.debug('CPU time, in system: %s s', stime) logging.debug('CPU time, in children: %s s', cutime) logging.debug('CPU time, in system for children: %s s', cstime) logging.debug('dumping memory profiling data: %s', msg) logging.debug('VmRSS: %s KiB', self._vmrss()) if kind == 'simple': return # These are fairly expensive operations, so we only log them # if we're doing expensive stuff anyway. logging.debug('# objects: %d', len(gc.get_objects())) logging.debug('# garbage: %d', len(gc.garbage)) def _vmrss(self): # pragma: no cover '''Return current resident memory use, in KiB.''' if platform.system() != 'Linux': return 0 try: f = open('/proc/self/status') except IOError: return 0 rss = 0 for line in f: if line.startswith('VmRSS'): rss = line.split()[1] f.close() return rss
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
__init__.py | File | 1.63 KB | 0644 |
|
__init__.pyc | File | 1.36 KB | 0644 |
|
app.py | File | 23.3 KB | 0644 |
|
app.pyc | File | 24.72 KB | 0644 |
|
app_tests.py | File | 11.56 KB | 0644 |
|
app_tests.pyc | File | 21.51 KB | 0644 |
|
fmt.py | File | 3.43 KB | 0644 |
|
fmt.pyc | File | 4.29 KB | 0644 |
|
fmt_tests.py | File | 2.06 KB | 0644 |
|
fmt_tests.pyc | File | 2.72 KB | 0644 |
|
genman.py | File | 6.82 KB | 0644 |
|
genman.pyc | File | 6.37 KB | 0644 |
|
hook.py | File | 2.39 KB | 0644 |
|
hook.pyc | File | 2.52 KB | 0644 |
|
hook_tests.py | File | 2.73 KB | 0644 |
|
hook_tests.pyc | File | 3.67 KB | 0644 |
|
hookmgr.py | File | 1.56 KB | 0644 |
|
hookmgr.pyc | File | 1.64 KB | 0644 |
|
hookmgr_tests.py | File | 2.05 KB | 0644 |
|
hookmgr_tests.pyc | File | 2.71 KB | 0644 |
|
plugin.py | File | 3.95 KB | 0644 |
|
plugin.pyc | File | 4.48 KB | 0644 |
|
plugin_tests.py | File | 1.96 KB | 0644 |
|
plugin_tests.pyc | File | 3.06 KB | 0644 |
|
pluginmgr.py | File | 5.54 KB | 0644 |
|
pluginmgr.pyc | File | 5.88 KB | 0644 |
|
pluginmgr_tests.py | File | 3.52 KB | 0644 |
|
pluginmgr_tests.pyc | File | 5.89 KB | 0644 |
|
runcmd.py | File | 11.38 KB | 0644 |
|
runcmd.pyc | File | 8.82 KB | 0644 |
|
runcmd_tests.py | File | 6.21 KB | 0644 |
|
runcmd_tests.pyc | File | 8.76 KB | 0644 |
|
settings.py | File | 29.27 KB | 0644 |
|
settings.pyc | File | 31.88 KB | 0644 |
|
settings_tests.py | File | 22.37 KB | 0644 |
|
settings_tests.pyc | File | 31.32 KB | 0644 |
|
util.py | File | 2.83 KB | 0644 |
|
util.pyc | File | 2.5 KB | 0644 |
|
version.py | File | 60 B | 0644 |
|
version.pyc | File | 228 B | 0644 |
|