亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

Python 操作 Rabbit MQ 基礎 (三)

系統 2370 0

Python 操作 Rabbit MQ 基礎:

一、簡介:

1.介紹:

RabbitMQ是一個消息代理:它接收和轉發消息。

可以把它比作為郵局,當您要發布郵件放在郵箱中時,可以確定這封郵件讓哪位快遞員來進行發送到您的收件人手中。

2.術語:

1.發送消息的程序是 生產者

img

2.隊列可以理解為郵箱,用來存儲一些郵件。隊列的由主機的 存儲器 磁盤限制約束 ,它本質上是一個大的 消息緩沖器 。很多生產者可以發送到一個隊列的消息,并且許多消費者可以嘗試從一個隊列接收數據:

img

3.消費者可以理解為接收人。一個消費者是一個程序, 主要是等待接收信息

img

注意

  • 生產者、消費者、消息隊列 不必駐留在同一個主機上 。

二、發送"Hello world":

實現功能:

生產者 → 消息隊列 → 消費者

  • 生產者發送單個消息到消息隊列中,并由消費者取出,進行處理。

  • 圖解:

    img

RabbitMQ有許多不同語言的客戶端,我們使用的Python客戶端,那么使用 Pika 1.0.0 包:

安裝命令: python -m pip install pika --upgrade

三、生產者:

img

新創建一個程序 send.py ,將向隊列發送一條消息:

            
              #
              
                !
              
              
                /
              
              usr
              
                /
              
              bin
              
                /
              
              python
# 
              
                -
              
              
                *
              
              
                -
              
               coding
              
                :
              
               utf
              
                -
              
              
                8
              
              
                -
              
              
                *
              
              
                -
              
              
                import
              
               pika

# 創建一個實例  本地訪問
              
                IP
              
              地址可以為 localhost 
              
                后面5672是端口地址
              
              
                (
              
              可以不用指定
              
                ,
              
               因為默認就是
              
                5672
              
              
                )
              
              
connection 
              
                =
              
               pika
              
                .
              
              
                BlockingConnection
              
              
                (
              
              pika
              
                .
              
              
                ConnectionParameters
              
              
                (
              
              
                'localhost'
              
              
                ,
              
              
                5672
              
              
                )
              
              
                )
              
              

# 聲明一個管道
              
                ,
              
               在管道里發送消息
channel 
              
                =
              
               connection
              
                .
              
              
                channel
              
              
                (
              
              
                )
              
              

# 在管道里聲明隊列名稱
channel
              
                .
              
              
                queue_declare
              
              
                (
              
              queue
              
                =
              
              
                'hello'
              
              
                )
              
              

# 參數exchange
              
                =
              
              
                ''
              
              表示默認交換
              
                ,
              
               目前記住rabbitmq消息永遠不是直接發送到隊列中的
              
                ,
              
               它需要通過交換
channel
              
                .
              
              
                basic_publish
              
              
                (
              
              exchange
              
                =
              
              
                ''
              
              
                ,
              
               routing_key
              
                =
              
              
                'hello'
              
              
                ,
              
               body
              
                =
              
              
                'hello world'
              
              
                )
              
              

# 隊列關閉
connection
              
                .
              
              
                close
              
              
                (
              
              
                )
              
            
          

注意

  • 若沒有看到’已發送’消息,有可能是消息隊列沒有足夠的磁盤空間可用。默認情況下它至少需要200MB空間,因此會拒絕接收消息。

四、消費者:

img

新創建第二個程序 receive.py ,將從隊列中接收消息并打印出來:

            
              #
              
                !
              
              
                /
              
              usr
              
                /
              
              bin
              
                /
              
              python
# 
              
                -
              
              
                *
              
              
                -
              
               coding
              
                :
              
               utf
              
                -
              
              
                8
              
              
                -
              
              
                *
              
              
                -
              
              
                import
              
               pika

              
                import
              
               time

# 創建實例
connection 
              
                =
              
               pika
              
                .
              
              
                BlockingConnection
              
              
                (
              
              pika
              
                .
              
              
                ConnectionParameters
              
              
                (
              
              
                'localhost'
              
              
                )
              
              
                )
              
              

# 聲明管道
channel 
              
                =
              
               connection
              
                .
              
              
                channel
              
              
                (
              
              
                )
              
              

# 這里又聲明一次
              
                'hello'
              
              隊列
              
                ,
              
              
                因為你不知道哪個程序
              
              
                (
              
              send
              
                .
              
              py
              
                )
              
              先運行
              
                ,
              
               所以要聲明兩次
channel
              
                .
              
              
                queue_declare
              
              
                (
              
              queue
              
                =
              
              
                'hello'
              
              
                )
              
              


def 
              
                callback
              
              
                (
              
              ch
              
                ,
              
               method
              
                ,
              
               properties
              
                ,
              
               body
              
                )
              
              
                :
              
              
                print
              
              
                (
              
              
                'ch:'
              
              
                ,
              
               ch
              
                )
              
              
                print
              
              
                (
              
              
                'method:'
              
              
                ,
              
               method
              
                )
              
              
                print
              
              
                (
              
              
                'properties:'
              
              
                ,
              
               properties
              
                )
              
              
                print
              
              
                (
              
              
                '--------收到消息:---------{}'
              
              
                .
              
              
                format
              
              
                (
              
              body
              
                )
              
              
                )
              
                # 看消息是否已經接收
    time
              
                .
              
              
                sleep
              
              
                (
              
              
                20
              
              
                )
              
                # 睡
              
                20
              
              秒
    ch
              
                .
              
              
                basic_ack
              
              
                (
              
              delivery_tag
              
                =
              
              method
              
                .
              
              delivery_tag
              
                )
              
                # 告訴生產者
              
                ,
              
               消息處理完成


# 消費消息
channel
              
                .
              
              
                basic_consume
              
              
                (
              
              queue
              
                =
              
              
                'hello'
              
              
                ,
              
                # 從指定的消息隊列中接收消息
                      on_message_callback
              
                =
              
              callback
              
                )
              
                # 如果收到消息
              
                ,
              
               就調用callback函數來處理


              
                print
              
              
                (
              
              
                '=======正在等待消息========'
              
              
                )
              
              
channel
              
                .
              
              
                start_consuming
              
              
                (
              
              
                )
              
                # 開始消費消息

            
          

列出目前有的隊列: sudo rabbitmqctl list_queues

五、運行程序:

1.首先在終端上使用我們的程序,先讓 消費者的程序運行起來 ,等待生產者的發送:

            
              python receive
              
                .
              
              py
# 
              
                ===
              
              
                ===
              
              
                =
              
              正在等待消息
              
                ===
              
              
                ===
              
              
                ==
              
            
          

2.現在開始讓生產者,發送消息:

            
              python send
              
                .
              
              py 
# 
              
                --
              
              
                --
              
              
                --
              
              
                --
              
              
                --
              
              
                --
              
              
                --
              
              
                --
              
              
                --
              
              
                --
              
              
                --
              
              發出消息
              
                --
              
              
                --
              
              
                --
              
              
                --
              
              
                --
              
              
                --
              
              
                --
              
              
                --
              
              
                --
              
              
                --
              
              
                -
              
            
          

3.可以看到消費者的打印信息:

            
              
                (
              
              
                'ch:'
              
              
                ,
              
              
                <
              
              BlockingChannel impl
              
                =
              
              
                <
              
              Channel number
              
                =
              
              
                1
              
              
                OPEN
              
               conn
              
                =
              
              
                <
              
              SelectConnection 
              
                OPEN
              
               transport
              
                =
              
              
                <
              
              pika
              
                .
              
              adapters
              
                .
              
              utils
              
                .
              
              io_services_utils
              
                .
              
              _AsyncPlaintextTransport object at 
              
                0x153b590
              
              
                >
              
               params
              
                =
              
              
                <
              
              ConnectionParameters host
              
                =
              
              localhost port
              
                =
              
              
                5672
              
               virtual_host
              
                =
              
              
                /
              
               ssl
              
                =
              
              False
              
                >>>
              
              
                >
              
              
                )
              
              
                (
              
              
                'method:'
              
              
                ,
              
              
                <
              
              Basic
              
                .
              
              
                Deliver
              
              
                (
              
              
                [
              
              
                'consumer_tag=ctag1.cc4070930568408fb20c783f85f9336e'
              
              
                ,
              
              
                'delivery_tag=1'
              
              
                ,
              
              
                'exchange='
              
              
                ,
              
              
                'redelivered=False'
              
              
                ,
              
              
                'routing_key=hello'
              
              
                ]
              
              
                )
              
              
                >
              
              
                )
              
              
                (
              
              
                'properties:'
              
              
                ,
              
              
                <
              
              BasicProperties
              
                >
              
              
                )
              
              
                --
              
              
                --
              
              
                --
              
              
                --
              
              收到消息:
              
                --
              
              
                --
              
              
                --
              
              
                --
              
              
                -
              
              hello world

            
          

4.可以查看一下目前有的隊列:

            
              rabbitmqctl list_queues   
              
                // 執行命令
              
              
Listing queues 
              
                ...
              
              
hello	
              
                0
              
              
                // hello 隊列的名稱  0:消息數量
              
            
          

5.我們已經成功的通過RabbitMQ發送第一條消息,hello world,但是 receive.py 程序不會退出,它將保持準備接收更多消息,使用 Ctrl +c 中斷 。


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

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

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

【本文對您有幫助就好】

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

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 国内精品福利 | 久久久精品影院 | 日本一区二区三区在线 观看网站 | 在线播放不卡 | 欧美成人亚洲高清在线观看 | 小香蕉影院 | 年级的后妈妈2中文翻译 | 色婷婷精品| 草久在线视频 | 日本三级11k影院在线 | 国产亚洲精品久久yy5099 | 在线播放成人毛片免费视 | 亚洲国产精品综合一区在线 | 国产亚洲精品九九久在线观看 | 成人黄色免费网站 | 久久久久久久国产精品影院 | 久久国产精品免费看 | 99久热只有精品视频免费看 | 成人午夜啪啪免费网站 | 一区二区三区久久精品 | 97视频在线免费 | 成人国产在线视频 | 我要看欧美精品一级毛片 | 欧美日韩国产超高清免费看片 | 亚洲区欧美 | 毛片网站在线观看 | 欧美性色福利视频在线观看 | 国产视频手机在线观看 | 久久久精品2018免费观看 | 999福利视频 | 色琪琪永久远网址 | 久久中文字幕亚洲精品最新 | 成熟的女性强烈交性视频 | 久久久无码精品亚洲日韩按摩 | 免费刺激性视频大片区 | 日韩中文精品亚洲第三区 | 中文字幕在线观看免费视频 | 一道精品视频一区二区三区图片 | 思99re久久这里只有精品首页 | 国产日比视频 | 欧美成人免费高清二区三区 |