多機調度問題python(多機調度問題動態規劃)

本文目錄一覽:

怎麼用Python調度使用voice portal

總結有三種方式。

1. 使用wx.Timer. 當然前提是使用wxpython進行編程。

這種方式的好處是,wx.Timer默認支持重複執行。但是有時間限制,設定輪循(延遲)時間最好在1ms以內,最大不能超過1s。超過會引起什麼樣的結果, 我尚未測試。

2. 使用sched模塊。

該模塊是python 2.5, 2.6內置模塊,使用比較簡單, 而且可以配置多個schedule。

但是該模塊只能在單線程中使用, 當schedule中的事件隊列(event queue)非空時,就不能為該scheduler添加新的事件。

3. 使用threading模塊的Timer class。

使用Timer, 就可以避免sched模塊的缺點。因為每一個事件,都是使用一個Timer實例進行管理,也就是一個單獨的線程存在,這樣就避免了不能動態添加scheduler的問題。

簡單強大的Python庫!Schedule—實用的周期任務調度工具

如果你想在Linux服務器上周期性地執行某個 Python 腳本,最出名的選擇應該是 Crontab 腳本,但是 Crontab 具有以下缺點:

1.不方便執行 秒級的任務 。

2.當需要執行的定時任務有上百個的時候,Crontab的 管理就會特別不方便 。

另外一個選擇是 Celery,但是 Celery 的配置比較麻煩,如果你只是需要一個輕量級的調度工具,Celery 不會是一個好選擇。

在你想要使用一個輕量級的任務調度工具,而且希望它盡量簡單、容易使用、不需要外部依賴,最好能夠容納 Crontab 的所有基本功能,那麼 Schedule 模塊是你的不二之選。

使用它來調度任務可能只需要幾行代碼,感受一下:

上面的代碼表示每10分鐘執行一次 job 函數,非常簡單方便。你只需要引入 schedule 模塊,通過調用 scedule.every(時間數).時間類型.do(job) 發布周期任務。

發布後的周期任務需要用 run_pending 函數來檢測是否執行,因此需要一個 While 循環不斷地輪詢這個函數。

下面具體講講Schedule模塊的安裝和初級、進階使用方法。

1.準備

請選擇以下任一種方式輸入命令安裝依賴 :

1. Windows 環境 打開 Cmd (開始-運行-CMD)。

2. MacOS 環境 打開 Terminal (command+空格輸入Terminal)。

3. 如果你用的是 VSCode編輯器 或 Pycharm,可以直接使用界面下方的Terminal.

2.基本使用

最基本的使用在文首已經提到過,下面給大家展示更多的調度任務例子:

可以看到,從月到秒的配置,上面的例子都覆蓋到了。不過 如果你想只運行一次任務 的話,可以這麼配:

參數傳遞

如果你有參數需要傳遞給作業去執行,你只需要這麼做:

獲取目前所有的作業

如果你想獲取目前所有的作業:

取消所有作業

如果某些機制觸發了,你需要立即清除當前程序的所有作業:

標籤功能

在設置作業的時候,為了後續方便管理作業,你可以給作業打個標籤,這樣你可以通過標籤過濾獲取作業或取消作業。

設定作業截止時間

如果你需要讓某個作業到某個時間截止,你可以通過這個方法:

截止日期之後,該作業將無法運行。

立即運行所有作業,而不管其安排如何

如果某個機制觸發了,你需要立即運行所有作業,可以調用 schedule.run_all :

3.高級使用

裝飾器安排作業

如果你覺得設定作業這種形式太啰嗦了,也可以使用裝飾器模式:

並行執行

默認情況下,Schedule 按順序執行所有作業。其背後的原因是,很難找到讓每個人都高興的並行執行模型。

不過你可以通過多線程的形式來運行每個作業以解決此限制:

日誌記錄

Schedule 模塊同時也支持 logging 日誌記錄,這麼使用:

效果如下:

異常處理

Schedule 不會自動捕捉異常,它遇到異常會直接拋出,這會導致一個嚴重的問題: 後續所有的作業都會被中斷執行 ,因此我們需要捕捉到這些異常。

你可以手動捕捉,但是某些你預料不到的情況需要程序進行自動捕獲,加一個裝飾器就能做到了:

這樣, bad_task 在執行時遇到的任何錯誤,都會被 catch_exceptions 捕獲,這點在保證調度任務正常運轉的時候非常關鍵。

python 調度sell

有很多方式,首先要解決的是你如何從A機器訪問到B機器。

可以通過ssh,可以用paramiko模塊來做,登陸、執行和回顯都有例子,比較方便

另外可以通過自己寫socket server,部署都B機器上接收指令,A機器負責調度

當然http的方式也行,如果B機器上有web服務器,那麼執行webshell也是很方便的,關鍵是你要做好安全措施,例如專門開個端口監聽訪問webshell的請求,並限制來源IP。

方式有很多,如果是做多服務器管理的,從效率上來講,socket最優

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/279062.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-20 15:02
下一篇 2024-12-20 15:02

相關推薦

  • Python中引入上一級目錄中函數

    Python中經常需要調用其他文件夾中的模塊或函數,其中一個常見的操作是引入上一級目錄中的函數。在此,我們將從多個角度詳細解釋如何在Python中引入上一級目錄的函數。 一、加入環…

    編程 2025-04-29
  • Python官網中文版:解決你的編程問題

    Python是一種高級編程語言,它可以用於Web開發、科學計算、人工智能等領域。Python官網中文版提供了全面的資源和教程,可以幫助你入門學習和進一步提高編程技能。 一、Pyth…

    編程 2025-04-29
  • Python列表中負數的個數

    Python列表是一個有序的集合,可以存儲多個不同類型的元素。而負數是指小於0的整數。在Python列表中,我們想要找到負數的個數,可以通過以下幾個方面進行實現。 一、使用循環遍歷…

    編程 2025-04-29
  • Python周杰倫代碼用法介紹

    本文將從多個方面對Python周杰倫代碼進行詳細的闡述。 一、代碼介紹 from urllib.request import urlopen from bs4 import Bea…

    編程 2025-04-29
  • Python計算陽曆日期對應周幾

    本文介紹如何通過Python計算任意陽曆日期對應周幾。 一、獲取日期 獲取日期可以通過Python內置的模塊datetime實現,示例代碼如下: from datetime imp…

    編程 2025-04-29
  • 如何查看Anaconda中Python路徑

    對Anaconda中Python路徑即conda環境的查看進行詳細的闡述。 一、使用命令行查看 1、在Windows系統中,可以使用命令提示符(cmd)或者Anaconda Pro…

    編程 2025-04-29
  • PHP和Python哪個好找工作?

    PHP和Python都是非常流行的編程語言,它們被廣泛應用於不同領域的開發中。但是,在考慮擇業方向的時候,很多人都會有一個問題:PHP和Python哪個好找工作?這篇文章將從多個方…

    編程 2025-04-29
  • Python for循環求1到100的積

    Python中的for循環可以方便地遍歷列表、元組、字典等數據類型。本文將以Python for循環求1到100的積為中心,從多個方面進行詳細闡述。 一、for循環語法 Pytho…

    編程 2025-04-29
  • Python程序需要編譯才能執行

    Python 被廣泛應用於數據分析、人工智能、科學計算等領域,它的靈活性和簡單易學的性質使得越來越多的人喜歡使用 Python 進行編程。然而,在 Python 中程序執行的方式不…

    編程 2025-04-29
  • Python字典去重複工具

    使用Python語言編寫字典去重複工具,可幫助用戶快速去重複。 一、字典去重複工具的需求 在使用Python編寫程序時,我們經常需要處理數據文件,其中包含了大量的重複數據。為了方便…

    編程 2025-04-29

發表回復

登錄後才能評論