Python 第三方模塊之 psutil - 獲取系統運行的進程和系統利用率信息

一、psutil模塊:

官方網址:http://pythonhosted.org/psutil/

1.psutil是一個跨平臺庫(http://pythonhosted.org/psutil/)能夠輕松實現獲取系統運行的進程和系統利用率(包括CPU、內存、磁盤、網絡等)信息。它主要用來做系統監控,性能分析,進程管理。它實現了同等命令行工具提供的功能,如ps、top、lsof、netstat、ifconfig、who、df、kill、free、nice、ionice、iostat、iotop、uptime、pidof、tty、taskset、pmap等。目前支持32位和64位的Linux、Windows、OS X、FreeBSD和Sun Solaris等操作系統.

2.安裝psutil模塊:

CentOS安裝psutil包:
pip3 install psutil
或者
wget https://pypi.python.org/packages/source/p/psutil/psutil-3.2.1.tar.gz --no-check-certificate
tar zxvf psutil-3.2.1.tar.gz 
cd psutil-3.2.1
python setup.py installWindos安裝psutil包:
pip3 install psutil

二、獲取系統基本信息的使用:

1.CPU信息

使用cpu_times方法獲取cpu的完整信息,如下所示。

psutil.cpu_times()
# scputimes(user=650613.02, nice=22.14, system=154916.5, idle=16702285.26, iowait=68894.55, irq=3.38, softirq=7075.65, steal=0.0, guest=0.0)

獲取單個數據,如用戶的cpu時或io等待時間,如下所示:

psutil.cpu_times().user    # 650617.11
psutil.cpu_times().iowait  # 68894.63

獲取cpu邏輯和物理個數,默認logical值為True 。

# CPU邏輯個數
psutil.cpu_count()  # 8
# CPU物理個數
psutil.cpu_count(logical=False)  # 1

獲取cpu的使用率:

psutil.cpu_percent(interval=None, percpu=False)   # 間隔空,cpu的總使用情況
psutil.cpu_percent(interval=None, percpu=True)    # 每個cpu的使用情況

2.內存信息

內存信息的獲取主要使用virtual_memory方法。swap使用就用swap_memory方法。

mem = psutil.virtual_memory()
print(mem)
# svmem(total=4018601984, available=1066205184, percent=73.5, used=3904004096, free=114597888, active=3302174720, inactive=426078208, buffers=156520448, cached=795086848)
# 其中percent表示實際已經使用的內存占比,即(1047543808-717537280)/1047543808\*100% 。available表示還可以使用的內存。
print(mem.total)  # 4018601984
print(mem.used)   # 3904004096
print(mem.free)   # 114597888
print(mem.total/1024/1024) # 3832.4375

3.磁盤信息

磁盤信息主要有兩部分,一個是磁盤的利用率,一個是io,他們分別可以通過disk_usage和disk_io_counters方法獲取。

如下先獲取分區信息,然后看下根分區的使用情況:

psutil.disk_partitions()
# [sdiskpart(device='/dev/mapper/root', mountpoint='/', fstype='ext4', opts='rw,errors=remount-ro'), sdiskpart(device='/dev/sda1', mountpoint='/boot', fstype='ext2', opts='rw')]
psutil.disk_usage('/')
# sdiskusage(total=42273669120, used=17241096192, free=22885195776, percent=40.8) 

默認disk_io_counters方法獲取的是硬盤總的io數和讀寫信息,如果需要獲取單個分區的io和讀寫信息加上"perdisk=True"參數。

psutil.disk_io_counters()
# sdiskio(read_count=638190, write_count=77080153, read_bytes=16037795840, write_bytes=1628871606272, read_time=2307367, write_time=1777841305)
psutil.disk_io_counters(perdisk=True)
# {'vdb1': sdiskio(read_count=312, write_count=0, read_bytes=1238016, write_bytes=0, read_time=95, write_time=0), 'vda1': sdiskio(read_count=637878, write_count=77080257, read_bytes=16036557824, write_bytes=1628873314304, read_time=2307272, write_time=1777841879)}

4.網絡信息

網絡io和磁盤io使用方法差不多,主要使用net_io_counters方法,如果需要獲取單個網卡的io信息,加上pernic=True參數。

# 獲取網絡總的io情況
psutil.net_io_counters()
# snetio(bytes_sent=525490132009, bytes_recv=409145642892, packets_sent=948527563, packets_recv=778182181, errin=0, errout=0, dropin=0, dropout=0)
# 獲取網卡的io情況
psutil.net_io_counters(pernic=True)
# {'lo': snetio(bytes_sent=56524704027, bytes_recv=56524704027, packets_sent=33602236, packets_recv=33602236, errin=0, errout=0, dropin=0, dropout=0), 'eth0': snetio(bytes_sent=468966480940, bytes_recv=352622081327, packets_sent=914930488, packets_recv=744583332, errin=0, errout=0, dropin=0, dropout=0)}

5.網卡

# 獲取網卡ens33的IP地址
psutil.net_if_addrs()['ens33'][0].address  # '192.168.137.16'# 子網掩碼
psutil.net_if_addrs()['ens33'][0].netmask  # '255.255.255.0'# 查看網卡是否開啟
psutil.net_if_stats()['ens33'].isup  # True#查看網卡的速率,命令有ifconfig,ethtool
psutil.net_if_stats()['ens33'].speed  # 1000  #單位 Mb/s

6.其他系統信息

1.獲取開機時間

# 以linux時間格式返回,可以使用時間戳轉換
psutil.boot_time()    # 1496647567.0# 轉換成自然時間格式
psutil.boot_time()    # 1496647567.0
datetime.datetime.fromtimestamp(psutil.boot_time ()).strftime("%Y-%m-%d %H: %M: %S")  # '2017-06-05 15: 26: 07'

2.查看系統全部進程

psutil.pids()
# [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 46, 47, 48, 49, 50, 51, 52, 53, 60, 61, 63, 64, 65, 97, 98, 279, 280, 331, 398, 481, 676, 693, 769, 845, 848, 1023, 1085, 1108, 1355, 1366, 1457, 1474, 1475, 1494, 1541, 1543, 1545, 1546, 1548, 1550, 1552, 2829, 12436, 12913, 13129, 16022, 16029, 16030, 16031, 16032, 16033, 16518, 16520, 17088, 17124, 19203, 25382, 32679]

3.查看單個進程

p = psutil.Process(16031) 
p.name()           # 進程名
p.exe()            # 進程的bin路徑
p.cwd()            # 進程的工作目錄絕對路徑
p.status()         # 進程狀態
p.create_time()    # 進程創建時間
p.uids()           # 進程uid信息
p.gids()           # 進程的gid信息
p.cpu_times()      # 進程的cpu時間信息,包括user,system兩個cpu信息
p.cpu_affinity()   # get進程cpu親和度,如果要設置cpu親和度,將cpu號作為參考就好
p.memory_percent() # 進程內存利用率
p.memory_info()    # 進程內存rss,vms信息
p.io_counters()    # 進程的IO信息,包括讀寫IO數字及參數
p.connectios()     # 返回進程列表
p.num_threads()    # 進程開啟的線程數# 聽過psutil的Popen方法啟動應用程序,可以跟蹤程序的相關信息
from subprocess import PIPE
p = psutil.Popen(["/usr/bin/python", "-c", "print('hello')"],stdout=PIPE)
p.name()
p.username()

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/453848.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/453848.shtml
英文地址,請注明出處:http://en.pswp.cn/news/453848.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

石頭機器人紅燈快閃_機器人集體“快閃”活動爆紅網絡 “我是AI”與您相約智能新時代...

原標題:機器人集體“快閃”活動爆紅網絡 “我是AI”與您相約智能新時代3月10日下午,天津科學技術館內,悠揚美妙的歌聲《我和我的祖國》突然響起,隨后50個身形矯健的阿爾法機器人伴隨著歌聲翩翩起舞,動作整齊、科技感十…

淺談云計算與數據中心計算

文/林仕鼎 云計算概念發端于Google和Amazon等超大規模的互聯網公司,隨著這些公司業務的成功,作為其支撐技術的云計算也得到了業界的高度認可和廣泛傳播。時至今日,云計算已被普遍認為是IT產業發展的新階段,從而被賦予了很多產業和…

無線網絡實體圖生成工具airgraph-ng

無線網絡實體圖生成工具airgraph-ngairgraph-ng是aircrack-ng套件提供的一個圖表生成工具。該工具可以根據airodump工具生成的CSV文件繪制PNG格式的圖。繪制的圖有兩種類型,分別為AP-客戶端關聯圖和通用探測圖。通過AP-客戶端關聯圖,可以更為直觀的了解無…

高等代數期末考試題庫及答案_數學類高等代數期末考試試題A卷(含答案)

數學類高等代數期末考試試題A卷(含答案)課程編號MTH17063 北京理工大學2010-2011學年第一學期2009級數學類高等代數期末考試試題A卷班級 學號 姓名 成績 一、(25分)設表示域上的所有階矩陣構成的上的線性空間。取定,對于任意的,定義。(1)證明為上的一個線…

cocos2d-lua3.7組件篇(三)-http通信demo

客戶端使用lua、服務端使用QT做為服務器。 步驟: 客戶端 -----------Post 用戶名和密碼 服務端接受Post請求,讀取數據,返回response一、客戶端代碼 loadingImg require"app.scenes.LoadingLayer"local LoginScene class(&qu…

數據挖掘:如何尋找相關項

導讀:隨著大數據時代浪潮的到來數據科學家這一新興職業也越來越受到人們的關注。本文作者Alexandru Nedelcu就將數學挖掘算法與大數據有機的結合起來,并無縫的應用在面臨大數據浪潮的網站之中。 數據科學家需要具備專業領域知識并研究相應的算法以分析對…

Python 第三方模塊之 selenium - 模擬操作 Chrome 瀏覽器

1、安裝selenium 1.1、Python 安裝 selenium 模塊 pip install selenium1.2、下載驅動 選擇和自己chrom版本相對應的驅動到本地,下載地址 http://npm.taobao.org/mirrors/chromedriver/2、Python 操作 from selenium import webdriver import time import json…

jupyter notebook代碼導出_Jupyter Notebook導出包含中文的pdf_親測有效

Jupyter Notebook是很好的數據科學創作環境,是非常方便的Python代碼編輯器。jupyter提供導出的格式有.py、.html、.md、.pdf等。目前用其導出包含中文的pdf會遇到很多坑,網上也有一些解決方案,大致分為兩種方式,一是安裝 pandoc并…

前端之使用 POST 提交數據并跳轉

GET 方式 window.location.href是我們常用來在js中實現頁面跳轉的方法,這是使用get方式發送請求,示例如下 window.location.href url;優點是簡單易用,缺點是如果有參數的話,參數會暴露在url地址中,這降低了系統的安…

cef js返回c++的代碼_CEF3開發者系列之外篇——IE中JS與C++交互

使用IE內核開發客戶端產品,系統和前端頁面之間的交互,通常給開發和維護帶來很大的便利性。但操作系統和前端之間的交互卻是比較復雜的。具體來說就是腳本語言和編譯語言的交互。在IE內核中html和css雖然不兼容,但是IE編程接口是完全一樣的,這得益于微軟的…

多線程編程指南 part 2

多線程編程指南Sun Microsystems, Inc.4150 Network CircleSanta Clara, CA95054U.S.A.文件號碼819–7051–102006 年10 月版權所有2005 Sun Microsystems, Inc. 4150 Network Circle, Santa Clara, CA95054 U.S.A. 保留所有權利。本文檔及其相關產品的使用、復制、分發和反編譯…

00030_ArrayList集合

1、數組可以保存多個元素,但在某些情況下無法確定到底要保存多少個元素,此時數組將不再適用,因為數組的長度不可變 2、JDK中提供了一系列特殊的類,這些類可以存儲任意類型的元素,并且長度可變,統稱為集合 3…

1.3tf的varible\labelencoder

1.tf的varible變量 import tensorflow as tf #定義變量--這里是計數的變量 statetf.Variable(0,namecounter) print (state.name) #輸出變量值 onetf.constant(1) #常量new_valuetf.add(state,one) updatetf.assign(state,new_value)#初始化所有變量 inittf.initialize_all_var…

kafka 日志相關配置

日志目錄 ${kafka.logs.dir}/server.log :服務器日志${kafka.logs.dir}/state-change.log:狀態變化日志${kafka.logs.dir}/kafka-request.log:請求處理日志${kafka.logs.dir}/log-cleaner.log:日志清理${kafka.logs.dir}/control…

linux mc服務器 mod_如何在linux搭建MC服務器

摘要:前言Q:為什么要用linux搭建MC服務器?A:因為linux系統占用率低,跑服務器效果非常好Q:看不懂linux ssh,后期自己無力運維怎么辦A:沒關系,這個教程是通過安裝BT...前言…

flask-SQLAlchemy 使用 session.commit() 處理異常回滾

最為原始的try/except辦法,多次插入數據就要寫多次,很麻煩,使用python原生的contextlib.contextmanager簡化代碼! try:user_db User(emailself.email, nicknameself.nickname, passwordself.password)db.session.add(user_db)#所…

小米機器人清理主刷和軸承_掃地機主刷怎樣更換

原標題:掃地機主刷怎樣更換隨著電動掃地機逐漸取代手動清潔,電動掃地機的工作量不斷增加,從而導致主刷磨損更加嚴重,并增加了主刷更換的次數。因此,偉頓在這里告訴大家掃地機主刷怎樣更換:1 .首先&#xff…

多線程編程指南

1. 多線程編程指南1--線程基礎 線程編程指南1--線程基礎 Wednesday, 29. March 2006, 11:48:45 多線程 本文出自:BBS水木清華站 作者:Mccartney (coolcat) (2002-01-29 20:25:25) multithreading可以被翻譯成多線程控制。與傳統的UNIX不同,一個傳統 的UNIX進…

路由器和貓的區別

路由器和貓的區別 網絡在我們現在生活中必不可少,我們鏈接互聯網經常需要用到貓和路由器,但是依然有很多菜鳥根本不知道什么是貓什么是路由器,至于貓和路由器怎么使用就更不知道了,下面給大家詳細的講解下路由器和貓的區別。 路由器和貓的用途和鏈接位置不一樣,如下圖: 路由器:…

Docker 精通之 docker-compose

1、Docker-compose簡介 1.1、ocker-compose簡介 Docker-Compose項目是Docker官方的開源項目,負責實現對Docker容器集群的快速編排。   Docker-Compose將所管理的容器分為三層,分別是工程(project),服務&#xff08…