python 之 资源使用与控制 resource模块

一、背景

2021年做可信计算时,由于甲方给的CPU利用率不能不能超过20%;
目的:我们的程序部署甲方服务器上不能阻碍其甲方服务的正常运行
我们的程序在CPU超过20%时,可以休眠几秒后继续运行
此时需要检测控制服务器的CPU资源使用信息,用于做判断程序是否休眠

resource 模块用于测量和控制程序使用的系统资源的基本机制

二、resource 基本用法
2.1 资源限制
  • resource.RLIM_INFINITY 无限资源的限制
  • resource.getrlimit(resource) 当前资源软硬限制的元组(soft, hard)
  • resource.setrlimit(resource, limits) 设置新的资源消耗限制 limits 两个整数的元组
  • resource.prlimit(pid, resource[, limits])
    setrlimit()将和结合getrlimit()在一个函数中,支持获取和设置任意进程的资源限制
    如果 pid为0,则调用适用于当前进程
    resource和limits与中的含义相同setrlimit(),limits可选
    当没有给出限制时,该函数返回进程pid的资源限制
    当给定限制时,设置进程的资源限制并返回以前的资源限制
    
    import resource
    
    # 进程可用存储区大小
    soft, hard = resource.getrlimit(resource.RLIMIT_AS)
    # 进程最大处理器时间
    soft, hard = resource.getrlimit(resource.RLIMIT_CPU)
    
    # 设置cpu最大处理时间
    resource.setrlimit(resource.RLIMIT_CPU, (seconds, hard))
    # 设置进程内存限制,程序运行到没有多余内存时会抛出 MemoryError 异常
    resource.setrlimit(resource.RLIMIT_AS, (size, hard))
    
    resource解释说明
    resource.RLIMIT_AS进程可用存储区大小
    resource.RLIMIT_CPU进程最大处理器时间超出限制SIGXCPU则会向进程发送信号
    resource.RLIMIT_FSIZE进程可创建文件的最大值
    resource.RLIMIT_COREcore文件最大字节
    resource.RLIMIT_DATA进程堆的最大大小数据段最大长度
    resource.RLIMIT_MEMLOCK可锁定在内存中的最大地址空间使用mlock能否在存储器中锁定最长字节数
    resource.RLIMIT_NOFILE当前进程的最大打开文件数
    resource.RLIMIT_NPROC当前进程可创建的最大进程数
    resource.RLIMIT_RSS供给进程的最大驻存集的字节长度
    resource.RLIMIT_STACK当前进程调用栈的最大长度
    resource.RLIMIT_OFILE-
    resource.RLIMIT_VMEM进程占用的最大映射内存区域
    resource.RLIMIT_MSGQUEUE分配给POSIX 消息队列的字节数
    resource.RLIMIT_NICE进程 nice 级别的上限
    resource.RLIMIT_RTPRIO实时优先级的上限
    resource.RLIMIT_RTTIME实时优先级的上限
    resource.RLIMIT_SIGPENDING进程可能排队的信号数
    resource.RLIMIT_SBSIZE用户使用的套接字缓冲区的最大大小
    resource.RLIMIT_SWAP该用户 ID 的所有进程保留或使用的交换空间的最大大小
    resource.RLIMIT_NPTS用户标识创建的伪终端的最大数量
    resource.RLIMIT_KQUEUES用户 ID 创建的最大 kqueue 数
2.2 资源使用
resource.getpagesize() 获取页面大小: 返回系统页面中的字节数

resource.getrusage(who) 由who参数指定的当前进程或其子进程消耗的资源
import resource

# 资源使用状况:请求调用进程消耗的资源,进程中所有线程使用的资源总和
sor = resource.getrusage(resource.RUSAGE_SELF)

# 已终止和等待的调用进程的子进程消耗的请求资源
sor = resource.getrusage(resource.RUSAGE_CHILDREN)

# 当前进程和子进程消耗的资源 并非在所有系统上都可用
sor = resource.getrusage(resource.RUSAGE_BOTH)

# 当前线程消耗的资源 可能并非在所有系统上都可用
sor = resource.getrusage(resource.RUSAGE_THREAD)

# 用户模式下的时间(其它参数如下)
print(sor.ru_utime)
序号函数描述
0ru_utime用户模式下的时间
1ru_stime系统模式下的时间
2ru_maxrss最大驻留集大小
3ru_ixrss共享内存大小
4ru_idrss非共享堆栈大小
5ru_isrss非共享堆栈大小
6ru_minflt不需要 I/O 的页面错误
7ru_majflt需要 I/O 的页面错误
8ru_nswap换出数量
9ru_inblock块输入操作
10ru_oublock块输出操作
11ru_msgsnd已发送消息
12ru_msgrcv收到的消息
13ru_nsignals收到的信号
14ru_nvcsw自愿上下文切换
15ru_nivcsw非自愿上下文切换

官方文档

三、限制进程的CPU处理时间和内存使用量
import signal
import resource
import os

# 限制 CPU 时间
def time_exceeded(signo, frame):
    # 超时时打印提示信息并引发 SystemExit 异常,以终止脚本
    print("CPU exceeded...")
    raise SystemExit(1)

def set_max_runtime(seconds):
    # 获取当前 CPU 时间的软限制和硬限制
    soft, hard = resource.getrlimit(resource.RLIMIT_CPU)
    # 设置软限制为指定的时间,硬限制不变
    resource.setrlimit(resource.RLIMIT_CPU, (seconds, hard))
    # 安装一个信号处理程序来处理超时信号 SIGXCPU
    signal.signal(signal.SIGXCPU, time_exceeded)

# 限制内存使用量
def set_max_memory(size):
    # 获取当前内存使用量的软限制和硬限制
    soft, hard = resource.getrlimit(resource.RLIMIT_AS)
    # 设置软限制为指定的大小,硬限制不变
    resource.setrlimit(resource.RLIMIT_AS, (size, hard))
  • set_max_runtime 函数通过调用 resource 模块中的 getrlimit 和 setrlimit 函数来限制 Python 进程的 CPU 时间。函数首先调用 getrlimit 函数获取当前 CPU 时间的软限制和硬限制,然后将软限制设置为指定的时间,将硬限制保持不变。最后,该函数调用 signal 模块中的 signal 函数,安装一个处理超时信号 SIGXCPU 的信号处理程序,该处理程序在超时时打印一条提示信息并引发 SystemExit 异常以终止脚本。

  • set_max_memory 函数同样使用 getrlimit 和 setrlimit 函数来限制 Python 进程的内存使用量。该函数首先调用 getrlimit 函数获取当前内存使用量的软限制和硬限制,然后将软限制设置为指定的大小,将硬限制保持不变。

python模块详解 各个模块的详解 核心模块 1.1. 介绍 1.2. _ _builtin_ _ 模块 1.3. exceptions 模块 1.4. os 模块 1.5. os.path 模块 1.6. stat 模块 1.7. string 模块 1.8. re 模块 1.9. math 模块 1.10. cmath 模块 1.11. operator 模块 1.12. copy 模块 1.13. sys 模块 1.14. atexit 模块 1.15. time 模块 1.16. types 模块 1.17. gc 模块 更多标准模块 2.1. 概览 2.2. fileinput 模块 2.3. shutil 模块 2.4. tempfile 模块 2.5. StringIO 模块 2.6. cStringIO 模块 2.7. mmap 模块 2.8. UserDict 模块 2.9. UserList 模块 2.10. UserString 模块 2.11. traceback 模块 2.12. errno 模块 2.13. getopt 模块 2.14. getpass 模块 2.15. glob 模块 2.16. fnmatch 模块 2.17. random 模块 2.18. whrandom 模块 2.19. md5 模块 2.20. sha 模块 2.21. crypt 模块 2.22. rotor 模块 2.23. zlib 模块 2.24. code 模块 线程和进程 3.1. 概览 3.2. threading 模块 3.3. Queue 模块 3.4. thread 模块 3.5. commands 模块 3.6. pipes 模块 3.7. popen2 模块 3.8. signal 模块 数据表示 4.1. 概览 4.2. array 模块 4.3. struct 模块 4.4. xdrlib 模块 4.5. marshal 模块 4.6. pickle 模块 4.7. cPickle 模块 4.8. copy_reg 模块 4.9. pprint 模块 4.10. repr 模块 4.11. base64 模块 4.12. binhex 模块 4.13. quopri 模块 4.14. uu 模块 4.15. binascii 模块 文件格式 5.1. 概览 5.2. xmllib 模块 5.3. xml.parsers.expat 模块 5.4. sgmllib 模块 5.5. htmllib 模块 5.6. htmlentitydefs 模块 5.7. formatter 模块 5.8. ConfigParser 模块 5.9. netrc 模块 5.10. shlex 模块 5.11. zipfile 模块 5.12. gzip 模块 邮件和新闻消息处理 6.1. 概览 6.2. rfc822 模块 6.3. mimetools 模块 6.4. MimeWriter 模块 6.5. mailbox 模块 6.6. mailcap 模块 6.7. mimetypes 模块 6.8. packmail 模块 6.9. mimify 模块 6.10. multifile 模块 网络协议 7.1. 概览 7.2. socket 模块 7.3. select 模块 7.4. asyncore 模块 7.5. asynchat 模块 7.6. urllib 模块 7.7. urlparse 模块 7.8. cookie 模块 7.9. robotparser 模块 7.10. ftplib 模块 7.11. gopherlib 模块 7.12. httplib 模块 7.13. poplib 模块 7.14. imaplib 模块 7.15. smtplib 模块 7.16. telnetlib 模块 7.17. nntplib 模块 7.18. SocketServer 模块 7.19. BaseHTTPServer 模块 7.20. SimpleHTTPServer 模块 7.21. CGIHTTPServer 模块 7.22. cgi 模块 7.23. webbrowser 模块 国际化 8.1. locale 模块 8.2. unicodedata 模块 8.3. ucnhash 模块 多媒体相关模块 9.1. 概览 9.2. imghdr 模块 9.3. sndhdr 模块 9.4. whatsound 模块 9.5. aifc 模块 9.6. sunau 模块 9.7. sunaudio 模块 9.8. wave 模块 9.9. audiodev 模块 9.10. winsound 模块 数据储存 10.1. 概览 10.2. anydbm 模块 10.3. whichdb 模块 10.4. shelve 模块 10.5. dbhash 模块 10.6. dbm 模块 10.7. dumbdbm 模块 10.8. gdbm 模块 工具和实用程序 11.1. dis 模块 11.2. pdb 模块 11.3. bdb 模块 11.4. profile 模块 11.5. pstats 模块 11.6. tabnanny 模块 其他模块 12.1. 概览 12.2. fcntl 模块 12.3. pwd 模块 12.4. grp 模块 12.5. nis 模块 12.6. curses 模块 12.7. termios 模块 12.8. tty 模块 12.9. resource 模块 12.10. syslog 模块 12.11. msvcrt 模块 12.12. nt 模块 12.13. _winreg 模块 12.14. posix 模块 执行支持模块 13.1. dospath 模块 13.2. macpath 模块 13.3. ntpath 模块 13.4. posixpath 模块 13.5. strop 模块 13.6. imp 模块 13.7. new 模块 13.8. pre 模块 13.9. sre 模块 13.10. py_compile 模块 13.11. compileall 模块 13.12. ihooks 模块 13.13. linecache 模块 13.14. macurl2path 模块 13.15. nturl2path 模块 13.16. tokenize 模块 13.17. keyword 模块 13.18. parser 模块 13.19. symbol 模块 13.20. token 模块 其他模块 14.1. 概览 14.2. pyclbr 模块 14.3. filecmp 模块 14.4. cmd 模块 14.5. rexec 模块 14.6. Bastion 模块 14.7. readline 模块 14.8. rlcompleter 模块 14.9. statvfs 模块 14.10. calendar 模块 14.11. sched 模块 14.12. statcache 模块 14.13. grep 模块 14.14. dircache 模块 14.15. dircmp 模块 14.16. cmp 模块 14.17. cmpcache 模块 14.18. util 模块 14.19. soundex 模块 14.20. timing 模块 14.21. posixfile 模块 14.22. bisect 模块 14.23. knee 模块 14.24. tzparse 模块 14.25. regex 模块 14.26. regsub 模块 14.27. reconvert 模块 14.28. regex_syntax 模块 14.29. find 模块
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

风华浪浪

讨个老婆本呗

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值