resource
— Resource usage information¶
Цей модуль надає базові механізми для вимірювання та контролю системних ресурсів, що використовуються програмою.
Availability: Unix, not Emscripten, not WASI.
Символьні константи використовуються для вказівки певних системних ресурсів і запиту інформації про використання поточного процесу або його дочірніх процесів.
У разі помилки системного виклику виникає OSError
.
Обмеження ресурсів¶
Використання ресурсів можна обмежити за допомогою функції setrlimit()
, описаної нижче. Кожен ресурс контролюється парою обмежень: м’яким обмеженням і жорстким обмеженням. М’яке обмеження – це поточне обмеження, яке з часом може бути знижено або підвищено процесом. М’яке обмеження ніколи не може перевищувати жорстке обмеження. Жорстке обмеження можна знизити до будь-якого значення, що перевищує м’яке обмеження, але не підняти. (Тільки процеси з ефективним UID суперкористувача можуть підняти жорстке обмеження.)
Конкретні ресурси, які можна обмежити, залежать від системи. Вони описані на сторінці довідки getrlimit(2). Перелічені нижче ресурси підтримуються, якщо їх підтримує базова операційна система; ресурси, які не можуть бути перевірені або контрольовані операційною системою, не визначені в цьому модулі для цих платформ.
- resource.RLIM_INFINITY¶
Константа, яка використовується для позначення обмеження для необмеженого ресурсу.
- resource.getrlimit(resource)¶
Повертає кортеж
(soft, hard)
із поточними м’якими та жорсткими обмеженнями ресурсу. ВикликаєValueError
, якщо вказано недійсний ресурс, абоerror
, якщо основний системний виклик несподівано завершується помилкою.
- resource.setrlimit(resource, limits)¶
Встановлює нові обмеження споживання ресурсу. Аргумент limits має бути кортежем
(soft, hard)
із двох цілих чисел, що описують нові обмеження. ЗначенняRLIM_INFINITY
можна використовувати для запиту необмеженого обмеження.Викликає
ValueError
, якщо вказано недійсний ресурс, якщо нове м’яке обмеження перевищує жорстке обмеження або якщо процес намагається підвищити жорстке обмеження. Вказівка лімітуRLIM_INFINITY
, коли жорсткий або системний ліміт для цього ресурсу не необмежений, призведе доValueError
. Процес із ефективним UID суперкористувача може запитувати будь-яке дійсне лімітне значення, включно з необмеженим, алеValueError
все одно буде викликано, якщо запитуваний ліміт перевищує обмеження, встановлене системою.setrlimit
також може викликатиerror
, якщо основний системний виклик не вдається.VxWorks підтримує лише налаштування
RLIMIT_NOFILE
.Викликає подію аудиту
resource.setrlimit
з аргументамиresource
,limits
.
- resource.prlimit(pid, resource[, limits])¶
Поєднує
setrlimit()
іgetrlimit()
в одній функції та підтримує отримання та встановлення обмежень ресурсів довільного процесу. Якщо pid дорівнює 0, тоді виклик застосовується до поточного процесу. resource і limits мають те саме значення, що й уsetrlimit()
, за винятком того, що limits є необов’язковим.Якщо limits не задано, функція повертає обмеження resource процесу pid. Коли задано limits, встановлюється обмеження resource для процесу та повертається попередній ліміт ресурсів.
Викликає
ProcessLookupError
, коли pid не може бути знайдено, іPermissionError
, коли користувач не маєCAP_SYS_RESOURCE
для процесу.Викликає подію аудиту
resource.prlimit
з аргументамиpid
,resource
,limits
.Availability: Linux >= 2.6.36 with glibc >= 2.13.
Нове в версії 3.4.
Ці символи визначають ресурси, споживання яких можна контролювати за допомогою функцій setrlimit()
і getrlimit()
, описаних нижче. Значення цих символів точно є константами, які використовуються програмами на Сі.
Сторінка довідки Unix для getrlimit(2) містить список доступних ресурсів. Зауважте, що не всі системи використовують один і той самий символ або те саме значення для позначення того самого ресурсу. Цей модуль не намагається маскувати відмінності платформ — символи, не визначені для платформи, не будуть доступні з цього модуля на цій платформі.
- resource.RLIMIT_CORE¶
Максимальний розмір (у байтах) основного файлу, який може створити поточний процес. Це може призвести до створення часткового файлу ядра, якщо для вмісту всього образу процесу знадобиться ядро більшого розміру.
- resource.RLIMIT_CPU¶
Максимальна кількість процесорного часу (у секундах), яку може використовувати процес. Якщо цей ліміт перевищено, процесу надсилається сигнал
SIGXCPU
. (Див. документацію модуляsignal
, щоб отримати інформацію про те, як зловити цей сигнал і зробити щось корисне, наприклад, скинути відкриті файли на диск.)
- resource.RLIMIT_FSIZE¶
Максимальний розмір файлу, який може створити процес.
- resource.RLIMIT_DATA¶
Максимальний розмір (у байтах) купи процесу.
- resource.RLIMIT_STACK¶
Максимальний розмір (у байтах) стека викликів для поточного процесу. Це впливає лише на стек основного потоку в багатопоточному процесі.
- resource.RLIMIT_RSS¶
Максимальний розмір резидентного набору, який має бути доступним для процесу.
- resource.RLIMIT_NPROC¶
Максимальна кількість процесів, які може створити поточний процес.
- resource.RLIMIT_NOFILE¶
Максимальна кількість відкритих файлових дескрипторів для поточного процесу.
- resource.RLIMIT_OFILE¶
Назва BSD для
RLIMIT_NOFILE
.
- resource.RLIMIT_MEMLOCK¶
Максимальний адресний простір, який може бути заблокований у пам’яті.
- resource.RLIMIT_VMEM¶
Найбільша область відображеної пам’яті, яку може зайняти процес.
Availability: FreeBSD >= 11.
- resource.RLIMIT_AS¶
Максимальна площа (у байтах) адресного простору, яку може зайняти процес.
- resource.RLIMIT_MSGQUEUE¶
Кількість байтів, які можна виділити для черг повідомлень POSIX.
Availability: Linux >= 2.6.8.
Нове в версії 3.4.
- resource.RLIMIT_NICE¶
Стеля для хорошого рівня процесу (розраховується як 20 - rlim_cur).
Availability: Linux >= 2.6.12.
Нове в версії 3.4.
- resource.RLIMIT_RTPRIO¶
Стеля пріоритету в реальному часі.
Availability: Linux >= 2.6.12.
Нове в версії 3.4.
- resource.RLIMIT_RTTIME¶
Обмеження часу (у мікросекундах) процесорного часу, який процес може витрачати в режимі планування в реальному часі без виконання блокуючого системного виклику.
Доступність: Linux >= 2.6.25.
Нове в версії 3.4.
- resource.RLIMIT_SIGPENDING¶
Кількість сигналів, які процес може поставити в чергу.
Availability: Linux >= 2.6.8.
Нове в версії 3.4.
- resource.RLIMIT_SBSIZE¶
Максимальний розмір (у байтах) використання буфера сокета для цього користувача. Це обмежує обсяг мережевої пам’яті, а отже, і кількість mbuf, які цей користувач може зберігати в будь-який час.
Availability: FreeBSD.
Нове в версії 3.4.
- resource.RLIMIT_SWAP¶
The maximum size (in bytes) of the swap space that may be reserved or used by all of this user id’s processes. This limit is enforced only if bit 1 of the vm.overcommit sysctl is set. Please see tuning(7) for a complete description of this sysctl.
Availability: FreeBSD.
Нове в версії 3.4.
- resource.RLIMIT_NPTS¶
Максимальна кількість псевдотерміналів, створених цим ідентифікатором користувача.
Availability: FreeBSD.
Нове в версії 3.4.
- resource.RLIMIT_KQUEUES¶
Максимальна кількість kqueue, яку дозволено створити цьому ідентифікатору користувача.
Availability: FreeBSD >= 11.
Нове в версії 3.10.
Використання ресурсів¶
Ці функції використовуються для отримання інформації про використання ресурсів:
- resource.getrusage(who)¶
This function returns an object that describes the resources consumed by either the current process or its children, as specified by the who parameter. The who parameter should be specified using one of the
RUSAGE_*
constants described below.Простий приклад:
from resource import * import time # a non CPU-bound task time.sleep(3) print(getrusage(RUSAGE_SELF)) # a CPU-bound task for i in range(10 ** 8): _ = 1 + 1 print(getrusage(RUSAGE_SELF))
Кожне з полів поверненого значення описує, як використовувався певний системний ресурс, напр. кількість часу, витраченого на роботу, є режимом користувача або кількістю разів, коли процес вивантажувався з основної пам’яті. Деякі значення залежать від внутрішнього такту годинника, напр. обсяг пам’яті, який використовує процес.
Для зворотної сумісності повернуте значення також доступне як кортеж із 16 елементів.
The fields
ru_utime
andru_stime
of the return value are floating point values representing the amount of time spent executing in user mode and the amount of time spent executing in system mode, respectively. The remaining values are integers. Consult the getrusage(2) man page for detailed information about these values. A brief summary is presented here:Індекс
Поле
Ресурс
0
ru_utime
час у режимі користувача (секунд з плаваючою точкою)
1
ru_stime
час у системному режимі (секунд з плаваючою точкою)
2
ru_maxrss
максимальний розмір резидентного набору
3
ru_ixrss
розмір спільної пам’яті
4
ru_idrss
нерозділений розмір пам’яті
5
ru_isrss
розмір стеку без спільного доступу
6
ru_minflt
помилки сторінки, які не вимагають введення-виведення
7
ru_majflt
помилки сторінки, які вимагають введення-виведення
8
ru_nswap
кількість обмінів
9
ru_inblock
операції введення блоку
10
ru_oublock
операції виведення блоків
11
ru_msgsnd
надісланих повідомлень
12
ru_msgrcv
отриманих повідомлень
13
ru_nsignals
отримані сигнали
14
ru_nvcsw
добровільні перемикання контексту
15
ru_nivcsw
мимовільні перемикання контексту
Ця функція викличе
ValueError
, якщо вказано недійсний параметр who. Він також може викликати винятокerror
за незвичайних обставин.
- resource.getpagesize()¶
Повертає кількість байтів на системній сторінці. (Це необов’язково збігається з апаратним розміром сторінки.)
The following RUSAGE_*
symbols are passed to the getrusage()
function to specify which processes information should be provided for.
- resource.RUSAGE_SELF¶
Передайте
getrusage()
, щоб запитати ресурси, спожиті процесом виклику, який є сумою ресурсів, використаних усіма потоками в процесі.
- resource.RUSAGE_CHILDREN¶
Перейдіть до
getrusage()
, щоб запитати ресурси, споживані дочірніми процесами викликаючого процесу, які були завершені та очікували.
- resource.RUSAGE_BOTH¶
Перейдіть до
getrusage()
, щоб запитати ресурси, споживані як поточним процесом, так і дочірніми процесами. Може бути недоступний у всіх системах.
- resource.RUSAGE_THREAD¶
Перейдіть до
getrusage()
, щоб запитати ресурси, спожиті поточним потоком. Може бути недоступний у всіх системах.Нове в версії 3.2.