国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

利用Python如何實時檢測自身內存占用

瀏覽:3日期:2022-07-26 10:09:03

前言

最近在做文本統計,用 Python 實現,遇到了一個比較有意思的難題——如何保存統計結果。

直接寫入內存實在是放不下,十幾個小時后內存耗盡,程序被迫關閉。如果直接寫入數據庫吧,每次寫入又太慢了,本來就十幾個小時了,這樣下去就要往星期上數了,也不是個辦法。

解決方案

最后,我想到了一個兩者兼顧的方案——用內存做緩沖,達到一定量之后一次性將當前所有數據合并到硬盤里。

但這樣就有一個閾值,如何確定同步硬盤的時機,通常可以按照文件粒度進行處理,比如處理一個語料文件同步一次……但我的語料有大有小,大的有10GB,根本等不到那一刻內存就爆炸了,后來我想用統計數據量進行判斷……可這又有點難以估計,小了吧頻繁寫入,緩存的意義就不大了,大了吧還沒等到條目數量達到,內存就已經爆滿。另外考慮到將來程序會運行在不同配置的設備上,讓其他開發者根據自身情況計算這個閾值也有點太不友好,于是我想到了一個辦法——不如讓 Python 自己檢測自己的內存占用,如果快滿了(或者達到閾值),就同步寫入硬盤一次。

對于其他開發者來說,自身設備的內存多大是很容易查看的,根據系統運行狀況設置一個合理的閾值,相當方便。

要用 Python 監控自身內存占用,要使用 psutil 這個庫來和系統進行交互,基本邏輯就是先拿到自己的 pid ,然后根據這個 pid 去跟系統獲取進程信息。

def get_current_memory_gb() -> int:# 獲取當前進程內存占用。pid = os.getpid()p = psutil.Process(pid)info = p.memory_full_info()return info.uss / 1024. / 1024. / 1024.

比如我系統是 32GB 內存,那么我設置個 20GB 就相當安全,用 Python 進行統計語料,數據多到進程占用 20GB 內存了,就把當前的數據寫入硬盤,同步統計數據,然后清空程序里的字典緩存釋放內存。

python之psutil

psutil是個跨平臺庫,能夠輕松實現獲取系統運行的進程和系統利用率,包括CPU、內存、磁盤、網絡等信息。

Linux系統下的安裝

pip install psutil

總結

到此這篇關于利用Python如何實時檢測自身內存占用的文章就介紹到這了,更多相關Python實時檢測自身內存占用內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 久久久www免费人成看片 | a级毛片免费播放 | 国内自拍网| 91黑丝国产线观看免费 | 日韩一级黄色毛片 | avtom影院入口永久在线 | 一级女毛片| 日韩在线专区 | 99视频精品免视3 | 99久久99这里只有免费费精品 | 日韩免费在线视频 | 免费一级特黄欧美大片久久网 | 国产成人毛片毛片久久网 | 欧美一级特黄aa大片视频 | 一区二区视屏 | 日韩中文字幕精品一区在线 | 国产成人教育视频在线观看 | 久久成人免费观看草草影院 | 精品中文字幕在线观看 | 在线观看日本永久免费视频 | 成人涩涩屋福利视频 | 91精品国产免费久久国语蜜臀 | 91久久国产综合精品 | 国产精品一区高清在线观看 | 爱视频福利广场 | 成人国产精品免费视频不卡 | 久草高清视频 | 国产精品免费久久久免费 | 自拍三级 | 综合精品 | 国产精品单位女同事在线 | 国产主播大尺度精品福利 | 在线天天干 | 国产精品资源 | 成人在线观看国产 | 久久久久毛片成人精品 | 精品伊人久久久久网站 | 一级黄视频 | 久久99热精品免费观看欧美 | 国产爱视频 | 日本在线理论片 |