欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

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

系統 1618 0

1.簡介

celery(芹菜)是一個異步任務隊列/基于分布式消息傳遞的作業隊列。它側重于實時操作,但對調度支持也很好。
celery用于生產系統每天處理數以百萬計的任務。
celery是用Python編寫的,但該協議可以在任何語言實現。它也可以與其他語言通過webhooks實現。
建議的消息代理RabbitMQ的,但提供有限支持Redis, Beanstalk, MongoDB, CouchDB, ,和數據庫(使用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驅動的同學可能需要安裝MySQL-python。
安裝完成之后,啟動服務:

            
$ rabbitmq-server[回車]

          

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

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

            
from celery import Celery

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

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


          

在同級目錄執行:

            
$ celery -A tasks worker --loglevel=info

          

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

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

          

到此為止,你已經可以使用celery執行任務了,上面的python交互模式下簡單的調用了add任務,并傳遞4,4參數。
但此時有一個問題,你突然想知道這個任務的執行結果和狀態,到底完了沒有。因此就需要設置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內執行,會輸出False,因為add中sleep了10s
>>>
>>> r = hostname.delay()
>>> r.result # 輸出你的hostname

          

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

            
$ celery -A tasks worker --loglevel=info

          

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

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

          

看你輸入的內容已經觀察兩臺服務器上你啟動celery服務的輸出。

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

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


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 一区二区三区免费网站 | 国产精品一区二 | 又黄又爽免费无遮挡在线观看 | 天天鲁天天爽天天视频 | 欧美激情二区三区 | 天天操夜夜夜 | 国产1级片 | 成人免费一级毛片在线播放视频 | 99久久久无码国产精品 | 精品在线一区二区 | 自拍偷拍视频网站 | 久久精品小视频 | 日韩精品视频一区二区三区 | 久久中文字幕一区 | www.色黄 | 国产无圣光高清一区二区 | 国产三级做爰在线观看视频 | av色站 | 欧洲精品一区 | 黄片一级毛片 | 日韩欧美一区二区三区 | 九一传媒在线观看 | 挑战者联盟第一季免费观看完整版 | 一区二区三区成人A片在线观看 | 日本吻胸捏胸激烈床戏视频 | 欧美日日操 | 两女互慰磨豆腐视频在线观看 | 日本综合欧美一区二区三区 | 97日日 | 亚洲国产一区二区三区四区 | 成人久久一区 | 日产精品久久久久久久 | 久爱视频www在线播放 | wwwxxx日本在线观看 | 国产在线看片 | 日韩黄色一级毛片 | 一级片视频免费观看 | 这里只有精品在线视频观看 | 草莓视频午夜在线观影 | 午夜在线视频一区二区三区 | 成人国产网站 |