[英]Python script to monitor devices
我被困在一個領域。 我在 MySQL 數據庫中有幾個設備已經設置為不同的輪詢間隔。 例如,我總共有 4 台設備,其中 2 台用戶希望每 5 分鍾輪詢一次,另外兩台每 10 分鍾輪詢一次,每 7 分鍾輪詢一次。
我想在 python 中構建一個解決方案,從數據庫中選擇這些設備及其輪詢間隔,然后開始在它們定義的輪詢間隔內連續輪詢這些設備。
因為我無法創建多個輪詢腳本(每個腳本一個),因為它會過度使用 CPU 資源。 而如果設備數量達到1000,那么一次輪詢所有1000將是一個問題。 它更像是一個持續運行和監控設備的監控解決方案。
我真的被困在這一點上。 我會很感激你在這方面的幫助。
為每個時間間隔生成一個工人將完成這項工作。 相同的代碼看起來有點像這樣:
from time import sleep
from multiprocessing import Process
intervals = [1, 2, 3] # hardcoding it to check, fetching it from db would be better
def generate_poll_worker(interval):
def poll_devices():
while True:
# fetch the devices and poll them
sleep(interval * 60)
return poll_devices
def worker_process(interval):
poll = generate_poll_worker(interval)
poll()
workers = []
for interval in intervals:
worker = Process(target=worker_process, args=(interval,))
worker.start()
workers.append(worker)
for worker in workers:
worker.join()
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.