Source code for pulsar.utils.system

'''Operative system specific functions and classes.
'''
import os

from .runtime import Platform
from .base import *     # noqa

platform = Platform()
seconds = platform.seconds

if platform.type == 'win':    # pragma nocover
    from .windowssystem import *    # noqa
else:
    from .posixsystem import *      # noqa


try:
    import psutil
except ImportError:    # pragma    nocover
    psutil = None

try:
    import ujson as json    # noqa
except ImportError:         # pragma    nocover
    import json             # noqa


memory_symbols = ('K', 'M', 'G', 'T', 'P', 'E', 'Z', 'Y')
memory_size = dict(((s, 1 << (i+1)*10) for i, s in enumerate(memory_symbols)))


def convert_bytes(b):
    '''Convert a number of bytes into a human readable memory usage, bytes,
kilo, mega, giga, tera, peta, exa, zetta, yotta'''
    if b is None:
        return '#NA'
    for s in reversed(memory_symbols):
        if b >= memory_size[s]:
            value = float(b) / memory_size[s]
            return '%.1f%sB' % (value, s)
    return "%sB" % b


[docs]def process_info(pid=None): '''Returns a dictionary of system information for the process ``pid``. It uses the psutil_ module for the purpose. If psutil_ is not available it returns an empty dictionary. .. _psutil: http://code.google.com/p/psutil/ ''' if psutil is None: # pragma nocover return {} pid = pid or os.getpid() try: p = psutil.Process(pid) # this fails on platforms which don't allow multiprocessing except psutil.NoSuchProcess: # pragma nocover return {} else: mem = p.memory_info() return {'memory': convert_bytes(mem.rss), 'memory_virtual': convert_bytes(mem.vms), 'cpu_percent': p.cpu_percent(), 'nice': p.nice(), 'num_threads': p.num_threads()}