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

Python環(huán)境下安裝使用異步任務隊列包Celery的基礎教程

 更新時間:2016年05月07日 18:03:42   投稿:goldensun  
這篇文章主要介紹了Python環(huán)境下安裝使用異步任務隊列包Celery的基礎教程,Celery的分布式任務管理適合用于服務器集群的管理和維護,需要的朋友可以參考下

1.簡介

celery(芹菜)是一個異步任務隊列/基于分布式消息傳遞的作業(yè)隊列。它側(cè)重于實時操作,但對調(diào)度支持也很好。
celery用于生產(chǎn)系統(tǒng)每天處理數(shù)以百萬計的任務。
celery是用Python編寫的,但該協(xié)議可以在任何語言實現(xiàn)。它也可以與其他語言通過webhooks實現(xiàn)。
建議的消息代理RabbitMQ的,但提供有限支持Redis, Beanstalk, MongoDB, CouchDB, ,和數(shù)據(jù)庫(使用SQLAlchemy的或Django的 ORM) 。
celery是易于集成Django, Pylons and Flask,使用 django-celery, celery-pylons and Flask-Celery 附加包即可。

2. 安裝
有了上面的概念,需要安裝這么幾個東西:RabbitMQ、SQLAlchemy、Celery
安裝方式也都很簡單: RabbitMQ:
mac下:

brew install rabbitmq

linux:

sudo apt-get install rabbitmq-server

剩下兩個都是Python的東西了,直接pip安裝就好了,對于從來沒有安裝過MySQL驅(qū)動的同學可能需要安裝MySQL-python。
安裝完成之后,啟動服務:

$ rabbitmq-server[回車]

啟動后不要關(guān)閉窗口, 下面操作新建窗口(Tab)

3. 簡單案例
確保你之前的RabbitMQ已經(jīng)啟動。
還是官網(wǎng)的那個例子,在任意目錄新建一個tasks.py的文件,內(nèi)容如下:

from celery import Celery

app = Celery('tasks', broker='amqp://guest@localhost//')

@app.task
def add(x, y):
  return x + y

在同級目錄執(zhí)行:

$ celery -A tasks worker --loglevel=info

該命令的意思是啟動一個worker,把tasks中的任務(add(x,y))把任務放到隊列中。
保持窗口打開,新開一個窗口進入交互模式,python或者ipython:

>>> from tasks import add
>>> add.delay(4, 4)

到此為止,你已經(jīng)可以使用celery執(zhí)行任務了,上面的python交互模式下簡單的調(diào)用了add任務,并傳遞4,4參數(shù)。
但此時有一個問題,你突然想知道這個任務的執(zhí)行結(jié)果和狀態(tài),到底完了沒有。因此就需要設置backend了。
修改之前的tasks.py中的代碼為:

# coding:utf-8
import subprocess
from time import sleep

from celery import Celery

backend = 'db+mysql://root:@192.168.0.102/celery'
broker = 'amqp://guest@192.168.0.102:5672'

app = Celery('tasks', backend=backend, broker=broker)


@app.task
def add(x, y):
  sleep(10)
  return x + y


@app.task
def hostname():
  return subprocess.check_output(['hostname'])

除了添加backend之外,上面還添加了一個who的方法用來測試多服務器操作。修改完成之后,還是按照之前的方式啟動。
同樣進入python的交互模型:

>>> from tasks import add, hostname
>>> r = add.delay(4, 4)
>>> r.ready() # 10s內(nèi)執(zhí)行,會輸出False,因為add中sleep了10s
>>>
>>> r = hostname.delay()
>>> r.result # 輸出你的hostname

4. 測試多服務器
做完上面的測試之后,產(chǎn)生了一個疑惑,Celery叫做分布式任務管理,那它的分布式體現(xiàn)在哪?它的任務都是怎么執(zhí)行的?在哪個機器上執(zhí)行的?
在當前服務器上的celery服務不關(guān)閉的情況下,按照同樣的方式在另外一臺服務器上安裝Celery,并啟動:

$ celery -A tasks worker --loglevel=info

發(fā)現(xiàn)前一個服務器的Celery服務中輸出你剛啟動的服務器的hostname,前提是那臺服務器連上了你的rabbitmq。
然后再進入python交互模式:

>>> from tasks import hostname
>>>
>>> for i in range(10):
...   r = hostname.delay()
...   print r.result # 輸出你的hostname
>>>

看你輸入的內(nèi)容已經(jīng)觀察兩臺服務器上你啟動celery服務的輸出。

5. RabbitMQ遠程連接的問題
一開始測試時遠程服務器無法連接本地的RabbitMQ服務,后來發(fā)現(xiàn)需要設置權(quán)限,在/usr/local/etc/rabbitmq/rabbitmq-env.conf這個文件中,修改NODE_IP_ADDRESS=127.0.0.1中的ip為0.0.0.0。

6. 總結(jié)的說
這篇文章簡單的介紹了Celery的使用,重點還是在分布式的使用。覺得不太爽的地方是,在擴展時,需要重新把代碼(tasks.py)部署一遍,而不是可以直接把tasks進行共享,可能Celery是通過task來進行不同的worker的匹配的?目前還不太了解,等深入使用之后再說。

相關(guān)文章

  • python線程優(yōu)先級隊列知識點總結(jié)

    python線程優(yōu)先級隊列知識點總結(jié)

    在本篇文章里小編給大家整理的一篇關(guān)于python線程優(yōu)先級隊列知識點總結(jié),有興趣的朋友們可以學習參考下。
    2021-02-02
  • tensorflow使用tf.data.Dataset 處理大型數(shù)據(jù)集問題

    tensorflow使用tf.data.Dataset 處理大型數(shù)據(jù)集問題

    這篇文章主要介紹了tensorflow使用tf.data.Dataset 處理大型數(shù)據(jù)集問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • 用python實現(xiàn)打磚塊小游戲

    用python實現(xiàn)打磚塊小游戲

    這篇文章主要為大家詳細介紹了用python實現(xiàn)打磚塊小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • Python3 完全平方數(shù)案例

    Python3 完全平方數(shù)案例

    這篇文章主要介紹了Python3 完全平方數(shù)的案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-03-03
  • 對python中的 os.mkdir和os.mkdirs詳解

    對python中的 os.mkdir和os.mkdirs詳解

    今天小編就為大家分享一篇對python中的 os.mkdir和os.mkdirs詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-10-10
  • Python調(diào)用百度OCR實現(xiàn)圖片文字識別的示例代碼

    Python調(diào)用百度OCR實現(xiàn)圖片文字識別的示例代碼

    這篇文章主要介紹了Python調(diào)用百度OCR實現(xiàn)圖片文字識別的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-07-07
  • python畫圖常見不同圖片格式保存方式

    python畫圖常見不同圖片格式保存方式

    這篇文章主要介紹了python畫圖常見不同圖片格式保存方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • Python合并Excel表(多sheet)的實現(xiàn)

    Python合并Excel表(多sheet)的實現(xiàn)

    這篇文章主要介紹了Python合并Excel表(多sheet)的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-04-04
  • Python+OpenCV實現(xiàn)圖片中的圓形檢測

    Python+OpenCV實現(xiàn)圖片中的圓形檢測

    這篇文章主要介紹了如何利用Python+OpenCV實現(xiàn)檢測圖片中的圓形,文中的示例代碼講解詳細,感興趣的小伙伴快跟隨小編一起學習一下
    2022-04-04
  • python?playwright?庫上傳和下載操作(自動化測試?playwright)

    python?playwright?庫上傳和下載操作(自動化測試?playwright)

    這篇文章主要介紹了python?playwright?庫上傳和下載操作(自動化測試?playwright?),playwright中的上傳和下載比selenium的上傳和下載要簡便些,本文結(jié)合實例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2023-05-05

最新評論