diff options
| author | Adrian Holovaty <adrian@holovaty.com> | 2005-07-13 01:25:57 +0000 |
|---|---|---|
| committer | Adrian Holovaty <adrian@holovaty.com> | 2005-07-13 01:25:57 +0000 |
| commit | ed114e15106192b22ebb78ef5bf5bce72b419d13 (patch) | |
| tree | f7c27f035cca8d50bd69e2ecbd7497fccec4a35a /django/bin/profiling | |
| parent | 07ffc7d605cc96557db28a9e35da69bc0719611b (diff) | |
Imported Django from private SVN repository (created from r. 8825)
git-svn-id: http://code.djangoproject.com/svn/django/trunk@3 bcc190cf-cafb-0310-a4f2-bffc1f526a37
Diffstat (limited to 'django/bin/profiling')
| -rw-r--r-- | django/bin/profiling/__init__.py | 0 | ||||
| -rw-r--r-- | django/bin/profiling/gather_profile_stats.py | 34 | ||||
| -rw-r--r-- | django/bin/profiling/handler.py | 22 |
3 files changed, 56 insertions, 0 deletions
diff --git a/django/bin/profiling/__init__.py b/django/bin/profiling/__init__.py new file mode 100644 index 0000000000..e69de29bb2 --- /dev/null +++ b/django/bin/profiling/__init__.py diff --git a/django/bin/profiling/gather_profile_stats.py b/django/bin/profiling/gather_profile_stats.py new file mode 100644 index 0000000000..852f16229d --- /dev/null +++ b/django/bin/profiling/gather_profile_stats.py @@ -0,0 +1,34 @@ +""" +gather_profile_stats.py /path/to/dir/of/profiles + +Note that the aggregated profiles must be read with pstats.Stats, not +hotshot.stats (the formats are incompatible) +""" + +from hotshot import stats +import pstats +import sys, os + +def gather_stats(p): + profiles = {} + for f in os.listdir(p): + if f.endswith('.agg.prof'): + path = f[:-9] + prof = pstats.Stats(os.path.join(p, f)) + elif f.endswith('.prof'): + bits = f.split('.') + path = ".".join(bits[:-3]) + prof = stats.load(os.path.join(p, f)) + else: + continue + print "Processing %s" % f + if profiles.has_key(path): + profiles[path].add(prof) + else: + profiles[path] = prof + os.unlink(os.path.join(p, f)) + for (path, prof) in profiles.items(): + prof.dump_stats(os.path.join(p, "%s.agg.prof" % path)) + +if __name__ == '__main__': + gather_stats(sys.argv[1]) diff --git a/django/bin/profiling/handler.py b/django/bin/profiling/handler.py new file mode 100644 index 0000000000..8a7512b079 --- /dev/null +++ b/django/bin/profiling/handler.py @@ -0,0 +1,22 @@ +import hotshot, time, os +from django.core.handler import CoreHandler + +PROFILE_DATA_DIR = "/var/log/cmsprofile/" + +def handler(req): + ''' + Handler that uses hotshot to store profile data. + + Stores profile data in PROFILE_DATA_DIR. Since hotshot has no way (that I + know of) to append profile data to a single file, each request gets its own + profile. The file names are in the format <url>.<n>.prof where <url> is + the request path with "/" replaced by ".", and <n> is a timestamp with + microseconds to prevent overwriting files. + + Use the gather_profile_stats.py script to gather these individual request + profiles into aggregated profiles by request path. + ''' + profname = "%s.%.3f.prof" % (req.uri.strip("/").replace('/', '.'), time.time()) + profname = os.path.join(PROFILE_DATA_DIR, profname) + prof = hotshot.Profile(profname) + return prof.runcall(CoreHandler(), req) |
