本文整理匯總了Python中resource.RUSAGE_SELF屬性的典型用法代碼示例。如果您正苦於以下問題:Python resource.RUSAGE_SELF屬性的具體用法?Python resource.RUSAGE_SELF怎麽用?Python resource.RUSAGE_SELF使用的例子?那麽, 這裏精選的屬性代碼示例或許可以為您提供幫助。您也可以進一步了解該屬性所在類resource
的用法示例。
在下文中一共展示了resource.RUSAGE_SELF屬性的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: print_used_time
# 需要導入模塊: import resource [as 別名]
# 或者: from resource import RUSAGE_SELF [as 別名]
def print_used_time(func):
''' 打印運行時間
:param func: 運行的函數名稱
:return:
'''
@wraps(func)
def wrapper(*args, **kwargs):
start_time, start_resources = timestamp(), resource_usage(RUSAGE_SELF)
func(*args, **kwargs)
end_resources, end_time = resource_usage(RUSAGE_SELF), timestamp()
print({'消耗時間': {'real': end_time - start_time,
'sys': end_resources.ru_stime - start_resources.ru_stime,
'user': end_resources.ru_utime - start_resources.ru_utime}})
return True
return wrapper
示例2: _get_mem_usage
# 需要導入模塊: import resource [as 別名]
# 或者: from resource import RUSAGE_SELF [as 別名]
def _get_mem_usage(self):
"""
Gets the RUSAGE memory usage, returns in K. Encapsulates the difference
between macOS and Linux rss reporting
:returns: memory usage in kilobytes
"""
from resource import getrusage, RUSAGE_SELF
mem = getrusage(RUSAGE_SELF).ru_maxrss
if sys.platform == 'darwin':
# man 2 getrusage:
# ru_maxrss
# This is the maximum resident set size utilized (in bytes).
return mem / 1024 # Kb
else:
# linux
# man 2 getrusage
# ru_maxrss (since Linux 2.6.32)
# This is the maximum resident set size used (in kilobytes).
return mem # Kb
示例3: update
# 需要導入模塊: import resource [as 別名]
# 或者: from resource import RUSAGE_SELF [as 別名]
def update(self):
"""
Get memory metrics of current process through `getrusage`. Only
available on Unix, on Linux most of the fields are not set,
and on BSD units are used that are not very helpful, see:
http://www.perlmonks.org/?node_id=626693
Furthermore, getrusage only provides accumulated statistics (e.g.
max rss vs current rss).
"""
usage = getrusage(RUSAGE_SELF)
self.rss = usage.ru_maxrss * 1024
self.data_segment = usage.ru_idrss * 1024 # TODO: ticks?
self.shared_segment = usage.ru_ixrss * 1024 # TODO: ticks?
self.stack_segment = usage.ru_isrss * 1024 # TODO: ticks?
self.vsz = self.data_segment + self.shared_segment + \
self.stack_segment
self.pagefaults = usage.ru_majflt
return self.rss != 0
示例4: get_cpu_consumption
# 需要導入模塊: import resource [as 別名]
# 或者: from resource import RUSAGE_SELF [as 別名]
def get_cpu_consumption():
global daemon_start
if os.name == 'nt':
return 0
# Some special unix maybe?
try:
from resource import getrusage, RUSAGE_SELF
except ImportError:
return 0
now = time.time()
# Maybe we did get back in time?
if now < daemon_start:
daemon_start = now
diff = now - daemon_start
if diff == 0:
return 0
rusage = getrusage(RUSAGE_SELF)
current_cpu_time = rusage.ru_utime + rusage.ru_stime
return 100 * current_cpu_time / diff
############# String diffs
示例5: memory_monitor
# 需要導入模塊: import resource [as 別名]
# 或者: from resource import RUSAGE_SELF [as 別名]
def memory_monitor(command_queue: Queue, poll_interval=1):
tracemalloc.start()
old_max = 0
snapshot = None
while True:
try:
command_queue.get(timeout=poll_interval)
if snapshot is not None:
print(datetime.now())
display_top(snapshot)
return
except Empty:
max_rss = getrusage(RUSAGE_SELF).ru_maxrss
if max_rss > old_max:
old_max = max_rss
snapshot = tracemalloc.take_snapshot()
display_top(snapshot, limit=1)
print(datetime.now(), 'max RSS', old_max)
示例6: _get_memory_usage_MB_
# 需要導入模塊: import resource [as 別名]
# 或者: from resource import RUSAGE_SELF [as 別名]
def _get_memory_usage_MB_():
"""
Return the maximum memory use of this Python process in MB
"""
to_MB = 1024.
if platform == 'darwin':
to_MB *= to_MB
return getrusage(RUSAGE_SELF).ru_maxrss / to_MB
#=========================================================================
# _get_io_blocksize_MB_
#=========================================================================
示例7: self
# 需要導入模塊: import resource [as 別名]
# 或者: from resource import RUSAGE_SELF [as 別名]
def self(level=logging.DEBUG):
log.log(level, rusage(resource.RUSAGE_SELF))
示例8: rusage
# 需要導入模塊: import resource [as 別名]
# 或者: from resource import RUSAGE_SELF [as 別名]
def rusage(target=resource.RUSAGE_SELF):
r = resource.getrusage(target)
fmt = "rss = %0.03fM user = %0.03f sys = %0.03f"
return fmt % (r.ru_maxrss / 1024.0, r.ru_utime, r.ru_stime)
示例9: memusage
# 需要導入模塊: import resource [as 別名]
# 或者: from resource import RUSAGE_SELF [as 別名]
def memusage(do_dump_rpy_heap=True, do_objgraph=True):
# type: (Optional[bool], Optional[bool]) -> str
"""Returning a str of memory usage stats"""
def trap_err(func, *args, **kwargs):
try:
return func(*args, **kwargs)
except Exception as e: # pragma: nocover
# include both __str/repr__, sometimes one's useless
buf.writelines([func.__name__, ': ', repr(e), ': ', str(e)])
buf = StringIO()
rusage = trap_err(resource.getrusage, resource.RUSAGE_SELF)
buf.writelines([repr(rusage), '\n\n'])
trap_err(pmap_extended, buf)
trap_err(jemalloc_stats, buf)
trap_err(glibc_malloc_info, buf)
if hasattr(gc, 'get_stats'):
buf.writelines(['\n\n', gc.get_stats(), '\n\n'])
if do_dump_rpy_heap:
# dump rpython's heap before objgraph potentially pollutes the
# heap with its heavy workload
trap_err(dump_rpy_heap, buf)
trap_err(get_stats_asmmemmgr, buf)
buf.write('\n\n')
if do_objgraph:
trap_err(objgraph.show_most_common_types, limit=0, file=buf)
return buf.getvalue()
示例10: _get_mem_usage
# 需要導入模塊: import resource [as 別名]
# 或者: from resource import RUSAGE_SELF [as 別名]
def _get_mem_usage(self):
from resource import getpagesize, getrusage, RUSAGE_SELF
mem = getrusage(RUSAGE_SELF).ru_maxrss
return mem * getpagesize() / 1024 / 1024
示例11: init_objects_and_adjacency_records
# 需要導入模塊: import resource [as 別名]
# 或者: from resource import RUSAGE_SELF [as 別名]
def init_objects_and_adjacency_records(self):
print("Initializing the segmenter...")
print("Max mem: {} GB".format(resource.getrusage(
resource.RUSAGE_SELF).ru_maxrss / 1024 / 1024))
obj_id = 0
for row in range(self.img_height):
for col in range(self.img_width):
pixels = set([(row, col)])
obj = Object(pixels, obj_id, self)
self.objects[obj_id] = obj
self.pixel2obj[(row, col)] = obj
obj_id += 1
for row in range(self.img_height):
for col in range(self.img_width):
obj1 = self.pixel2obj[(row, col)]
for o, idx in zip(self.offsets, range(len(self.offsets))):
(i, j) = o
if (0 <= row + i < self.img_height and
0 <= col + j < self.img_width):
obj2 = self.pixel2obj[(row + i, col + j)]
arec = AdjacencyRecord(obj1, obj2, self, (row, col), idx)
self.adjacency_records[arec] = arec
obj1.adjacency_list[arec] = arec
obj2.adjacency_list[arec] = arec
if arec.merge_priority >= 0:
heappush(self.queue, (-arec.merge_priority, arec))
示例12: _get_usage_info
# 需要導入模塊: import resource [as 別名]
# 或者: from resource import RUSAGE_SELF [as 別名]
def _get_usage_info():
rusage = getrusage(RUSAGE_SELF)
curr_usage = rusage.ru_utime + rusage.ru_stime
curr_time = time.time()
return curr_usage, curr_time
示例13: memusage
# 需要導入模塊: import resource [as 別名]
# 或者: from resource import RUSAGE_SELF [as 別名]
def memusage( point = "") :
usage = resource.getrusage( resource.RUSAGE_SELF)
return '''%s: usertime = %s systime = %s mem = %s mb
'''%( point, usage[ 0 ], usage[ 1 ],
( usage[ 2 ]*resource.getpagesize( ) ) /1000000.0 )
示例14: generate_parsed_data
# 需要導入模塊: import resource [as 別名]
# 或者: from resource import RUSAGE_SELF [as 別名]
def generate_parsed_data(self):
# Get a rough idea of how much memory we have to play with
CHECK_MEM_COUNT = 10000
kb_free = _get_free_memory_kb()
starting_maxrss = getrusage(RUSAGE_SELF).ru_maxrss
check_memory_usage = True
check_memory_count = 1
for (comm, pid, cpu, line, data_str) in zip(self.comm_array, self.pid_array,
self.cpu_array, self.line_array,
self.data_array):
data_dict = {"__comm": comm, "__pid": pid, "__cpu": cpu, "__line": line}
data_dict.update(self.generate_data_dict(data_str))
# When running out of memory, Pandas has been observed to segfault
# rather than throwing a proper Python error.
# Look at how much memory our process is using and warn if we seem
# to be getting close to the system's limit, check it only once
# in the beginning and then every CHECK_MEM_COUNT events
check_memory_count -= 1
if check_memory_usage and check_memory_count == 0:
kb_used = (getrusage(RUSAGE_SELF).ru_maxrss - starting_maxrss)
if kb_free and kb_used > kb_free * 0.9:
warnings.warn("TRAPpy: Appear to be low on memory. "
"If errors arise, try providing more RAM")
check_memory_usage = False
check_memory_count = CHECK_MEM_COUNT
yield data_dict
示例15: install
# 需要導入模塊: import resource [as 別名]
# 或者: from resource import RUSAGE_SELF [as 別名]
def install(self):
self.faults_at_start = get_fault_count(resource.RUSAGE_SELF)
self.run_start_time = time.time()
self.real_fork = os.fork
os.fork = self.my_fork