欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python實現(xiàn)監(jiān)控遠程主機實時數(shù)據(jù)的示例詳解

 更新時間:2023年04月06日 08:44:27   作者:Day-3  
這篇文章主要為大家詳細介紹了Python如何使用Socket庫和相應的第三方庫來監(jiān)控遠程主機的實時數(shù)據(jù),比如CPU使用率、內(nèi)存使用率、網(wǎng)絡帶寬等,感興趣的可以了解一下

0 簡述

實時監(jiān)控應用程序,使用Python的Socket庫和相應的第三方庫來監(jiān)控遠程主機的實時數(shù)據(jù),比如CPU使用率、內(nèi)存使用率、網(wǎng)絡帶寬等信息。可以允許多個用戶同時訪問服務端。
注:部分指令響應較慢,請耐心等待。

1 程序說明文檔

1.1 服務端

本程序為一個基于TCP協(xié)議的服務端程序,可以接收客戶端發(fā)送的指令并執(zhí)行相應的操作,最終將操作結果返回給客戶端。程序運行在localhost(即本機)的8888端口。

主要功能及指令:

• 獲取CPU使用率:指令“cpu”

• 獲取內(nèi)存使用率:指令“memory”

• 獲取網(wǎng)絡帶寬信息:指令“network”

• 獲取當前登錄用戶:指令“user”

• 獲取系統(tǒng)負載情況:指令“loadavg”

• 獲取當前時間:指令“time”

• 獲取進程列表:指令“process”

• 獲取系統(tǒng)信息:指令“system”

• 獲取網(wǎng)絡連接列表:指令“connection”

• 獲取GPU使用情況:指令“gpu”

• 獲取磁盤使用情況:指令“disk”

對于不同的指令,程序采用不同的庫函數(shù)進行數(shù)據(jù)獲取和處理,具體如下:

• 對于指令“cpu”,使用psutil庫獲取CPU使用率。

• 對于指令“memory”,使用psutil庫獲取內(nèi)存使用率。

• 對于指令“network”,使用speedtest-cli庫獲取網(wǎng)絡帶寬信息。

• 對于指令“user”,使用psutil庫獲取當前登錄用戶。

• 對于指令“loadavg”,使用os庫獲取系統(tǒng)負載情況。

• 對于指令“time”,使用datetime庫獲取當前時間。

• 對于指令“process”,使用psutil庫獲取進程列表。程序將進程按照內(nèi)存使用量排序,只返回前10個進程。

• 對于指令“system”,使用platform庫獲取系統(tǒng)信息。

• 對于指令“connection”,使用psutil庫獲取網(wǎng)絡連接列表。程序將連接按照進程ID排序,只返回前10個連接。

• 對于指令“gpu”,使用nvidia-smi工具獲取GPU使用情況。

• 對于指令“disk”,使用psutil庫獲取磁盤使用情況。

每個指令的處理結果均以字符串形式返回給客戶端。在處理指令時,程序會判斷接收到的數(shù)據(jù)是否為空。如果為空,則斷開連接并關閉客戶端套接字。程序中的handle_client函數(shù)是負責與單個客戶端通信的線程函數(shù),每個客戶端連接都會啟動一個線程。

1.2 客戶端

該程序是一個簡單的TCP客戶端,可以連接到一個服務器并向其發(fā)送請求,然后等待服務器的響應。程序使用Python的socket模塊來創(chuàng)建TCP套接字,并使用connect方法連接到一個服務器地址。程序通過循環(huán)不斷地等待用戶輸入請求數(shù)據(jù)類型,然后將請求數(shù)據(jù)類型編碼成UTF-8格式并使用sendall方法將其發(fā)送給服務器。接著程序等待服務器響應,并將響應數(shù)據(jù)解碼成UTF-8格式并打印出來。最后,程序關閉客戶端套接字。

程序的主要流程如下:

1. 導入socket模塊。

2. 創(chuàng)建一個TCP套接字對象。

3. 連接到指定的服務器地址。

4. 循環(huán)等待用戶輸入請求數(shù)據(jù)類型。

5. 將請求數(shù)據(jù)類型編碼成UTF-8格式并發(fā)送給服務器。

6. 等待服務器響應并接收響應數(shù)據(jù)。

7. 將響應數(shù)據(jù)解碼成UTF-8格式并打印出來。

8. 關閉客戶端套接字。

該程序可以用于與提供特定數(shù)據(jù)類型的服務器進行通信。用戶可以輸入不同的請求數(shù)據(jù)類型來獲取不同類型的數(shù)據(jù)。服務器將根據(jù)請求類型返回相應的數(shù)據(jù)。程序的運行依賴于服務器的可用性和響應速度。如果服務器無法響應,程序將一直等待,直到服務器響應或者程序被中斷。

2 代碼

服務端

import os
import socket
import subprocess
import threading
from datetime import datetime
from sys import platform

import psutil
from speedtest import Speedtest

# 創(chuàng)建TCP套接字
server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

# 綁定IP和端口
server_address = ('localhost', 8888)
server_socket.bind(server_address)

# 監(jiān)聽連接請求
server_socket.listen(5)


def handle_client(client_socket, client_address):
    while True:
        # 接收客戶端發(fā)送的數(shù)據(jù)
        data = client_socket.recv(1024)

        # 如果接收到空數(shù)據(jù),則斷開連接
        if not data:
            client_socket.close()
            print(f"Connection with {client_address} closed")
            break

        # 處理接收到的數(shù)據(jù)
        request = data.decode('utf-8')
        if request == 'cpu':
            # 使用psutil庫獲取CPU使用率
            cpu_percent = psutil.cpu_percent(interval=1)
            response_data = f'CPU使用率:{cpu_percent}%'.encode('utf-8')
        elif request == 'memory':
            # 使用psutil庫獲取內(nèi)存使用率
            memory_percent = psutil.virtual_memory().percent
            response_data = f'內(nèi)存使用率:{memory_percent}%'.encode('utf-8')
        elif request == 'network':
            # 使用speedtest-cli庫獲取網(wǎng)絡帶寬信息
            st = Speedtest()
            download_speed = st.download()
            upload_speed = st.upload()
            response_data = f'下載速度:{download_speed / 1000000}Mbps,上傳速度:{upload_speed / 1000000}Mbps'.encode('utf-8')
        elif request == 'user':
            # 使用psutil庫獲取當前登錄用戶
            username = psutil.users()[0].name
            response_data = f'當前登錄用戶:{username}'.encode('utf-8')
        elif request == 'loadavg':
            # 使用os庫獲取系統(tǒng)負載情況
            load_avg = os.getloadavg()
            response_data = f'系統(tǒng)負載情況:{load_avg}'.encode('utf-8')
        elif request == 'time':
            # 使用datetime庫獲取當前時間
            current_time = datetime.datetime.now()
            response_data = f'當前時間:{current_time}'.encode('utf-8')
        elif request == 'process':
            # 使用psutil庫獲取進程列表
            process_list = []
            for process in psutil.process_iter(['pid', 'name', 'memory_info']):
                try:
                    process_list.append((process.info['pid'], process.info['name'], process.info['memory_info'].rss))
                except (psutil.AccessDenied, psutil.NoSuchProcess):
                    pass
            process_list.sort(key=lambda x: x[2], reverse=True)
            response_data = ''
            for i, (pid, name, memory) in enumerate(process_list[:10]):
                response_data += f'{i + 1}. 進程名稱:{name},進程ID:{pid},占用內(nèi)存:{memory / 1024 / 1024:.2f}MB\n'
            response_data = response_data.encode('utf-8')
        elif request == 'system':
            # 使用platform庫獲取系統(tǒng)信息
            system_info = f'操作系統(tǒng):{platform.system()} {platform.release()}\n處理器:{platform.processor()}\nPython版本:{platform.python_version()}'
            response_data = system_info.encode('utf-8')
        elif request == 'connection':
            # 使用psutil庫獲取網(wǎng)絡連接列表
            conn_list = []
            for conn in psutil.net_connections():
                if conn.status == psutil.CONN_ESTABLISHED:
                    conn_list.append((conn.laddr.ip, conn.laddr.port, conn.raddr.ip, conn.raddr.port, conn.pid))
            conn_list.sort(key=lambda x: x[4])
            response_data = ''
            for i, (laddr_ip, laddr_port, raddr_ip, raddr_port, pid) in enumerate(conn_list[:10]):
                response_data += f'{i + 1}. 本地地址:{laddr_ip}:{laddr_port},遠程地址:{raddr_ip}:{raddr_port},進程ID:{pid}\n'
            response_data = response_data.encode('utf-8')
        elif request == 'disk':
            # 使用psutil庫獲取磁盤使用情況
            disk_usage = psutil.disk_usage('/')
            disk_info = f'磁盤總容量:{disk_usage.total / 1024 / 1024 / 1024:.2f}GB,已用容量:{disk_usage.used / 1024 / 1024 / 1024:.2f}GB,可用容量:{disk_usage.free / 1024 / 1024 / 1024:.2f}GB'
            response_data = disk_info.encode('utf-8')
        elif request == 'load':
            # 使用psutil庫獲取系統(tǒng)負載
            load_avg = psutil.getloadavg()
            load_info = f'1分鐘內(nèi)平均負載:{load_avg[0]:.2f},5分鐘內(nèi)平均負載:{load_avg[1]:.2f},15分鐘內(nèi)平均負載:{load_avg[2]:.2f}'
            response_data = load_info.encode('utf-8')
        elif request == 'thread':
            # 使用psutil庫獲取進程線程數(shù)
            thread_info = f'當前進程線程數(shù):{psutil.Process().num_threads()}'
            response_data = thread_info.encode('utf-8')
        else:
            response_data = b'Invalid request'

        # 發(fā)送響應數(shù)據(jù)
        client_socket.sendall(response_data)


# 接收多個客戶端連接
while True:
    client_socket, client_address = server_socket.accept()
    print(f"New connection from {client_address}")
    # 創(chuàng)建新線程處理客戶端連接
    client_thread = threading.Thread(target=handle_client, args=(client_socket, client_address))
    client_thread.start()

客戶端

import socket

# 創(chuàng)建TCP套接字
client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

# 連接服務器
server_address = ('localhost', 8888)
client_socket.connect(server_address)

while True:
    # 發(fā)送請求數(shù)據(jù)給服務器
    request = input("請輸入要請求的數(shù)據(jù)類型(cpu/memory/network/user/loadavg/time/process/system/connection/disk/load/thread):")
    client_socket.sendall(request.encode('utf-8'))

    # 接收服務器響應數(shù)據(jù)
    response_data = client_socket.recv(1024)

    # 處理接收到的數(shù)據(jù)
    response = response_data.decode('utf-8')
    print(response)

# 關閉客戶端套接字
client_socket.close()

到此這篇關于Python實現(xiàn)監(jiān)控遠程主機實時數(shù)據(jù)的示例詳解的文章就介紹到這了,更多相關Python監(jiān)控主機數(shù)據(jù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Django model反向關聯(lián)名稱的方法

    Django model反向關聯(lián)名稱的方法

    今天小編就為大家分享一篇Django model反向關聯(lián)名稱的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-12-12
  • 用Python實現(xiàn)數(shù)據(jù)篩選與匹配實例

    用Python實現(xiàn)數(shù)據(jù)篩選與匹配實例

    大家好,本篇文章主要講的是用Python實現(xiàn)數(shù)據(jù)篩選與匹配實例,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-02-02
  • python庫pydantic的簡易入門教程

    python庫pydantic的簡易入門教程

    pydantic庫是一種常用的用于數(shù)據(jù)接口schema定義與檢查的庫,通過pydantic庫,我們可以更為規(guī)范地定義和使用數(shù)據(jù)接口,下面這篇文章主要給大家介紹了關于python庫pydantic的簡易入門教程,需要的朋友可以參考下
    2022-03-03
  • 利用Python實現(xiàn)讀取Word表格計算匯總并寫入Excel

    利用Python實現(xiàn)讀取Word表格計算匯總并寫入Excel

    這篇文章主要給大家介紹了關于如何利用Python實現(xiàn)讀取Word表格計算匯總并寫入Excel的相關資料,文中通過實例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2022-01-01
  • 10分鐘用Python快速搭建全文搜索引擎詳解流程

    10分鐘用Python快速搭建全文搜索引擎詳解流程

    讀萬卷書不如行萬里路,只學書上的理論是遠遠不夠的,只有在實戰(zhàn)中才能獲得能力的提升,本篇文章帶你用python花10分鐘迅速搭建一個好玩的Python全文搜索引擎,大家可以在過程中查缺補漏,提升水平
    2021-10-10
  • Jupyter notebook如何修改平臺字體

    Jupyter notebook如何修改平臺字體

    這篇文章主要介紹了Jupyter notebook如何修改平臺字體,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-05-05
  • 推薦系統(tǒng)MostPopular算法的Python實現(xiàn)方式

    推薦系統(tǒng)MostPopular算法的Python實現(xiàn)方式

    這篇文章主要介紹了推薦系統(tǒng)MostPopular算法的Python實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • PyQt5+QtChart實現(xiàn)繪制極坐標圖

    PyQt5+QtChart實現(xiàn)繪制極坐標圖

    QChart是一個QGraphicScene中可以顯示的QGraphicsWidget。本文將利用QtChart實現(xiàn)極坐標圖的繪制,文中的示例代碼講解詳細,感興趣的小伙伴可以了解一下
    2022-12-12
  • 簡析Python函數(shù)式編程字符串和元組及函數(shù)分類與高階函數(shù)

    簡析Python函數(shù)式編程字符串和元組及函數(shù)分類與高階函數(shù)

    這篇文章主要介紹了Python函數(shù)式編程中的字符串、元組及函數(shù)分類與高階函數(shù),有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2021-09-09
  • Python實現(xiàn)可視化CSV文件中的數(shù)據(jù)

    Python實現(xiàn)可視化CSV文件中的數(shù)據(jù)

    CSV文件包含許多記錄,數(shù)據(jù)分布在各行和各列中,在這篇文章中,小編主要為大家詳細介紹了Python如何實現(xiàn)可視化CSV文件中的數(shù)據(jù),感興趣的小伙伴可以跟隨小編一起學習一下
    2023-11-11

最新評論