久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

RabbitMQ从入门到精通

發(fā)布時間:2024/7/23 编程问答 60 豆豆
生活随笔 收集整理的這篇文章主要介紹了 RabbitMQ从入门到精通 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

?

From:http://blog.csdn.net/column/details/rabbitmq.html

?

?

RabbitMQ 介紹

?

歷史

?

? ? RabbitMQ是一個由erlang開發(fā)的AMQP(Advanced Message Queue )的開源實現(xiàn)。AMQP 的出現(xiàn)其實也是應了廣大人民群眾的需求,雖然在同步消息通訊的世界里有很多公開標準(如 COBAR的 IIOP ,或者是 SOAP 等),但是在異步消息處理中卻不是這樣,只有大企業(yè)有一些商業(yè)實現(xiàn)(如微軟的 MSMQ ,IBM 的 Websphere MQ 等),因此,在 2006 年的 6 月,Cisco 、Redhat、iMatix 等聯(lián)合制定了 AMQP 的公開標準。

??? RabbitMQ是由RabbitMQ?Technologies Ltd開發(fā)并且提供商業(yè)支持的。該公司在2010年4月被SpringSource(VMWare的一個部門)收購。在2013年5月被并入Pivotal。其實VMWare,Pivotal和EMC本質(zhì)上是一家的。不同的是VMWare是獨立上市子公司,而Pivotal是整合了EMC的某些資源,現(xiàn)在并沒有上市。

??? RabbitMQ的官網(wǎng)是:http://www.rabbitmq.com

?

?

?

應用場景

?

?

? ? ?言歸正傳。RabbitMQ,或者說AMQP解決了什么問題,或者說它的應用場景是什么?

???? 對于一個大型的軟件系統(tǒng)來說,它會有很多的組件或者說模塊或者說子系統(tǒng)或者(subsystem or Component or submodule)。那么這些模塊的如何通信?這和傳統(tǒng)的IPC有很大的區(qū)別。傳統(tǒng)的IPC很多都是在單一系統(tǒng)上的,模塊耦合性很大,不適合擴展(Scalability);如果使用socket那么不同的模塊的確可以部署到不同的機器上,但是還是有很多問題需要解決。比如:

?1)信息的發(fā)送者和接收者如何維持這個連接,如果一方的連接中斷,這期間的數(shù)據(jù)如何方式丟失?

?2)如何降低發(fā)送者和接收者的耦合度?

?3)如何讓Priority高的接收者先接到數(shù)據(jù)?

?4)如何做到load balance?有效均衡接收者的負載?

?5)如何有效的將數(shù)據(jù)發(fā)送到相關的接收者?也就是說將接收者subscribe 不同的數(shù)據(jù),如何做有效的filter。

?6)如何做到可擴展,甚至將這個通信模塊發(fā)到cluster上?

?7)如何保證接收者接收到了完整,正確的數(shù)據(jù)?

? AMDQ協(xié)議解決了以上的問題,而RabbitMQ實現(xiàn)了AMQP。

?

系統(tǒng)架構

?

?

?

成為系統(tǒng)架構可能不太合適,可能叫應用場景的系統(tǒng)架構更合適。

??

??? 這個系統(tǒng)架構圖版權屬于sunjun041640。

????RabbitMQ Server: 也叫broker server,它不是運送食物的卡車,而是一種傳輸服務。原話是RabbitMQisn’t a food truck, it’s a delivery service. 他的角色就是維護一條從Producer到Consumer的路線,保證數(shù)據(jù)能夠按照指定的方式進行傳輸。但是這個保證也不是100%的保證,但是對于普通的應用來說這已經(jīng)足夠了。當然對于商業(yè)系統(tǒng)來說,可以再做一層數(shù)據(jù)一致性的guard,就可以徹底保證系統(tǒng)的一致性了。

????Client A & B: 也叫Producer,數(shù)據(jù)的發(fā)送方。createmessages and publish (send) them to a broker server (RabbitMQ).一個Message有兩個部分:payload(有效載荷)和label(標簽)。payload顧名思義就是傳輸?shù)臄?shù)據(jù)。label是exchange的名字或者說是一個tag,它描述了payload,而且RabbitMQ也是通過這個label來決定把這個Message發(fā)給哪個Consumer。AMQP僅僅描述了label,而RabbitMQ決定了如何使用這個label的規(guī)則。

????Client 1,2,3:也叫Consumer,數(shù)據(jù)的接收方。Consumersattach to a broker server (RabbitMQ) and subscribe to a queue。把queue比作是一個有名字的郵箱。當有Message到達某個郵箱后,RabbitMQ把它發(fā)送給它的某個訂閱者即Consumer。當然可能會把同一個Message發(fā)送給很多的Consumer。在這個Message中,只有payload,label已經(jīng)被刪掉了。對于Consumer來說,它是不知道誰發(fā)送的這個信息的。就是協(xié)議本身不支持。但是當然了如果Producer發(fā)送的payload包含了Producer的信息就另當別論了。

? ?? 對于一個數(shù)據(jù)從Producer到Consumer的正確傳遞,還有三個概念需要明確:exchanges, queues and bindings。

????????Exchanges?are where producers publish their messages.

????????Queuesare where the messages end up and are received by consumers

????????Bindings?are how the messages get routed from the exchange to particular queues.

?? 還有幾個概念是上述圖中沒有標明的,那就是Connection(連接),Channel(通道,頻道)。

?

???Connection: 就是一個TCP的連接。Producer和Consumer都是通過TCP連接到RabbitMQ Server的。以后我們可以看到,程序的起始處就是建立這個TCP連接。

???Channels:?虛擬連接。它建立在上述的TCP連接中。數(shù)據(jù)流動都是在Channel中進行的。也就是說,一般情況是程序起始建立TCP連接,第二步就是建立這個Channel。

????那么,為什么使用Channel,而不是直接使用TCP連接?

??? 對于OS來說,建立和關閉TCP連接是有代價的,頻繁的建立關閉TCP連接對于系統(tǒng)的性能有很大的影響,而且TCP的連接數(shù)也有限制,這也限制了系統(tǒng)處理高并發(fā)的能力。但是,在TCP連接中建立Channel是沒有上述代價的。對于Producer或者Consumer來說,可以并發(fā)的使用多個Channel進行Publish或者Receive。有實驗表明,1s的數(shù)據(jù)可以Publish10K的數(shù)據(jù)包。當然對于不同的硬件環(huán)境,不同的數(shù)據(jù)包大小這個數(shù)據(jù)肯定不一樣,但是我只想說明,對于普通的Consumer或者Producer來說,這已經(jīng)足夠了。如果不夠用,你考慮的應該是如何細化split你的設計。

?

進一步的細節(jié)闡明

?

?

使用ack確認Message的正確傳遞

?

默認情況下,如果Message 已經(jīng)被某個Consumer正確的接收到了,那么該Message就會被從queue中移除。當然也可以讓同一個Message發(fā)送到很多的Consumer。

??? 如果一個queue沒被任何的Consumer Subscribe(訂閱),那么,如果這個queue有數(shù)據(jù)到達,那么這個數(shù)據(jù)會被cache,不會被丟棄。當有Consumer時,這個數(shù)據(jù)會被立即發(fā)送到這個Consumer,這個數(shù)據(jù)被Consumer正確收到時,這個數(shù)據(jù)就被從queue中刪除。

???? 那么什么是正確收到呢?通過ack。每個Message都要被acknowledged(確認,ack)。我們可以顯示的在程序中去ack,也可以自動的ack。如果有數(shù)據(jù)沒有被ack,那么:

???? RabbitMQ Server會把這個信息發(fā)送到下一個Consumer。

??? 如果這個app有bug,忘記了ack,那么RabbitMQ Server不會再發(fā)送數(shù)據(jù)給它,因為Server認為這個Consumer處理能力有限。

?? 而且ack的機制可以起到限流的作用(Benefitto throttling):在Consumer處理完成數(shù)據(jù)后發(fā)送ack,甚至在額外的延時后發(fā)送ack,將有效的balance Consumer的load。

?? 當然對于實際的例子,比如我們可能會對某些數(shù)據(jù)進行merge,比如merge 4s內(nèi)的數(shù)據(jù),然后sleep 4s后再獲取數(shù)據(jù)。特別是在監(jiān)聽系統(tǒng)的state,我們不希望所有的state實時的傳遞上去,而是希望有一定的延時。這樣可以減少某些IO,而且終端用戶也不會感覺到。

?

Reject a message

?

? ?有兩種方式,第一種的Reject可以讓RabbitMQ Server將該Message 發(fā)送到下一個Consumer。第二種是從queue中立即刪除該Message。

?

Creating a queue

? ? ??Consumer和Procuder都可以通過?queue.declare?創(chuàng)建queue。對于某個Channel來說,Consumer不能declare一個queue,卻訂閱其他的queue。當然也可以創(chuàng)建私有的queue。這樣只有app本身才可以使用這個queue。queue也可以自動刪除,被標為auto-delete的queue在最后一個Consumer unsubscribe后就會被自動刪除。那么如果是創(chuàng)建一個已經(jīng)存在的queue呢?那么不會有任何的影響。需要注意的是沒有任何的影響,也就是說第二次創(chuàng)建如果參數(shù)和第一次不一樣,那么該操作雖然成功,但是queue的屬性并不會被修改。

?

? ??那么誰應該負責創(chuàng)建這個queue呢?是Consumer,還是Producer?

如果queue不存在,當然Consumer不會得到任何的Message。但是如果queue不存在,那么Producer Publish的Message會被丟棄。所以,還是為了數(shù)據(jù)不丟失,Consumer和Producer都try to create the queue!反正不管怎么樣,這個接口都不會出問題。

?? queue對load balance的處理是完美的。對于多個Consumer來說,RabbitMQ 使用循環(huán)的方式(round-robin)的方式均衡的發(fā)送給不同的Consumer。

Exchanges

?

? ? 從架構圖可以看出,Procuder Publish的Message進入了Exchange。接著通過“routing keys”, RabbitMQ會找到應該把這個Message放到哪個queue里。queue也是通過這個routing keys來做的綁定。

???? 有三種類型的Exchanges:direct, fanout,topic。 每個實現(xiàn)了不同的路由算法(routing algorithm)。

·????????Direct exchange: 如果 routing key 匹配, 那么Message就會被傳遞到相應的queue中。其實在queue創(chuàng)建時,它會自動的以queue的名字作為routing key來綁定那個exchange。

·????????Fanout exchange: 會向響應的queue廣播。

·????????Topic exchange: 對key進行模式匹配,比如ab*可以傳遞到所有ab*的queue。

?

Virtual hosts

?

?

? ?每個virtual host本質(zhì)上都是一個RabbitMQ Server,擁有它自己的queue,exchagne,和bings rule等等。這保證了你可以在多個不同的application中使用RabbitMQ。

?? 接下來我會使用Python來說明RabbitMQ的使用方法。

?

python 使用 RabbitMQ 寫 "Hello World"

?

http://www.rabbitmq.com/tutorials/tutorial-one-python.html

?

使用Python(pika 0.9.8)實現(xiàn)從Producer到Consumer傳遞數(shù)據(jù)”Hello, World“。

?

? ? ?RabbitMQ實現(xiàn)了AMQP定義的消息隊列。它實現(xiàn)的功能”非常簡單“:從Producer接收數(shù)據(jù)然后傳遞到Consumer。它能保證多并發(fā),數(shù)據(jù)安全傳遞,可擴展。

???? 和任何的Hello world一樣,它們都不復雜。我們將會設計兩個程序,一個發(fā)送Hello world,另一個接收這個數(shù)據(jù)并且打印到屏幕。
????? 整體的設計如下圖:

?

?

環(huán)境配置

?

?

?

RabbitMQ 實現(xiàn)了AMQP。因此,我們需要安裝AMPQ的library。幸運的是對于多種編程語言都有實現(xiàn)。我們可以使用以下lib的任何一個:

  • py-amqplib??
  • txAMQP
  • pika

在這里我們將使用pika. 可以通過?pip?包管理工具來安裝:

$ sudo pip install pika==0.9.8

?

?

這個安裝依賴于pip和Git-core。

  • On Ubuntu:

    $ sudo apt-get install python-pip git-core
  • On Debian:

    $ sudo apt-get install python-setuptools git-core $ sudo easy_install pip
  • On Windows:To install easy_install, run the MS Windows Installer for?setuptools

    > easy_install pip > pip install pika==0.9.8

?

Sending

?

?

?

第一個program?send.py:發(fā)送Hello world 到queue。正如我們在上篇文章提到的,你程序的第一句話就是建立連接,第二句話就是創(chuàng)建channel:

#!/usr/bin/env python import pika connection = pika.BlockingConnection(pika.ConnectionParameters( 'localhost')) channel = connection.channel()

創(chuàng)建連接傳入的參數(shù)就是RabbitMQ Server的ip或者name。關于誰創(chuàng)建queue,上面也討論過:Producer和Consumer都應該去創(chuàng)建。接下來我們創(chuàng)建名字為hello的queue:

?

channel.queue_declare(queue='hello')

?

創(chuàng)建了channel,我們可以通過相應的命令來list queue:

?

$ sudo rabbitmqctl list_queues Listing queues ... hello 0 ...done.

?

現(xiàn)在我們已經(jīng)準備好了發(fā)送了。

從架構圖可以看出,Producer只能發(fā)送到exchange,它是不能直接發(fā)送到queue的。

現(xiàn)在我們使用默認的exchange(名字是空字符)。這個默認的exchange允許我們發(fā)送給指定的queue。routing_key就是指定的queue名字。

?

channel.basic_publish(exchange='', routing_key='hello', body='Hello World!') print " [x] Sent 'Hello World!'"

?

退出前別忘了關閉connection。

?

connection.close()

?

Receiving

?

?

第二個program?receive.py?將從queue中獲取Message并且打印到屏幕。

第一步還是創(chuàng)建connection。第二步創(chuàng)建channel。第三步創(chuàng)建queue,name = hello:

?

?

?

channel.queue_declare(queue='hello')

?

接下來要subscribe了。在這之前,需要聲明一個回調(diào)函數(shù)來處理接收到的數(shù)據(jù)。

?

def callback(ch, method, properties, body): print " [x] Received %r" % (body,)

?

subscribe:

?

channel.basic_consume(callback, queue='hello', no_ack=True)

?

最后,準備好無限循環(huán)監(jiān)聽吧:

?

print ' [*] Waiting for messages. To exit press CTRL+C' channel.start_consuming()

?

最終版本

send.py:

?

#!/usr/bin/env python import pika connection = pika.BlockingConnection(pika.ConnectionParameters( host='localhost')) channel = connection.channel() channel.queue_declare(queue='hello') channel.basic_publish(exchange='', routing_key='hello', body='Hello World!') print " [x] Sent 'Hello World!'" connection.close()

?

?receive.py:

?

#!/usr/bin/env python import pika connection = pika.BlockingConnection(pika.ConnectionParameters( host='localhost')) channel = connection.channel() channel.queue_declare(queue='hello') print ' [*] Waiting for messages. To exit press CTRL+C' def callback(ch, method, properties, body): print " [x] Received %r" % (body,) channel.basic_consume(callback, queue='hello', no_ack=True) channel.start_consuming()

?

最終運行

先運行?send.py?program:

?

$ python send.py [x] Sent 'Hello World!'

?

send.py?每次運行完都會停止。注意:現(xiàn)在數(shù)據(jù)已經(jīng)存到queue里了。接收它:

?

$ python receive.py [*] Waiting for messages. To exit press CTRL+C [x] Received 'Hello World!'

?

?

任務分發(fā)機制

?

http://www.rabbitmq.com/tutorials/tutorial-two-Python.html

?

? ?上面解決了從發(fā)送端(Producer)向接收端(Consumer)發(fā)送“Hello World”的問題。在實際的應用場景中,這是遠遠不夠的。現(xiàn)在將結合更加實際的應用場景來講解更多的高級用法。

?? 當有Consumer需要大量的運算時,RabbitMQ Server需要一定的分發(fā)機制來balance每個Consumer的load。試想一下,對于web application來說,在一個很多的HTTP request里是沒有時間來處理復雜的運算的,只能通過后臺的一些工作線程來完成。接下來我們分布講解。?

?? 應用場景就是RabbitMQ Server會將queue的Message分發(fā)給不同的Consumer以處理計算密集型的任務:

?

準備

?

?

在上面,我們簡單在Message中包含了一個字符串"Hello World"。現(xiàn)在為了是Consumer做的是計算密集型的工作,那就不能簡單的字符串了。在現(xiàn)實應用中,Consumer有可能做的是一個圖片的resize,或者是pdf文件的渲染或者內(nèi)容提取。但是作為Demo,還是用字符串模擬吧:通過字符串中的.的數(shù)量來決定計算的復雜度,每個.都會消耗1s,即sleep(1)。

??? 還是復用上面的code,根據(jù)“計算密集型”做一下簡單的修改,為了辨別,我們把send.py 的名字換成new_task.py

import sys message = ' '.join(sys.argv[1:]) or "Hello World!" channel.basic_publish(exchange='', routing_key='hello', body=message) print " [x] Sent %r" % (message,)

同樣的道理,把receive.py的名字換成worker.py,并且根據(jù)Message中的.的數(shù)量進行計算密集型模擬:

?

import time def callback(ch, method, properties, body): print " [x] Received %r" % (body,) time.sleep( body.count('.') ) print " [x] Done"

?

Round-robin dispatching 循環(huán)分發(fā)

?

? ? ? ? RabbitMQ的分發(fā)機制非常適合擴展,而且它是專門為并發(fā)程序設計的。如果現(xiàn)在load加重,那么只需要創(chuàng)建更多的Consumer來進行任務處理即可。當然了,對于負載還要加大怎么辦?我沒有遇到過這種情況,那就可以創(chuàng)建多個virtual Host,細化不同的通信類別了。

???? 首先開啟兩個Consumer,即運行兩個worker.py。

Console1:

?

?

?

shell1$ python worker.py [*] Waiting for messages. To exit press CTRL+C

?

Consule2:

?

shell2$ python worker.py [*] Waiting for messages. To exit press CTRL+C

?

Producer new_task.py要Publish Message了:

?

shell3$ python new_task.py First message. shell3$ python new_task.py Second message.. shell3$ python new_task.py Third message... shell3$ python new_task.py Fourth message.... shell3$ python new_task.py Fifth message.....

?

注意一下:.代表的sleep(1)。接著開一下Consumer worker.py收到了什么:

?

Console1:

shell1$ python worker.py [*] Waiting for messages. To exit press CTRL+C [x] Received 'First message.' [x] Received 'Third message...' [x] Received 'Fifth message.....'

Console2:

?

shell2$ python worker.py [*] Waiting for messages. To exit press CTRL+C [x] Received 'Second message..' [x] Received 'Fourth message....'

?

默認情況下,RabbitMQ 會順序的分發(fā)每個Message。當每個收到ack后,會將該Message刪除,然后將下一個Message分發(fā)到下一個Consumer。這種分發(fā)方式叫做round-robin。這種分發(fā)還有問題,接著向下讀吧。

Message acknowledgment 消息確認

?

? ? ? 每個Consumer可能需要一段時間才能處理完收到的數(shù)據(jù)。如果在這個過程中,Consumer出錯了,異常退出了,而數(shù)據(jù)還沒有處理完成,那么非常不幸,這段數(shù)據(jù)就丟失了。因為我們采用no-ack的方式進行確認,也就是說,每次Consumer接到數(shù)據(jù)后,而不管是否處理完成,RabbitMQ Server會立即把這個Message標記為完成,然后從queue中刪除了。

???? 如果一個Consumer異常退出了,它處理的數(shù)據(jù)能夠被另外的Consumer處理,這樣數(shù)據(jù)在這種情況下就不會丟失了(注意是這種情況下)。

????? 為了保證數(shù)據(jù)不被丟失,RabbitMQ支持消息確認機制,即acknowledgments。為了保證數(shù)據(jù)能被正確處理而不僅僅是被Consumer收到,那么我們不能采用no-ack。而應該是在處理完數(shù)據(jù)后發(fā)送ack。

??? 在處理數(shù)據(jù)后發(fā)送的ack,就是告訴RabbitMQ數(shù)據(jù)已經(jīng)被接收,處理完成,RabbitMQ可以去安全的刪除它了。

??? 如果Consumer退出了但是沒有發(fā)送ack,那么RabbitMQ就會把這個Message發(fā)送到下一個Consumer。這樣就保證了在Consumer異常退出的情況下數(shù)據(jù)也不會丟失。

??? 這里并沒有用到超時機制。RabbitMQ僅僅通過Consumer的連接中斷來確認該Message并沒有被正確處理。也就是說,RabbitMQ給了Consumer足夠長的時間來做數(shù)據(jù)處理。

??? 默認情況下,消息確認是打開的(enabled)。在上篇文章中我們通過no_ack = True 關閉了ack。重新修改一下callback,以在消息處理完成后發(fā)送ack:

?

?

?

def callback(ch, method, properties, body): print " [x] Received %r" % (body,) time.sleep( body.count('.') ) print " [x] Done" ch.basic_ack(delivery_tag = method.delivery_tag) channel.basic_consume(callback, queue='hello')

?

? ? ?這樣即使你通過Ctr-C中斷了worker.py,那么Message也不會丟失了,它會被分發(fā)到下一個Consumer。

?

????? 如果忘記了ack,那么后果很嚴重。當Consumer退出時,Message會重新分發(fā)。然后RabbitMQ會占用越來越多的內(nèi)存,由于RabbitMQ會長時間運行,因此這個“內(nèi)存泄漏”是致命的。去調(diào)試這種錯誤,可以通過一下命令打印un-acked Messages:

$ sudo rabbitmqctl list_queues name messages_ready messages_unacknowledged Listing queues ... hello 0 0 ...done.

Message durability消息持久化

?

? ? ?在上一節(jié)中我們知道了即使Consumer異常退出,Message也不會丟失。但是如果RabbitMQ Server退出呢?軟件都有bug,即使RabbitMQ Server是完美毫無bug的(當然這是不可能的,是軟件就有bug,沒有bug的那不叫軟件),它還是有可能退出的:被其它軟件影響,或者系統(tǒng)重啟了,系統(tǒng)panic了。。。

??? 為了保證在RabbitMQ退出或者crash了數(shù)據(jù)仍沒有丟失,需要將queue和Message都要持久化。

queue的持久化需要在聲明時指定durable=True:

channel.queue_declare(queue='hello', durable=True)

上述語句執(zhí)行不會有什么錯誤,但是確得不到我們想要的結果,原因就是RabbitMQ Server已經(jīng)維護了一個叫hello的queue,那么上述執(zhí)行不會有任何的作用,也就是hello的任何屬性都不會被影響。這一點在上篇文章也討論過。

?

那么workaround也很簡單,聲明一個另外的名字的queue,比如名字定位task_queue:

?

[python]?view plain?copy

  • channel.queue_declare(queue='task_queue',?durable=True)??
  • 再次強調(diào),Producer和Consumer都應該去創(chuàng)建這個queue,盡管只有一個地方的創(chuàng)建是真正起作用的:

    ?

    接下來,需要持久化Message,即在Publish的時候指定一個properties,方式如下:

    ?

    [python]?view plain?copy

  • channel.basic_publish(exchange='',??
  • ??????????????????????routing_key="task_queue",??
  • ??????????????????????body=message,??
  • ??????????????????????properties=pika.BasicProperties(??
  • ?????????????????????????delivery_mode?=?2,?#?make?message?persistent??
  • ??????????????????????)) ?
  • 關于持久化的進一步討論:

    ?

    ? ? 為了數(shù)據(jù)不丟失,我們采用了:

  • 在數(shù)據(jù)處理結束后發(fā)送ack,這樣RabbitMQ Server會認為Message Deliver 成功。
  • 持久化queue,可以防止RabbitMQ Server 重啟或者crash引起的數(shù)據(jù)丟失。
  • 持久化Message,理由同上。
  • ??? 但是這樣能保證數(shù)據(jù)100%不丟失嗎?

    ??? 答案是否定的。問題就在與RabbitMQ需要時間去把這些信息存到磁盤上,這個time window雖然短,但是它的確還是有。在這個時間窗口內(nèi)如果數(shù)據(jù)沒有保存,數(shù)據(jù)還會丟失。還有另一個原因就是RabbitMQ并不是為每個Message都做fsync:它可能僅僅是把它保存到Cache里,還沒來得及保存到物理磁盤上。

    ??? 因此這個持久化還是有問題。但是對于大多數(shù)應用來說,這已經(jīng)足夠了。當然為了保持一致性,你可以把每次的publish放到一個transaction中。這個transaction的實現(xiàn)需要user defined codes。

    ??? 那么商業(yè)系統(tǒng)會做什么呢?一種可能的方案是在系統(tǒng)panic時或者異常重啟時或者斷電時,應該給各個應用留出時間去flash cache,保證每個應用都能exit gracefully。

    Fair dispatch 公平分發(fā)

    ?

    ? ? 你可能也注意到了,分發(fā)機制不是那么優(yōu)雅。默認狀態(tài)下,RabbitMQ將第n個Message分發(fā)給第n個Consumer。當然n是取余后的。它不管Consumer是否還有unacked Message,只是按照這個默認機制進行分發(fā)。

    ?? 那么如果有個Consumer工作比較重,那么就會導致有的Consumer基本沒事可做,有的Consumer卻是毫無休息的機會。那么,RabbitMQ是如何處理這種問題呢?

    ?

    ? 通過?basic.qos?方法設置prefetch_count=1?。這樣RabbitMQ就會使得每個Consumer在同一個時間點最多處理一個Message。換句話說,在接收到該Consumer的ack前,他它不會將新的Message分發(fā)給它。 設置方法如下:

    ?

    [python]?view plain?copy

  • channel.basic_qos(prefetch_count=1)??
  • 注意,這種方法可能會導致queue滿。當然,這種情況下你可能需要添加更多的Consumer,或者創(chuàng)建更多的virtualHost來細化你的設計。

    ?

    ?

    ?

    最終版本

    ?

    new_task.py?script:

    ?

    [python]?view plain?copy

  • #!/usr/bin/env?python??
  • import?pika??
  • import?sys??
  • ??
  • connection?=?pika.BlockingConnection(pika.ConnectionParameters(??
  • ????????host='localhost'))??
  • channel?=?connection.channel()??
  • ??
  • channel.queue_declare(queue='task_queue',?durable=True)??
  • ??
  • message?=?'?'.join(sys.argv[1:])?or?"Hello?World!"??
  • channel.basic_publish(exchange='',??
  • ??????????????????????routing_key='task_queue',??
  • ??????????????????????body=message,??
  • ??????????????????????properties=pika.BasicProperties(??
  • ?????????????????????????delivery_mode?=?2,?#?make?message?persistent??
  • ??????????????????????))??
  • print?"?[x]?Sent?%r"?%?(message,)??
  • connection.close()??
  • ?

    worker.py script:

    ?

    [python]?view plain?copy

  • #!/usr/bin/env?python??
  • import?pika??
  • import?time??
  • ??
  • connection?=?pika.BlockingConnection(pika.ConnectionParameters(??
  • ????????host='localhost'))??
  • channel?=?connection.channel()??
  • ??
  • channel.queue_declare(queue='task_queue',?durable=True)??
  • print?'?[*]?Waiting?for?messages.?To?exit?press?CTRL+C'??
  • ??
  • def?callback(ch,?method,?properties,?body):??
  • ????print?"?[x]?Received?%r"?%?(body,)??
  • ????time.sleep(?body.count('.')?)??
  • ????print?"?[x]?Done"??
  • ????ch.basic_ack(delivery_tag?=?method.delivery_tag)??
  • ??
  • channel.basic_qos(prefetch_count=1)??
  • channel.basic_consume(callback,??
  • ??????????????????????queue='task_queue')??
  • ??
  • channel.start_consuming() ?
  • ?

    分發(fā)到多Consumer(Publish/Subscribe)

    ?

    http://www.rabbitmq.com/tutorials/tutorial-three-Python.html

    ?

    ? ? ? 上篇文章中,我們把每個Message都是deliver到某個Consumer。在這篇文章中,我們將會將同一個Message deliver到多個Consumer中。這個模式也被成為 "publish / subscribe"。
    ??? 這篇文章中,我們將創(chuàng)建一個日志系統(tǒng),它包含兩個部分:第一個部分是發(fā)出log(Producer),第二個部分接收到并打印(Consumer)。 我們將構建兩個Consumer,第一個將log寫到物理磁盤上;第二個將log輸出的屏幕。

    ?

    Exchanges

    ?

    ? ? RabbitMQ 的Messaging Model就是Producer并不會直接發(fā)送Message到queue。實際上,Producer并不知道它發(fā)送的Message是否已經(jīng)到達queue。

    ?? Producer發(fā)送的Message實際上是發(fā)到了Exchange中。它的功能也很簡單:從Producer接收Message,然后投遞到queue中。Exchange需要知道如何處理Message,是把它放到那個queue中,還是放到多個queue中?這個rule是通過Exchange 的類型定義的。

    ?

    ?? 我們知道有三種類型的Exchange:direct,?topic?和fanout。fanout就是廣播模式,會將所有的Message都放到它所知道的queue中。創(chuàng)建一個名字為logs,類型為fanout的Exchange:

    ?

    [python]?view plain?copy

  • channel.exchange_declare(exchange='logs',??
  • ?????????????????????????type='fanout')??
  • ?

    Listing exchanges

    通過rabbitmqctl可以列出當前所有的Exchange:

    ?

    [python]?view plain?copy

  • $?sudo?rabbitmqctl?list_exchanges??
  • Listing?exchanges?...??
  • logs??????fanout??
  • amq.direct??????direct??
  • amq.topic???????topic??
  • amq.fanout??????fanout??
  • amq.headers?????headers??
  • ...done.??

  • 注意?amq.*?exchanges 和the default (unnamed)exchange是RabbitMQ默認創(chuàng)建的。

    ?

    現(xiàn)在我們可以通過exchange,而不是routing_key來publish Message了:

    ?

    [python]?view plain?copy

  • channel.basic_publish(exchange='logs',??
  • ??????????????????????routing_key='',??
  • ??????????????????????body=message) ?
  • ?

    Temporary queues

    ?

    ?

    ? ? 截至現(xiàn)在,我們用的queue都是有名字的:第一個是hello,第二個是task_queue。使用有名字的queue,使得在Producer和Consumer之前共享queue成為可能。

    ??? 但是對于我們將要構建的日志系統(tǒng),并不需要有名字的queue。我們希望得到所有的log,而不是它們中間的一部分。而且我們只對當前的log感興趣。為了實現(xiàn)這個目標,我們需要兩件事情:
    ??? 1) 每當Consumer連接時,我們需要一個新的,空的queue。因為我們不對老的log感興趣。幸運的是,如果在聲明queue時不指定名字,那么RabbitMQ會隨機為我們選擇這個名字。方法:

    ?

    [python]?view plain?copy

  • result?=?channel.queue_declare()??
  • ??? 通過result.method.queue?可以取得queue的名字。基本上都是這個樣子:amq.gen-JzTY20BRgKO-HjmUJj0wLg
    ??? 2)當Consumer關閉連接時,這個queue要被deleted。可以加個exclusive的參數(shù)。方法:

    ?

    [python]?view plain?copy

  • result?=?channel.queue_declare(exclusive=True) ?
  • ?

    Bindings綁定

    ?

    ?

    現(xiàn)在我們已經(jīng)創(chuàng)建了fanout類型的exchange和沒有名字的queue(實際上是RabbitMQ幫我們?nèi)×嗣?#xff09;。那exchange怎么樣知道它的Message發(fā)送到哪個queue呢?答案就是通過bindings:綁定。

    ?

    方法:

    ?

    [python]?view plain?copy

  • channel.queue_bind(exchange='logs',??
  • ???????????????????queue=result.method.queue)??
  • 現(xiàn)在logs的exchange就將它的Message附加到我們創(chuàng)建的queue了。

    ?

    Listing bindings

    使用命令rabbitmqctl list_bindings。

    ?

    最終版本

    ?

    ?

    ? ? 我們最終實現(xiàn)的數(shù)據(jù)流圖如下:

    Producer,在這里就是產(chǎn)生log的program,基本上和前幾個都差不多。最主要的區(qū)別就是publish通過了exchange而不是routing_key。

    emit_log.py?script:

    ?

    [python]?view plain?copy

  • #!/usr/bin/env?python??
  • import?pika??
  • import?sys??
  • ??
  • connection?=?pika.BlockingConnection(pika.ConnectionParameters(??
  • ????????host='localhost'))??
  • channel?=?connection.channel()??
  • ??
  • channel.exchange_declare(exchange='logs',??
  • ?????????????????????????type='fanout')??
  • ??
  • message?=?'?'.join(sys.argv[1:])?or?"info:?Hello?World!"??
  • channel.basic_publish(exchange='logs',??
  • ??????????????????????routing_key='',??
  • ??????????????????????body=message)??
  • print?"?[x]?Sent?%r"?%?(message,)??
  • connection.close()??
  • ?

    還有一點要注意的是我們聲明了exchange。publish到一個不存在的exchange是被禁止的。如果沒有queue bindings exchange的話,log是被丟棄的。
    Consumer:receive_logs.py:

    ?

    [python]?view plain?copy

  • #!/usr/bin/env?python??
  • import?pika??
  • ??
  • connection?=?pika.BlockingConnection(pika.ConnectionParameters(??
  • ????????host='localhost'))??
  • channel?=?connection.channel()??
  • ??
  • channel.exchange_declare(exchange='logs',??
  • ?????????????????????????type='fanout')??
  • ??
  • result?=?channel.queue_declare(exclusive=True)??
  • queue_name?=?result.method.queue??
  • ??
  • channel.queue_bind(exchange='logs',??
  • ???????????????????queue=queue_name)??
  • ??
  • print?'?[*]?Waiting?for?logs.?To?exit?press?CTRL+C'??
  • ??
  • def?callback(ch,?method,?properties,?body):??
  • ????print?"?[x]?%r"?%?(body,)??
  • ??
  • channel.basic_consume(callback,??
  • ??????????????????????queue=queue_name,??
  • ??????????????????????no_ack=True)??
  • ??
  • channel.start_consuming()??
  • 我們開始不是說需要兩個Consumer嗎?一個負責記錄到文件;一個負責打印到屏幕?
    其實用重定向就可以了,當然你想修改callback自己寫文件也行。我們使用重定向的方法:
    We're done. If you want to save logs to a file, just open a console and type:

    ?

    [python]?view plain?copy

  • $?python?receive_logs.py?>?logs_from_rabbit.log??
  • Consumer2:打印到屏幕:

    ?

    [python]?view plain?copy

  • $?python?receive_logs.py??
  • 接下來,Producer:

    ?

    [python]?view plain?copy

  • $?python?emit_log.py??
  • 使用命令rabbitmqctl list_bindings你可以看我們創(chuàng)建的queue。
    一個output:

    ?

    [python]?view plain?copy

  • $?sudo?rabbitmqctl?list_bindings??
  • Listing?bindings?...??
  • logs????exchange????????amq.gen-JzTY20BRgKO-HjmUJj0wLg??queue???????????[]??
  • logs????exchange????????amq.gen-vso0PVvyiRIL2WoV3i48Yg??queue???????????[]??
  • ...done.??
  • 這個結果還是很好理解的。

    ?

    ?

    ?

    Routing 消息路由

    http://www.rabbitmq.com/tutorials/tutorial-four-Python.html

    ?

    ? ? 上篇文章中,我們構建了一個簡單的日志系統(tǒng)。接下來,我們將豐富它:能夠使用不同的severity來監(jiān)聽不同等級的log。比如我們希望只有error的log才保存到磁盤上。

    ?

    ?

    Bindings綁定

    ?

    ?

    ??? 上篇文章中我們是這么做的綁定:

    ?

    [python]?view plain?copy

  • channel.queue_bind(exchange=exchange_name,??
  • ???????????????????queue=queue_name)??
  • ??? 綁定其實就是關聯(lián)了exchange和queue。或者這么說:queue對exchagne的內(nèi)容感興趣,exchange要把它的Message deliver到queue中。

    ?

    ??? 實際上,綁定可以帶routing_key?這個參數(shù)。其實這個參數(shù)的名稱和basic_publish?的參數(shù)名是相同了。為了避免混淆,我們把它成為binding key。
    ??? 使用一個key來創(chuàng)建binding :

    ?

    [python]?view plain?copy

  • channel.queue_bind(exchange=exchange_name,??
  • ???????????????????queue=queue_name,??
  • ???????????????????routing_key='black')??
  • 對于fanout的exchange來說,這個參數(shù)是被忽略的。

    ?

    ?

    Direct exchange

    ?

    ?

    ? Direct exchange的路由算法非常簡單:通過binding key的完全匹配,可以通過下圖來說明。?


    ??? exchange X和兩個queue綁定在一起。Q1的binding key是orange。Q2的binding key是black和green。
    ??? 當P publish key是orange時,exchange會把它放到Q1。如果是black或者green那么就會到Q2。其余的Message都會被丟棄。

    ?

    ?

    Multiple bindings

    ?

    ????? 多個queue綁定同一個key是可以的。對于下圖的例子,Q1和Q2都綁定了black。也就是說,對于routing key是black的Message,會被deliver到Q1和Q2。其余的Message都會被丟棄。

    ??

    ?

    Emitting logs

    ?

    首先是我們要創(chuàng)建一個direct的exchange:

    ?

    [python]?view plain?copy

  • channel.exchange_declare(exchange='direct_logs',??
  • ?????????????????????????type='direct')??
  • 我們將使用log的severity作為routing key,這樣Consumer可以針對不同severity的log進行不同的處理。
    publish:

    ?

    ?

    [python]?view plain?copy

  • channel.basic_publish(exchange='direct_logs',??
  • ??????????????????????routing_key=severity,??
  • ??????????????????????body=message)??
  • 我們使用三種severity:'info', 'warning', 'error'.

    ?

    ?

    Subscribing

    ?

    對于queue,我們需要綁定severity:

    ?

    [python]?view plain?copy

  • result?=?channel.queue_declare(exclusive=True)??
  • queue_name?=?result.method.queue??
  • ??
  • for?severity?in?severities:??
  • ????channel.queue_bind(exchange='direct_logs',??
  • ???????????????????????queue=queue_name,??
  • ???????????????????????routing_key=severity)??
  • ?

    ?

    最終版本

    ?

    The code for?emit_log_direct.py:

    ?

    [python]?view plain?copy

  • #!/usr/bin/env?python??
  • import?pika??
  • import?sys??
  • ??
  • connection?=?pika.BlockingConnection(pika.ConnectionParameters(??
  • ????????host='localhost'))??
  • channel?=?connection.channel()??
  • ??
  • channel.exchange_declare(exchange='direct_logs',??
  • ?????????????????????????type='direct')??
  • ??
  • severity?=?sys.argv[1]?if?len(sys.argv)?>?1?else?'info'??
  • message?=?'?'.join(sys.argv[2:])?or?'Hello?World!'??
  • channel.basic_publish(exchange='direct_logs',??
  • ??????????????????????routing_key=severity,??
  • ??????????????????????body=message)??
  • print?"?[x]?Sent?%r:%r"?%?(severity,?message)??
  • connection.close()??

  • The code for?receive_logs_direct.py:

    ?

    ?

    [python]?view plain?copy

  • #!/usr/bin/env?python??
  • import?pika??
  • import?sys??
  • ??
  • connection?=?pika.BlockingConnection(pika.ConnectionParameters(??
  • ????????host='localhost'))??
  • channel?=?connection.channel()??
  • ??
  • channel.exchange_declare(exchange='direct_logs',??
  • ?????????????????????????type='direct')??
  • ??
  • result?=?channel.queue_declare(exclusive=True)??
  • queue_name?=?result.method.queue??
  • ??
  • severities?=?sys.argv[1:]??
  • if?not?severities:??
  • ????print?>>?sys.stderr,?"Usage:?%s?[info]?[warning]?[error]"?%?\??
  • ?????????????????????????(sys.argv[0],)??
  • ????sys.exit(1)??
  • ??
  • for?severity?in?severities:??
  • ????channel.queue_bind(exchange='direct_logs',??
  • ???????????????????????queue=queue_name,??
  • ???????????????????????routing_key=severity)??
  • ??
  • print?'?[*]?Waiting?for?logs.?To?exit?press?CTRL+C'??
  • ??
  • def?callback(ch,?method,?properties,?body):??
  • ????print?"?[x]?%r:%r"?%?(method.routing_key,?body,)??
  • ??
  • channel.basic_consume(callback,??
  • ??????????????????????queue=queue_name,??
  • ??????????????????????no_ack=True)??
  • ??
  • channel.start_consuming()??
  • 我們想把warning和error的log記錄到一個文件中:

    ?

    ?

    [python]?view plain?copy

  • $?python?receive_logs_direct.py?warning?error?>?logs_from_rabbit.log??
  • 打印所有l(wèi)og到屏幕:

    ?

    ?

    [python]?view plain?copy

  • $?python?receive_logs_direct.py?info?warning?error??
  • ?[*]?Waiting?for?logs.?To?exit?press?CTRL+C??
  • ?

    ?

    使用主題進行消息分發(fā)

    ?

    ?

    http://www.rabbitmq.com/tutorials/tutorial-five-Python.html

    ?

    上面實現(xiàn)了一個簡單的日志系統(tǒng)。Consumer可以監(jiān)聽不同severity的log。但是,這也是它之所以叫做簡單日志系統(tǒng)的原因,因為是僅僅能夠通過severity設定。不支持更多的標準。

    ??????? 比如syslog?unix的日志工具,它可以通過severity (info/warn/crit...) 和模塊(auth/cron/kern...)。這可能更是我們想要的:我們可以僅僅需要cron模塊的log。

    ??????? 為了實現(xiàn)類似的功能,我們需要用到topic exchange。

    ?

    Topic exchange

    ?

    ?

    ? ? ? ? 對于Message的routing_key是有限制的,不能使任意的。格式是以點號“."分割的字符表。比如:"stock.usd.nyse", "nyse.vmw", "quick.orange.rabbit"。你可以放任意的key在routing_key中,當然最長不能超過255 bytes。

    ??????? 對于routing_key,有兩個特殊字符(在正則表達式里叫元字符):

    • *?(星號) 代表任意 一個單詞
    • #?(hash) 0個或者多個單詞

    ??????? 請看下面一個例子:

    ???? Producer發(fā)送消息時需要設置routing_key,routing_key包含三個單詞和兩個點號。第一個key是描述了celerity(靈巧,敏捷),第二個是colour(色彩),第三個是species(物種):"<celerity>.<colour>.<species>"。

    ???? 在這里我們創(chuàng)建了兩個綁定: Q1 的binding key 是"*.orange.*"; Q2 是? "*.*.rabbit" 和 "lazy.#":

    • Q1 感興趣所有orange顏色的動物
    • Q2 感興趣所有的rabbits和所有的lazy的

    ???? 比如routing_key是 "quick.orange.rabbit"將會發(fā)送到Q1和Q2中。消息"lazy.orange.elephant" 也會發(fā)送到Q1和Q2。但是"quick.orange.fox" 會發(fā)送到Q1;"lazy.brown.fox"會發(fā)送到Q2。"lazy.pink.rabbit" 也會發(fā)送到Q2,但是盡管兩個routing_key都匹配,它也只是發(fā)送一次。"quick.brown.fox" 會被丟棄。

    ???? 如果發(fā)送的單詞不是3個呢? 答案要看情況,因為#是可以匹配0個或任意個單詞。比如"orange" or "quick.orange.male.rabbit",它們會被丟棄。如果是lazy那么就會進入Q2。類似的還有 "lazy.orange.male.rabbit",盡管它包含四個單詞。

    Topic exchange和其他exchange

    由于有"*" (star) and "#" (hash), Topic exchange 非常強大并且可以轉化為其他的exchange:

    ??? 如果binding_key 是 "#" - 它會接收所有的Message,不管routing_key是什么,就像是fanout exchange。

    ??? 如果 "*" (star) and "#" (hash) 沒有被使用,那么topic exchange就變成了direct exchange。

    ?

    代碼實現(xiàn)

    ?

    ?

    ? ? ?現(xiàn)在我們要refine我們上篇的日志系統(tǒng)。routing keys 有兩個部分: "<facility>.<severity>"。

    The code for?emit_log_topic.py:

    ?

    [python]?view plain?copy

  • #!/usr/bin/env?python??
  • import?pika??
  • import?sys??
  • ??
  • connection?=?pika.BlockingConnection(pika.ConnectionParameters(??
  • ????????host='localhost'))??
  • channel?=?connection.channel()??
  • ??
  • channel.exchange_declare(exchange='topic_logs',??
  • ?????????????????????????type='topic')??
  • ??
  • routing_key?=?sys.argv[1]?if?len(sys.argv)?>?1?else?'anonymous.info'??
  • message?=?'?'.join(sys.argv[2:])?or?'Hello?World!'??
  • channel.basic_publish(exchange='topic_logs',??
  • ??????????????????????routing_key=routing_key,??
  • ??????????????????????body=message)??
  • print?"?[x]?Sent?%r:%r"?%?(routing_key,?message)??
  • connection.close()??

  • The code for?receive_logs_topic.py:

    ?

    ?

    [python]?view plain?copy

  • #!/usr/bin/env?python??
  • import?pika??
  • import?sys??
  • ??
  • connection?=?pika.BlockingConnection(pika.ConnectionParameters(??
  • ????????host='localhost'))??
  • channel?=?connection.channel()??
  • ??
  • channel.exchange_declare(exchange='topic_logs',??
  • ?????????????????????????type='topic')??
  • ??
  • result?=?channel.queue_declare(exclusive=True)??
  • queue_name?=?result.method.queue??
  • ??
  • binding_keys?=?sys.argv[1:]??
  • if?not?binding_keys:??
  • ????print?>>?sys.stderr,?"Usage:?%s?[binding_key]..."?%?(sys.argv[0],)??
  • ????sys.exit(1)??
  • ??
  • for?binding_key?in?binding_keys:??
  • ????channel.queue_bind(exchange='topic_logs',??
  • ???????????????????????queue=queue_name,??
  • ???????????????????????routing_key=binding_key)??
  • ??
  • print?'?[*]?Waiting?for?logs.?To?exit?press?CTRL+C'??
  • ??
  • def?callback(ch,?method,?properties,?body):??
  • ????print?"?[x]?%r:%r"?%?(method.routing_key,?body,)??
  • ??
  • channel.basic_consume(callback,??
  • ??????????????????????queue=queue_name,??
  • ??????????????????????no_ack=True)??
  • ??
  • channel.start_consuming() ?
  • ?

    運行和結果

    ?

    接收所有的log:

    ?

    [python]?view plain?copy

  • python?receive_logs_topic.py?"#"??
  • 接收所有kern facility的log:

    ?

    ?

    ?

    ?

    [python]?view plain?copy

  • python?receive_logs_topic.py?"kern.*"??
  • 僅僅接收critical的log:

    ?

    ?

    [python]?view plain?copy

  • python?receive_logs_topic.py?"*.critical"??
  • 可以創(chuàng)建多個綁定:

    ?

    ?

    [python]?view plain?copy

  • python?receive_logs_topic.py?"kern.*"?"*.critical"??
  • Producer產(chǎn)生一個log:"kern.critical" type:

    ?

    ?

    [python]?view plain?copy

  • python?emit_log_topic.py?"kern.critical"?"A?critical?kernel?error"??

  • 課后思考題:

    ?

    • Will "*" binding catch a message sent with an empty routing key?
    • Will "#.*" catch a message with a string ".." as a key? Will it catch a message with a single word key?
    • How different is "a.*.#" from "a.#"?

    ?

    適用于云計算集群的遠程調(diào)用(RPC)

    ?

    ?

    http://www.rabbitmq.com/tutorials/tutorial-six-Python.html

    ? ? ? ? 在云計算環(huán)境中,很多時候需要用它其他機器的計算資源,我們有可能會在接收到Message進行處理時,會把一部分計算任務分配到其他節(jié)點來完成。那么,RabbitMQ如何使用RPC呢?在本篇文章中,我們將會通過其它節(jié)點求來斐波納契完成示例。


    客戶端接口 Client interface

    ?

    ? ? ? ? 為了展示一個RPC服務是如何使用的,我們將創(chuàng)建一段很簡單的客戶端class。 它將會向外提供名字為call的函數(shù),這個call會發(fā)送RPC請求并且阻塞知道收到RPC運算的結果。代碼如下:

    ?

    [python]?view plain?copy

  • fibonacci_rpc?=?FibonacciRpcClient()??
  • result?=?fibonacci_rpc.call(4)??
  • print?"fib(4)?is?%r"?%?(result,)??
  • ?

    回調(diào)函數(shù)隊列 Callback queue

    ?

    ? ? ? ? 總體來說,在RabbitMQ進行RPC遠程調(diào)用是比較容易的。client發(fā)送請求的Message然后server返回響應結果。為了收到響應client在publish message時需要提供一個”callback“(回調(diào))的queue地址。code如下:

    ?

    [python]?view plain?copy

  • result?=?channel.queue_declare(exclusive=True)??
  • callback_queue?=?result.method.queue??
  • ??
  • channel.basic_publish(exchange='',??
  • ??????????????????????routing_key='rpc_queue',??
  • ??????????????????????properties=pika.BasicProperties(??
  • ????????????????????????????reply_to?=?callback_queue,??
  • ????????????????????????????),??
  • ??????????????????????body=request)??
  • ??
  • #?...?and?some?code?to?read?a?response?message?from?the?callback_queue?...??
  • Message properties

    ?

    AMQP 預定義了14個屬性。它們中的絕大多很少會用到。以下幾個是平時用的比較多的:

    • delivery_mode: 持久化一個Message(通過設定值為2)。其他任意值都是非持久化。請移步RabbitMQ消息隊列(三):任務分發(fā)機制
    • content_type: 描述mime-type 的encoding。比如設置為JSON編碼:設置該property為application/json。
    • reply_to: 一般用來指明用于回調(diào)的queue(Commonly used to name a callback queue)。
    • correlation_id: 在請求中關聯(lián)處理RPC響應(correlate RPC responses with requests)。


    相關id Correlation id

    ?

    ? ? ? ?在上個小節(jié)里,實現(xiàn)方法是對每個RPC請求都會創(chuàng)建一個callback queue。這是不高效的。幸運的是,在這里有一個解決方法:為每個client創(chuàng)建唯一的callback queue。

    ?????? 這又有其他問題了:收到響應后它無法確定是否是它的,因為所有的響應都寫到同一個queue了。上一小節(jié)的correlation_id在這種情況下就派上用場了:對于每個request,都設置唯一的一個值,在收到響應后,通過這個值就可以判斷是否是自己的響應。如果不是自己的響應,就不去處理。


    總結

    ?

    ?

    ???? 工作流程:

    • 當客戶端啟動時,它創(chuàng)建了匿名的exclusive callback queue.
    • 客戶端的RPC請求時將同時設置兩個properties:?reply_to設置為callback queue;correlation_id設置為每個request一個獨一無二的值.
    • 請求將被發(fā)送到an?rpc_queue?queue.
    • RPC端或者說server一直在等待那個queue的請求。當請求到達時,它將通過在reply_to指定的queue回復一個message給client。
    • client一直等待callback queue的數(shù)據(jù)。當message到達時,它將檢查correlation_id的值,如果值和它request發(fā)送時的一致那么就將返回響應。

    ?

    最終實現(xiàn)

    ?

    ?

    The code for?rpc_server.py:

    ?

    [python]?view plain?copy

  • #!/usr/bin/env?python??
  • import?pika??
  • ??
  • connection?=?pika.BlockingConnection(pika.ConnectionParameters(??
  • ????????host='localhost'))??
  • ??
  • channel?=?connection.channel()??
  • ??
  • channel.queue_declare(queue='rpc_queue')??
  • ??
  • def?fib(n):??
  • ????if?n?==?0:??
  • ????????return?0??
  • ????elif?n?==?1:??
  • ????????return?1??
  • ????else:??
  • ????????return?fib(n-1)?+?fib(n-2)??
  • ??
  • def?on_request(ch,?method,?props,?body):??
  • ????n?=?int(body)??
  • ??
  • ????print?"?[.]?fib(%s)"??%?(n,)??
  • ????response?=?fib(n)??
  • ??
  • ????ch.basic_publish(exchange='',??
  • ?????????????????????routing_key=props.reply_to,??
  • ?????????????????????properties=pika.BasicProperties(correlation_id?=?\??
  • ?????????????????????????????????????????????????????props.correlation_id),??
  • ?????????????????????body=str(response))??
  • ????ch.basic_ack(delivery_tag?=?method.delivery_tag)??
  • ??
  • channel.basic_qos(prefetch_count=1)??
  • channel.basic_consume(on_request,?queue='rpc_queue')??
  • ??
  • print?"?[x]?Awaiting?RPC?requests"??
  • channel.start_consuming()??

  • The server code is rather straightforward:

    ?

    • (4) As usual we start by establishing the connection and declaring the queue.
    • (11) We declare our fibonacci function. It assumes only valid positive integer input. (Don't expect this one to work for big numbers, it's probably the slowest recursive implementation possible).
    • (19) We declare a callback for?basic_consume, the core of the RPC server. It's executed when the request is received. It does the work and sends the response back.
    • (32) We might want to run more than one server process. In order to spread the load equally over multiple servers we need to set theprefetch_count?setting.

    The code for?rpc_client.py:

    ?

    [python]?view plain?copy

  • #!/usr/bin/env?python??
  • import?pika??
  • import?uuid??
  • ??
  • class?FibonacciRpcClient(object):??
  • ????def?__init__(self):??
  • ????????self.connection?=?pika.BlockingConnection(pika.ConnectionParameters(??
  • ????????????????host='localhost'))??
  • ??
  • ????????self.channel?=?self.connection.channel()??
  • ??
  • ????????result?=?self.channel.queue_declare(exclusive=True)??
  • ????????self.callback_queue?=?result.method.queue??
  • ??
  • ????????self.channel.basic_consume(self.on_response,?no_ack=True,??
  • ???????????????????????????????????queue=self.callback_queue)??
  • ??
  • ????def?on_response(self,?ch,?method,?props,?body):??
  • ????????if?self.corr_id?==?props.correlation_id:??
  • ????????????self.response?=?body??
  • ??
  • ????def?call(self,?n):??
  • ????????self.response?=?None??
  • ????????self.corr_id?=?str(uuid.uuid4())??
  • ????????self.channel.basic_publish(exchange='',??
  • ???????????????????????????????????routing_key='rpc_queue',??
  • ???????????????????????????????????properties=pika.BasicProperties(??
  • ?????????????????????????????????????????reply_to?=?self.callback_queue,??
  • ?????????????????????????????????????????correlation_id?=?self.corr_id,??
  • ?????????????????????????????????????????),??
  • ???????????????????????????????????body=str(n))??
  • ????????while?self.response?is?None:??
  • ????????????self.connection.process_data_events()??
  • ????????return?int(self.response)??
  • ??
  • fibonacci_rpc?=?FibonacciRpcClient()??
  • ??
  • print?"?[x]?Requesting?fib(30)"??
  • response?=?fibonacci_rpc.call(30)??
  • print?"?[.]?Got?%r"?%?(response,)??

  • The client code is slightly more involved:

    ?

    • (7) We establish a connection, channel and declare an exclusive 'callback' queue for replies.
    • (16) We subscribe to the 'callback' queue, so that we can receive RPC responses.
    • (18) The 'on_response' callback executed on every response is doing a very simple job, for every response message it checks if thecorrelation_id?is the one we're looking for. If so, it saves the response inself.response?and breaks the consuming loop.
    • (23) Next, we define our main?call?method - it does the actual RPC request.
    • (24) In this method, first we generate a unique?correlation_id?number and save it - the 'on_response' callback function will use this value to catch the appropriate response.
    • (25) Next, we publish the request message, with two properties:?reply_to?and?correlation_id.
    • (32) At this point we can sit back and wait until the proper response arrives.
    • (33) And finally we return the response back to the user.

    開始rpc_server.py:

    [python]?view plain?copy

  • $?python?rpc_server.py??
  • ?[x]?Awaiting?RPC?requests??
  • 通過client來請求fibonacci數(shù):

    ?

    ?

    [python]?view plain?copy

  • $?python?rpc_client.py??
  • ?[x]?Requesting?fib(30)??
  • ????? 現(xiàn)在這個設計并不是唯一的,但是這個實現(xiàn)有以下優(yōu)勢:

    ?

    ?

    ?

    • 如何RPC server太慢,你可以擴展它:啟動另外一個RPC server。
    • 在client端, 無所進行加鎖能同步操作,他所作的就是發(fā)送請求等待響應。

    ????? 我們的code還是挺簡單的,并沒有嘗試去解決更復雜和重要的問題,比如:

    • 如果沒有server在運行,client需要怎么做?
    • RPC應該設置超時機制嗎?
    • 如果server運行出錯并且拋出了異常,需要將這個問題轉發(fā)到client嗎?
    • 需要邊界檢查嗎?

    ?

    RabbitMQ消息隊列的小伙伴: ProtoBuf(Google Protocol Buffer)

    ?

    ?

    ? ? ?什么是ProtoBuf?

    ???? 一種輕便高效的結構化數(shù)據(jù)存儲格式,可以用于結構化數(shù)據(jù)串行化,或者說序列化。它很適合做數(shù)據(jù)存儲或 RPC 數(shù)據(jù)交換格式。可用于通訊協(xié)議、數(shù)據(jù)存儲等領域的語言無關、平臺無關、可擴展的序列化結構數(shù)據(jù)格式。目前提供了 C++、Java、Python?三種語言的 API。

    ???? 它可以作為RabbitMQ的Message的數(shù)據(jù)格式進行傳輸,由于是結構化的數(shù)據(jù),這樣就極大的方便了Consumer的數(shù)據(jù)高效處理。當然了你可能說使用XML不也可以嗎?與XML相比,ProtoBuf有以下優(yōu)勢:

  • 簡單
  • size小了3-10倍
  • 速度快樂20-100倍
  • 易于編程
  • 減小了語義的歧義
  • ?????? 當然了,的確還有很多類似的技術,比如JSON,Thrift等等,和他們相比,ProtoBuf的優(yōu)勢或者劣勢在哪里?簡單說來,ProtoBuf就是簡單,快。以測試為證:項目 thrift-protobuf-compare 比較了這些類似的技術,下圖 顯示了該項目的一項測試結果。

    在占用空間上的性能比較:

    由此可見,ProtoBuf具有速度和空間的優(yōu)勢,使得它現(xiàn)在應用非常廣泛。比如Hadoop就使用了它。

    更多信息,請閱 http://www.ibm.com/developerworks/cn/Linux/l-cn-gpb/。

    ?

    Publisher的消息確認機制

    ?

    ? ? ? ?在前面的文章中提到了queue和consumer之間的消息確認機制:通過設置ack。那么Publisher能不到知道他post的Message有沒有到達queue,甚至更近一步,是否被某個Consumer處理呢?畢竟對于一些非常重要的數(shù)據(jù),可能Publisher需要確認某個消息已經(jīng)被正確處理。

    ????? 在我們的系統(tǒng)中,我們沒有是實現(xiàn)這種確認,也就是說,不管Message是否被Consume了,Publisher不會去care。他只是將自己的狀態(tài)publish給上層,由上層的邏輯去處理。如果Message沒有被正確處理,可能會導致某些狀態(tài)丟失。但是由于提供了其他強制刷新全部狀態(tài)的機制,因此這種異常情況的影響也就可以忽略不計了。

    ???? 對于某些異步操作,比如客戶端需要創(chuàng)建一個FileSystem,這個可能需要比較長的時間,甚至要數(shù)秒鐘。這時候通過RPC可以解決這個問題。因此也就不存在Publisher端的確認機制了。

    ???? 那么,有沒有一種機制能保證Publisher能夠感知它的Message有沒有被處理的?答案肯定的。在這里感謝笑天居士同學:他在我的《RabbitMQ消息隊列(三):任務分發(fā)機制》文后留言一起討論了問題,而且也查找了一些資料。在這里我整理了一下他轉載和一篇文章和原創(chuàng)的一篇文章。銜接已經(jīng)附后。

    事務機制 VS Publisher Confirm

    ?

    ? ? ? ?如果采用標準的 AMQP 協(xié)議,則唯一能夠保證消息不會丟失的方式是利用事務機制 -- 令 channel 處于 transactional 模式、向其 publish 消息、執(zhí)行 commit 動作。在這種方式下,事務機制會帶來大量的多余開銷,并會導致吞吐量下降 250% 。為了補救事務帶來的問題,引入了 confirmation 機制(即 Publisher Confirm)。

    ???? 為了使能 confirm 機制,client 首先要發(fā)送 confirm.select 方法幀。取決于是否設置了 no-wait 屬性,broker 會相應的判定是否以 confirm.select-ok 進行應答。一旦在 channel 上使用 confirm.select方法,channel 就將處于 confirm 模式。處于 transactional 模式的 channel 不能再被設置成 confirm 模式,反之亦然。
    ??? 一旦 channel 處于 confirm 模式,broker 和 client 都將啟動消息計數(shù)(以?confirm.select?為基礎從 1 開始計數(shù))。broker 會在處理完消息后,在當前 channel 上通過發(fā)送?basic.ack?的方式對其進行 confirm 。delivery-tag 域的值標識了被 confirm 消息的序列號。broker 也可以通過設置?basic.ack?中的?multiple 域來表明到指定序列號為止的所有消息都已被 broker 正確的處理了。

    ?????? 在異常情況中,broker 將無法成功處理相應的消息,此時 broker 將發(fā)送?basic.nack?來代替?basic.ack?。在這個情形下,basic.nack?中各域值的含義與?basic.ack 中相應各域含義是相同的,同時?requeue 域的值應該被忽略。通過?nack 一或多條消息,broker 表明自身無法對相應消息完成處理,并拒絕為這些消息的處理負責。在這種情況下,client 可以選擇將消息 re-publish 。

    ??????在 channel 被設置成 confirm 模式之后,所有被 publish 的后續(xù)消息都將被 confirm(即 ack) 或者被 nack 一次。但是沒有對消息被 confirm 的快慢做任何保證,并且同一條消息不會既被 confirm 又被 nack 。

    ?

    消息在什么時候確認

    ?

    broker 將在下面的情況中對消息進行 confirm :

    • broker 發(fā)現(xiàn)當前消息無法被路由到指定的 queues 中(如果設置了?mandatory 屬性,則 broker 會先發(fā)送?basic.return)
    • 非持久屬性的消息到達了其所應該到達的所有 queue 中(和鏡像 queue 中)
    • 持久消息到達了其所應該到達的所有 queue 中(和鏡像 queue 中),并被持久化到了磁盤(被 fsync)
    • 持久消息從其所在的所有 queue 中被 consume 了(如果必要則會被 acknowledge)

    ?

    broker 會丟失持久化消息,如果 broker 在將上述消息寫入磁盤前異常。在一定條件下,這種情況會導致 broker 以一種奇怪的方式運行。例如,考慮下述情景:

    ?? 1.? 一個 client 將持久消息 publish 到持久 queue 中
    ?? 2.? 另一個 client 從 queue 中 consume 消息(注意:該消息具有持久屬性,并且 queue 是持久化的),當尚未對其進行 ack
    ?? 3.? broker 異常重啟
    ?? 4.? client 重連并開始 consume 消息

    ?? 在上述情景下,client 有理由認為消息需要被(broker)重新 deliver 。但這并非事實:重啟(有可能)會令 broker 丟失消息。為了確保持久性,client 應該使用 confirm 機制。如果 publisher 使用的 channel 被設置為 confirm 模式,publisher 將不會收到已丟失消息的 ack(這是因為 consumer 沒有對消息進行 ack ,同時該消息也未被寫入磁盤)。

    ?

    編程實現(xiàn)

    ?

    ?

    首先要區(qū)別AMQP協(xié)議mandatory和immediate標志位的作用。

    mandatory和immediate是AMQP協(xié)議中basic.pulish方法中的兩個標志位,它們都有當消息傳遞過程中不可達目的地時將消息返回給生產(chǎn)者的功能。具體區(qū)別在于:
    1. mandatory標志位
    當mandatory標志位設置為true時,如果exchange根據(jù)自身類型和消息routeKey無法找到一個符合條件的queue,那么會調(diào)用basic.return方法將消息返還給生產(chǎn)者;當mandatory設為false時,出現(xiàn)上述情形broker會直接將消息扔掉。
    2. immediate標志位
    當immediate標志位設置為true時,如果exchange在將消息route到queue(s)時發(fā)現(xiàn)對應的queue上沒有消費者,那么這條消息不會放入隊列中。當與消息routeKey關聯(lián)的所有queue(一個或多個)都沒有消費者時,該消息會通過basic.return方法返還給生產(chǎn)者。

    具體的代碼參考請參考參考資料1.

    ?

    參考資料:

    1. http://blog.csdn.NET/jiao_fuyou/article/details/21594205

    2. http://blog.csdn.net/jiao_fuyou/article/details/21594947

    3.??http://my.oschina.Net/moooofly/blog/142095

    ?

    ?

    ?

    ?

    總結

    以上是生活随笔為你收集整理的RabbitMQ从入门到精通的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

    无码人妻精品一区二区三区不卡 | 国产av一区二区三区最新精品 | 波多野42部无码喷潮在线 | 日韩av无码一区二区三区不卡 | 少妇被粗大的猛进出69影院 | 国产精品丝袜黑色高跟鞋 | 中文字幕av日韩精品一区二区 | 西西人体www44rt大胆高清 | 在线欧美精品一区二区三区 | 亚洲国产精品一区二区美利坚 | 亚洲国产成人av在线观看 | 国产免费无码一区二区视频 | 亚洲色无码一区二区三区 | 国产免费无码一区二区视频 | 麻豆国产丝袜白领秘书在线观看 | 久久精品中文字幕一区 | 99re在线播放 | 国产一精品一av一免费 | 国产亚洲人成在线播放 | 日韩视频 中文字幕 视频一区 | 亚洲色大成网站www国产 | 久久亚洲精品中文字幕无男同 | 激情国产av做激情国产爱 | 国产成人一区二区三区在线观看 | 亚洲理论电影在线观看 | 精品国产一区二区三区四区 | 纯爱无遮挡h肉动漫在线播放 | 国产熟女一区二区三区四区五区 | 国产激情无码一区二区app | 大地资源网第二页免费观看 | 欧美精品无码一区二区三区 | 丝袜人妻一区二区三区 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 久久99久久99精品中文字幕 | 精品国产乱码久久久久乱码 | 亚洲国产av精品一区二区蜜芽 | 风流少妇按摩来高潮 | 免费网站看v片在线18禁无码 | 少妇性俱乐部纵欲狂欢电影 | 亚洲熟女一区二区三区 | 青草青草久热国产精品 | 国产无遮挡吃胸膜奶免费看 | 国产精品办公室沙发 | 亚洲精品一区二区三区四区五区 | 国产精品成人av在线观看 | 一本色道婷婷久久欧美 | 日韩亚洲欧美精品综合 | 国产精华av午夜在线观看 | 牲欲强的熟妇农村老妇女视频 | 亚洲区小说区激情区图片区 | 一本大道伊人av久久综合 | 鲁大师影院在线观看 | 风流少妇按摩来高潮 | 精品一区二区三区波多野结衣 | 亚洲一区二区三区无码久久 | 亚洲综合无码一区二区三区 | 久久久中文字幕日本无吗 | 国产精品国产自线拍免费软件 | 中文字幕乱码人妻无码久久 | 激情亚洲一区国产精品 | 国产三级久久久精品麻豆三级 | 亚洲成av人片在线观看无码不卡 | 熟女俱乐部五十路六十路av | av无码电影一区二区三区 | 国产做国产爱免费视频 | a国产一区二区免费入口 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 狠狠色欧美亚洲狠狠色www | 日本欧美一区二区三区乱码 | 国产精品资源一区二区 | 亚洲自偷自偷在线制服 | 中文字幕久久久久人妻 | 爱做久久久久久 | 人妻少妇精品视频专区 | 亚洲色成人中文字幕网站 | 亚洲精品一区二区三区在线观看 | 国产免费久久久久久无码 | 在教室伦流澡到高潮hnp视频 | 少妇无码av无码专区在线观看 | 国产午夜亚洲精品不卡 | 久久99精品久久久久久动态图 | 国产精品99爱免费视频 | 欧美乱妇无乱码大黄a片 | 国产又爽又黄又刺激的视频 | 亚拍精品一区二区三区探花 | 丰满少妇人妻久久久久久 | 亚洲区欧美区综合区自拍区 | 成人性做爰aaa片免费看 | 国产情侣作爱视频免费观看 | 日产精品99久久久久久 | 国产成人精品久久亚洲高清不卡 | 久久综合久久自在自线精品自 | 成人无码精品一区二区三区 | 亚洲人交乣女bbw | 久久综合香蕉国产蜜臀av | 麻花豆传媒剧国产免费mv在线 | 亚洲色在线无码国产精品不卡 | 国产精品办公室沙发 | 国产精品久久久久影院嫩草 | 成人亚洲精品久久久久 | 日韩av激情在线观看 | 亚洲日韩一区二区 | 国産精品久久久久久久 | 色综合视频一区二区三区 | 熟妇女人妻丰满少妇中文字幕 | 午夜不卡av免费 一本久久a久久精品vr综合 | 色情久久久av熟女人妻网站 | 波多野结衣一区二区三区av免费 | 国产激情综合五月久久 | 天天拍夜夜添久久精品 | 曰韩无码二三区中文字幕 | 国产成人精品优优av | 性色av无码免费一区二区三区 | 精品无码一区二区三区的天堂 | 国产精品无码永久免费888 | 久久综合色之久久综合 | 综合激情五月综合激情五月激情1 | 国产性生大片免费观看性 | 亚洲一区二区三区国产精华液 | аⅴ资源天堂资源库在线 | 捆绑白丝粉色jk震动捧喷白浆 | 玩弄中年熟妇正在播放 | 人妻少妇精品无码专区动漫 | 亚洲一区二区三区偷拍女厕 | 国产综合久久久久鬼色 | 蜜臀av在线播放 久久综合激激的五月天 | 久久国语露脸国产精品电影 | 亚洲日本在线电影 | 欧美日本日韩 | 亚洲综合另类小说色区 | 国产九九九九九九九a片 | 成人精品视频一区二区三区尤物 | 野狼第一精品社区 | 成人精品一区二区三区中文字幕 | 精品无码成人片一区二区98 | 亚洲国产av精品一区二区蜜芽 | 国内少妇偷人精品视频 | 国产极品视觉盛宴 | 正在播放老肥熟妇露脸 | 一本无码人妻在中文字幕免费 | av人摸人人人澡人人超碰下载 | 亚洲国产精品无码一区二区三区 | 中文久久乱码一区二区 | 欧美丰满少妇xxxx性 | 精品人妻av区 | 亚洲日韩乱码中文无码蜜桃臀网站 | 色老头在线一区二区三区 | av无码久久久久不卡免费网站 | 国产精品久久久久久久9999 | 丰满少妇人妻久久久久久 | 在线精品国产一区二区三区 | 国产成人精品视频ⅴa片软件竹菊 | 夜夜高潮次次欢爽av女 | 国产人妖乱国产精品人妖 | 日本一本二本三区免费 | 色综合久久88色综合天天 | 久久精品人人做人人综合试看 | 国产欧美精品一区二区三区 | www国产精品内射老师 | 婷婷丁香六月激情综合啪 | 1000部啪啪未满十八勿入下载 | 在线观看国产午夜福利片 | 亚洲 激情 小说 另类 欧美 | 久久无码专区国产精品s | 玩弄少妇高潮ⅹxxxyw | 欧美xxxx黑人又粗又长 | 色婷婷综合激情综在线播放 | 少妇愉情理伦片bd | 伊人久久大香线蕉av一区二区 | 日韩成人一区二区三区在线观看 | 欧美人与禽猛交狂配 | 国产激情一区二区三区 | 色综合久久中文娱乐网 | 亚洲娇小与黑人巨大交 | av在线亚洲欧洲日产一区二区 | 日本成熟视频免费视频 | 日本一卡2卡3卡四卡精品网站 | 人人爽人人澡人人高潮 | 国产精品无码一区二区三区不卡 | 老头边吃奶边弄进去呻吟 | 一本大道伊人av久久综合 | 中文无码精品a∨在线观看不卡 | 俺去俺来也在线www色官网 | 久久人人爽人人爽人人片ⅴ | 欧美人与禽zoz0性伦交 | 国产精品久久精品三级 | 老子影院午夜伦不卡 | 久久视频在线观看精品 | 丰满肥臀大屁股熟妇激情视频 | 成人动漫在线观看 | 熟妇人妻中文av无码 | 99久久无码一区人妻 | 天天做天天爱天天爽综合网 | 人人澡人人妻人人爽人人蜜桃 | 国产成人无码午夜视频在线观看 | 老子影院午夜精品无码 | 国产精品久久久久久亚洲毛片 | 欧美一区二区三区视频在线观看 | 久久精品女人天堂av免费观看 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 东京无码熟妇人妻av在线网址 | 久久国产自偷自偷免费一区调 | 久久综合九色综合欧美狠狠 | 露脸叫床粗话东北少妇 | 国产口爆吞精在线视频 | 国产舌乚八伦偷品w中 | 日日鲁鲁鲁夜夜爽爽狠狠 | 免费无码午夜福利片69 | 亚洲日韩精品欧美一区二区 | 香蕉久久久久久av成人 | 日韩精品无码免费一区二区三区 | 国产乱人无码伦av在线a | 精品久久综合1区2区3区激情 | 欧美午夜特黄aaaaaa片 | 色欲av亚洲一区无码少妇 | 亚洲精品国偷拍自产在线麻豆 | 国产特级毛片aaaaaaa高清 | 精品久久久无码中文字幕 | 一二三四在线观看免费视频 | a国产一区二区免费入口 | 国产精品自产拍在线观看 | 精品久久久中文字幕人妻 | 精品夜夜澡人妻无码av蜜桃 | 久久亚洲精品成人无码 | 色综合天天综合狠狠爱 | 亚洲精品国偷拍自产在线观看蜜桃 | 国产午夜视频在线观看 | 免费人成网站视频在线观看 | 蜜桃视频韩日免费播放 | 中文亚洲成a人片在线观看 | 中文字幕亚洲情99在线 | 久久婷婷五月综合色国产香蕉 | 美女极度色诱视频国产 | 激情五月综合色婷婷一区二区 | 中文字幕无码人妻少妇免费 | 国精产品一区二区三区 | 九月婷婷人人澡人人添人人爽 | 中文久久乱码一区二区 | 日韩欧美成人免费观看 | 色欲久久久天天天综合网精品 | 精品一二三区久久aaa片 | 色一情一乱一伦一区二区三欧美 | 荫蒂添的好舒服视频囗交 | 天堂а√在线中文在线 | 成 人影片 免费观看 | 日日天日日夜日日摸 | 亚洲自偷精品视频自拍 | 日日麻批免费40分钟无码 | 真人与拘做受免费视频 | 国产精品无码一区二区三区不卡 | 国产成人人人97超碰超爽8 | 曰韩少妇内射免费播放 | 一本久道高清无码视频 | 精品成在人线av无码免费看 | 精品国产麻豆免费人成网站 | 久久久av男人的天堂 | 久久无码中文字幕免费影院蜜桃 | 欧美阿v高清资源不卡在线播放 | 久久久久成人片免费观看蜜芽 | 中文字幕av日韩精品一区二区 | 中国大陆精品视频xxxx | 色五月丁香五月综合五月 | а√资源新版在线天堂 | 亚洲欧洲日本无在线码 | 欧洲极品少妇 | 野狼第一精品社区 | 精品国产一区二区三区四区在线看 | 日产精品高潮呻吟av久久 | 7777奇米四色成人眼影 | 无码人妻久久一区二区三区不卡 | 色狠狠av一区二区三区 | av小次郎收藏 | 狠狠色丁香久久婷婷综合五月 | 99久久婷婷国产综合精品青草免费 | 97久久国产亚洲精品超碰热 | 日韩人妻少妇一区二区三区 | 国产午夜福利100集发布 | 国产精品99久久精品爆乳 | 色综合视频一区二区三区 | 在线观看免费人成视频 | 激情内射日本一区二区三区 | 国产成人无码区免费内射一片色欲 | 精品久久久久久亚洲精品 | 99er热精品视频 | 中文字幕无码日韩专区 | 亚洲精品国产a久久久久久 | 丰满人妻翻云覆雨呻吟视频 | 久久99精品国产麻豆 | 成在人线av无码免费 | 欧美亚洲日韩国产人成在线播放 | 国产明星裸体无码xxxx视频 | 国产一精品一av一免费 | 少妇被黑人到高潮喷出白浆 | 国产人妻精品一区二区三区 | 欧洲熟妇色 欧美 | 在线播放无码字幕亚洲 | 久久精品成人欧美大片 | 亚洲精品中文字幕久久久久 | 亚洲精品国偷拍自产在线观看蜜桃 | 欧美精品在线观看 | 97资源共享在线视频 | 亚洲成a人片在线观看日本 | 日本护士xxxxhd少妇 | 国产午夜无码视频在线观看 | 美女极度色诱视频国产 | 最新国产乱人伦偷精品免费网站 | 全黄性性激高免费视频 | 精品亚洲成av人在线观看 | 亚洲色www成人永久网址 | 久久综合网欧美色妞网 | 最近的中文字幕在线看视频 | 亲嘴扒胸摸屁股激烈网站 | 国产乱人伦偷精品视频 | 欧美亚洲日韩国产人成在线播放 | 国产精品手机免费 | 日日麻批免费40分钟无码 | 国内精品久久久久久中文字幕 | 国产国语老龄妇女a片 | 疯狂三人交性欧美 | aa片在线观看视频在线播放 | 精品国产成人一区二区三区 | 四虎影视成人永久免费观看视频 | 亚洲国产精品一区二区第一页 | 2020最新国产自产精品 | 色狠狠av一区二区三区 | 99久久人妻精品免费二区 | 日韩人妻无码中文字幕视频 | 色婷婷久久一区二区三区麻豆 | 无码国产色欲xxxxx视频 | 亚洲中文字幕在线无码一区二区 | 在线观看欧美一区二区三区 | 国产av久久久久精东av | 日本爽爽爽爽爽爽在线观看免 | 99久久精品国产一区二区蜜芽 | 兔费看少妇性l交大片免费 | 日日碰狠狠躁久久躁蜜桃 | 老司机亚洲精品影院 | 波多野结衣aⅴ在线 | 激情内射亚州一区二区三区爱妻 | 女高中生第一次破苞av | 国产精品成人av在线观看 | 国产免费无码一区二区视频 | 最近的中文字幕在线看视频 | 理论片87福利理论电影 | 久在线观看福利视频 | 亚洲熟妇色xxxxx亚洲 | 国产精品资源一区二区 | 一区二区三区乱码在线 | 欧洲 | 天下第一社区视频www日本 | 蜜桃无码一区二区三区 | 亚洲s码欧洲m码国产av | 麻花豆传媒剧国产免费mv在线 | 婷婷丁香六月激情综合啪 | 亚洲国产成人av在线观看 | 大地资源中文第3页 | 中文字幕av无码一区二区三区电影 | 欧美人与禽猛交狂配 | 日韩亚洲欧美中文高清在线 | 影音先锋中文字幕无码 | 精品久久久无码人妻字幂 | 特大黑人娇小亚洲女 | 无码av中文字幕免费放 | 国产真人无遮挡作爱免费视频 | 精品国产一区二区三区四区 | 国精产品一区二区三区 | 天海翼激烈高潮到腰振不止 | 亚洲日本一区二区三区在线 | 国产亚av手机在线观看 | 少妇高潮喷潮久久久影院 | 熟女体下毛毛黑森林 | 嫩b人妻精品一区二区三区 | 国产人妻精品一区二区三区 | 少妇高潮一区二区三区99 | 少妇高潮一区二区三区99 | 国产在线精品一区二区高清不卡 | 国产精品久久精品三级 | 久久99精品国产.久久久久 | 老子影院午夜伦不卡 | 亚洲s色大片在线观看 | 中文字幕av日韩精品一区二区 | 久久精品成人欧美大片 | 麻豆md0077饥渴少妇 | 色欲人妻aaaaaaa无码 | 色欲av亚洲一区无码少妇 | 2019午夜福利不卡片在线 | 成年美女黄网站色大免费全看 | 中文字幕人妻丝袜二区 | 亚洲中文字幕av在天堂 | 欧美xxxx黑人又粗又长 | 波多野结衣av在线观看 | 日韩人妻少妇一区二区三区 | 亚洲国产精品无码久久久久高潮 | 丰满岳乱妇在线观看中字无码 | 一个人看的www免费视频在线观看 | 亚洲精品一区二区三区四区五区 | 精品人人妻人人澡人人爽人人 | 亚洲狠狠色丁香婷婷综合 | 中文字幕中文有码在线 | 97久久超碰中文字幕 | 香蕉久久久久久av成人 | 久久久久久久人妻无码中文字幕爆 | 伊人久久大香线蕉午夜 | 免费观看又污又黄的网站 | 精品久久综合1区2区3区激情 | 天天做天天爱天天爽综合网 | 国产精品第一区揄拍无码 | 中国女人内谢69xxxxxa片 | 麻豆国产人妻欲求不满谁演的 | 国内丰满熟女出轨videos | 99久久精品国产一区二区蜜芽 | 国产精品美女久久久 | 无码国产激情在线观看 | 亚洲日韩乱码中文无码蜜桃臀网站 | 中文字幕 人妻熟女 | 在线 国产 欧美 亚洲 天堂 | 欧美肥老太牲交大战 | 久久午夜无码鲁丝片午夜精品 | 无码乱肉视频免费大全合集 | 国产欧美精品一区二区三区 | 国产suv精品一区二区五 | 国产明星裸体无码xxxx视频 | 真人与拘做受免费视频一 | 欧美freesex黑人又粗又大 | 日韩av无码一区二区三区不卡 | 成人性做爰aaa片免费看 | 伊人久久婷婷五月综合97色 | 领导边摸边吃奶边做爽在线观看 | 国产精品久久久久无码av色戒 | www国产精品内射老师 | 欧洲vodafone精品性 | 亚洲狠狠色丁香婷婷综合 | 丰腴饱满的极品熟妇 | 成人无码精品一区二区三区 | 亚洲日韩乱码中文无码蜜桃臀网站 | 性色av无码免费一区二区三区 | 国产一区二区三区精品视频 | 奇米影视7777久久精品人人爽 | 丰满肥臀大屁股熟妇激情视频 | 亚洲人成网站免费播放 | 成人一区二区免费视频 | 午夜福利一区二区三区在线观看 | 99久久99久久免费精品蜜桃 | 精品日本一区二区三区在线观看 | 久久久精品国产sm最大网站 | 三级4级全黄60分钟 | 黑人大群体交免费视频 | 久久久久久av无码免费看大片 | 久久精品国产99精品亚洲 | 欧美日韩一区二区免费视频 | 西西人体www44rt大胆高清 | 少妇性俱乐部纵欲狂欢电影 | 国产激情艳情在线看视频 | 一本无码人妻在中文字幕免费 | 国产成人综合美国十次 | 国产在线精品一区二区三区直播 | 国产精品国产自线拍免费软件 | 免费看少妇作爱视频 | 日韩欧美中文字幕公布 | 色噜噜亚洲男人的天堂 | 97久久国产亚洲精品超碰热 | 男人和女人高潮免费网站 | 樱花草在线播放免费中文 | 久久无码人妻影院 | 日韩精品无码免费一区二区三区 | www国产亚洲精品久久久日本 | 国产精品无码一区二区三区不卡 | 少妇人妻大乳在线视频 | 久久综合给久久狠狠97色 | 国产另类ts人妖一区二区 | 欧美老妇交乱视频在线观看 | 丁香啪啪综合成人亚洲 | 亚洲日韩av一区二区三区中文 | 亚洲欧美精品aaaaaa片 | 国产精品欧美成人 | 国产成人精品久久亚洲高清不卡 | 色偷偷人人澡人人爽人人模 | 九九综合va免费看 | 中文字幕av伊人av无码av | 欧美人与善在线com | 日日天干夜夜狠狠爱 | 欧美 亚洲 国产 另类 | 蜜臀av无码人妻精品 | 狠狠色欧美亚洲狠狠色www | а天堂中文在线官网 | 久久视频在线观看精品 | 在线精品国产一区二区三区 | √天堂中文官网8在线 | 亚洲精品午夜无码电影网 | 亚洲小说图区综合在线 | 在线 国产 欧美 亚洲 天堂 | 国产人妻精品午夜福利免费 | 婷婷五月综合缴情在线视频 | 欧美xxxx黑人又粗又长 | 精品国产一区av天美传媒 | 玩弄人妻少妇500系列视频 | 天天躁夜夜躁狠狠是什么心态 | 久久久国产精品无码免费专区 | 国产一区二区三区日韩精品 | 亚洲综合无码一区二区三区 | 久久亚洲a片com人成 | 免费看少妇作爱视频 | 精品无码av一区二区三区 | 精品厕所偷拍各类美女tp嘘嘘 | 波多野结衣aⅴ在线 | 日日碰狠狠丁香久燥 | 亚洲码国产精品高潮在线 | 一区二区三区乱码在线 | 欧洲 | 国内精品久久久久久中文字幕 | 欧美日韩久久久精品a片 | 欧美人与善在线com | 人妻有码中文字幕在线 | 国产网红无码精品视频 | 免费无码肉片在线观看 | 国产免费观看黄av片 | 黑人巨大精品欧美一区二区 | 无码福利日韩神码福利片 | 98国产精品综合一区二区三区 | 无码人妻丰满熟妇区五十路百度 | 无码人妻少妇伦在线电影 | 成人aaa片一区国产精品 | 久久久久久久久蜜桃 | 九一九色国产 | 国产亚洲欧美日韩亚洲中文色 | 99久久久国产精品无码免费 | 色窝窝无码一区二区三区色欲 | 日本乱人伦片中文三区 | 美女扒开屁股让男人桶 | 久久这里只有精品视频9 | 18精品久久久无码午夜福利 | 一区二区三区高清视频一 | 美女毛片一区二区三区四区 | 久久亚洲中文字幕精品一区 | 少妇性l交大片欧洲热妇乱xxx | 东京热男人av天堂 | 日产精品99久久久久久 | 啦啦啦www在线观看免费视频 | 国产精品免费大片 | 无码人妻黑人中文字幕 | 国产成人综合美国十次 | 精品国产成人一区二区三区 | 亚洲小说图区综合在线 | 国产精品久久久久无码av色戒 | 国产精品va在线播放 | 人妻有码中文字幕在线 | 精品厕所偷拍各类美女tp嘘嘘 | 久久久久亚洲精品男人的天堂 | 久久无码中文字幕免费影院蜜桃 | 天天躁日日躁狠狠躁免费麻豆 | 四十如虎的丰满熟妇啪啪 | 亚洲精品鲁一鲁一区二区三区 | 亚洲七七久久桃花影院 | 国产av人人夜夜澡人人爽麻豆 | 日韩 欧美 动漫 国产 制服 | 亚洲一区二区三区含羞草 | 亚洲区小说区激情区图片区 | 国产精品人妻一区二区三区四 | 亚无码乱人伦一区二区 | 亚洲一区二区三区 | 中文字幕av伊人av无码av | 熟女少妇在线视频播放 | 黑人大群体交免费视频 | 双乳奶水饱满少妇呻吟 | 国产精品理论片在线观看 | 亚洲国产日韩a在线播放 | 亚洲区小说区激情区图片区 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 日韩成人一区二区三区在线观看 | 无码人中文字幕 | 久久久久99精品成人片 | 无码吃奶揉捏奶头高潮视频 | 娇妻被黑人粗大高潮白浆 | 日韩av无码一区二区三区 | 性色av无码免费一区二区三区 | 亚洲欧美国产精品专区久久 | 欧美兽交xxxx×视频 | 麻豆精产国品 | ass日本丰满熟妇pics | 天堂一区人妻无码 | 日本精品久久久久中文字幕 | 国产美女精品一区二区三区 | 国内少妇偷人精品视频免费 | 日韩精品无码免费一区二区三区 | 国产熟女一区二区三区四区五区 | 亚洲乱码国产乱码精品精 | 免费人成在线视频无码 | 无码人妻久久一区二区三区不卡 | 午夜肉伦伦影院 | 精品国产aⅴ无码一区二区 | 无码精品国产va在线观看dvd | 亚洲色欲色欲欲www在线 | 久久久中文久久久无码 | 爆乳一区二区三区无码 | 玩弄少妇高潮ⅹxxxyw | 国产精品国产三级国产专播 | 国产又爽又猛又粗的视频a片 | 亚洲色欲色欲欲www在线 | 无码成人精品区在线观看 | 成人影院yy111111在线观看 | 一区二区三区高清视频一 | 午夜精品久久久久久久久 | 天天躁夜夜躁狠狠是什么心态 | 亚洲欧美国产精品久久 | 亚洲精品国产a久久久久久 | 99riav国产精品视频 | 亚洲一区二区三区在线观看网站 | 精品国产国产综合精品 | 国产一区二区三区影院 | 国产欧美精品一区二区三区 | 久久综合激激的五月天 | 精品乱码久久久久久久 | 亚洲国产成人av在线观看 | 国产口爆吞精在线视频 | 日日麻批免费40分钟无码 | 久久综合九色综合欧美狠狠 | 国产av剧情md精品麻豆 | 亚洲成a人片在线观看日本 | 亚洲国产高清在线观看视频 | 国产精品高潮呻吟av久久4虎 | 国产猛烈高潮尖叫视频免费 | 国产97色在线 | 免 | 日本www一道久久久免费榴莲 | 亚洲一区二区观看播放 | 久久精品中文闷骚内射 | 亚洲精品国产a久久久久久 | 中文字幕乱码中文乱码51精品 | 国产农村乱对白刺激视频 | 性欧美熟妇videofreesex | 疯狂三人交性欧美 | 亚洲第一无码av无码专区 | 久久亚洲中文字幕无码 | 精品久久久无码人妻字幂 | 精品无码国产自产拍在线观看蜜 | 久久99精品国产.久久久久 | 亚洲国产一区二区三区在线观看 | 少妇无码av无码专区在线观看 | 亚洲日韩精品欧美一区二区 | 国产9 9在线 | 中文 | 久久97精品久久久久久久不卡 | 日本熟妇乱子伦xxxx | 成年女人永久免费看片 | 国产一区二区三区四区五区加勒比 | 久久精品国产99久久6动漫 | 国语精品一区二区三区 | 最近的中文字幕在线看视频 | 国产激情综合五月久久 | 无码人妻精品一区二区三区不卡 | 久久久精品456亚洲影院 | 亚洲娇小与黑人巨大交 | 精品一二三区久久aaa片 | 色综合视频一区二区三区 | 无码国内精品人妻少妇 | 人妻与老人中文字幕 | 99久久久无码国产精品免费 | 婷婷丁香六月激情综合啪 | 亚洲成色在线综合网站 | 成熟女人特级毛片www免费 | 美女黄网站人色视频免费国产 | 午夜嘿嘿嘿影院 | 一个人看的视频www在线 | 国产欧美亚洲精品a | 国产va免费精品观看 | 欧洲美熟女乱又伦 | 最新版天堂资源中文官网 | av香港经典三级级 在线 | 性开放的女人aaa片 | 亚洲一区二区三区香蕉 | 麻豆国产97在线 | 欧洲 | 久久久精品国产sm最大网站 | 欧美国产日韩久久mv | 性生交大片免费看l | 亚洲人成网站在线播放942 | 熟妇女人妻丰满少妇中文字幕 | 任你躁国产自任一区二区三区 | 国内精品九九久久久精品 | 久久综合九色综合欧美狠狠 | a在线亚洲男人的天堂 | 婷婷六月久久综合丁香 | 自拍偷自拍亚洲精品10p | 亚洲国产欧美在线成人 | 装睡被陌生人摸出水好爽 | 国产真实夫妇视频 | 亚洲一区二区三区香蕉 | 国产精品第一国产精品 | 天天av天天av天天透 | 免费无码午夜福利片69 | 欧美性猛交xxxx富婆 | 国产精品免费大片 | 国产亚洲精品久久久ai换 | 欧美人与牲动交xxxx | 成人影院yy111111在线观看 | 欧美精品一区二区精品久久 | 亚洲熟妇色xxxxx欧美老妇 | 精品乱子伦一区二区三区 | 无码一区二区三区在线 | 久久综合网欧美色妞网 | 国产人妻人伦精品1国产丝袜 | 国产精品亚洲综合色区韩国 | 天干天干啦夜天干天2017 | 亚洲精品中文字幕 | 露脸叫床粗话东北少妇 | 色妞www精品免费视频 | 黄网在线观看免费网站 | 国产无遮挡又黄又爽又色 | 欧美熟妇另类久久久久久不卡 | 亚洲精品中文字幕 | 亚洲 欧美 激情 小说 另类 | 性生交大片免费看女人按摩摩 | 丁香花在线影院观看在线播放 | 亚洲第一无码av无码专区 | 午夜福利一区二区三区在线观看 | 欧美性生交活xxxxxdddd | 亚洲色无码一区二区三区 | 欧美熟妇另类久久久久久不卡 | 亚洲熟熟妇xxxx | 又色又爽又黄的美女裸体网站 | 欧美日本精品一区二区三区 | 国产精品第一区揄拍无码 | 欧美喷潮久久久xxxxx | yw尤物av无码国产在线观看 | 亚洲成a人片在线观看无码 | 亚洲欧美中文字幕5发布 | 色婷婷香蕉在线一区二区 | 久久久久久a亚洲欧洲av冫 | 樱花草在线播放免费中文 | 久久精品国产精品国产精品污 | 99久久久国产精品无码免费 | 偷窥村妇洗澡毛毛多 | 97久久精品无码一区二区 | 97精品人妻一区二区三区香蕉 | 国产精品久久福利网站 | 亚洲热妇无码av在线播放 | 99久久亚洲精品无码毛片 | 色偷偷人人澡人人爽人人模 | 亚洲日韩精品欧美一区二区 | 欧美日韩久久久精品a片 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 国产精品资源一区二区 | 十八禁真人啪啪免费网站 | 色婷婷综合中文久久一本 | 久久国产精品二国产精品 | 麻豆精品国产精华精华液好用吗 | 人妻体内射精一区二区三四 | 亚洲欧洲无卡二区视頻 | 国内精品九九久久久精品 | 国产suv精品一区二区五 | 精品久久8x国产免费观看 | 久久久久99精品国产片 | 国内丰满熟女出轨videos | 亚洲色www成人永久网址 | 少妇无套内谢久久久久 | 丁香花在线影院观看在线播放 | 日日夜夜撸啊撸 | 男女性色大片免费网站 | 嫩b人妻精品一区二区三区 | 国产成人无码区免费内射一片色欲 | 青草青草久热国产精品 | 亚洲中文字幕av在天堂 | 男女猛烈xx00免费视频试看 | 无码av最新清无码专区吞精 | 人人爽人人爽人人片av亚洲 | 成人无码视频免费播放 | 在线欧美精品一区二区三区 | 99精品无人区乱码1区2区3区 | 少女韩国电视剧在线观看完整 | 午夜精品一区二区三区的区别 | 亚洲人成网站在线播放942 | 日本在线高清不卡免费播放 | 久久久亚洲欧洲日产国码αv | 欧美高清在线精品一区 | 男人的天堂2018无码 | 九月婷婷人人澡人人添人人爽 | 亚洲国产精品无码一区二区三区 | 亚洲熟妇色xxxxx欧美老妇y | 四虎永久在线精品免费网址 | 丰满岳乱妇在线观看中字无码 | 色狠狠av一区二区三区 | 亚洲性无码av中文字幕 | 国产无套内射久久久国产 | 综合人妻久久一区二区精品 | 久久精品女人天堂av免费观看 | 国产激情无码一区二区app | 99re在线播放 | 一本色道久久综合亚洲精品不卡 | 未满成年国产在线观看 | av无码电影一区二区三区 | 欧美老人巨大xxxx做受 | 国产明星裸体无码xxxx视频 | 国产欧美亚洲精品a | 久久久精品国产sm最大网站 | 国产乱人伦偷精品视频 | 日本饥渴人妻欲求不满 | 99er热精品视频 | 国产9 9在线 | 中文 | 久久综合久久自在自线精品自 | 国产成人人人97超碰超爽8 | 中文字幕人妻无码一区二区三区 | 亚洲区欧美区综合区自拍区 | 亚洲精品久久久久中文第一幕 | 国产精品久久久久久亚洲影视内衣 | 成人影院yy111111在线观看 | 亚洲国产成人a精品不卡在线 | 嫩b人妻精品一区二区三区 | 一本色道久久综合亚洲精品不卡 | 亚洲精品一区二区三区在线观看 | 99精品无人区乱码1区2区3区 | 99久久无码一区人妻 | 精品国产乱码久久久久乱码 | 国产内射爽爽大片视频社区在线 | 免费无码午夜福利片69 | 中文精品久久久久人妻不卡 | 国产成人综合在线女婷五月99播放 | 又黄又爽又色的视频 | 亚洲男人av香蕉爽爽爽爽 | 国产精品亚洲专区无码不卡 | 日韩人妻系列无码专区 | 久久久久久国产精品无码下载 | 国产成人综合美国十次 | 丰满人妻一区二区三区免费视频 | 激情爆乳一区二区三区 | 久久国内精品自在自线 | 国产97在线 | 亚洲 | 精品少妇爆乳无码av无码专区 | 人人妻人人澡人人爽欧美精品 | 亚洲第一网站男人都懂 | 国产精品美女久久久网av | 国产精品99爱免费视频 | 久久国产精品二国产精品 | 又粗又大又硬又长又爽 | 久久久精品欧美一区二区免费 | 大肉大捧一进一出视频出来呀 | 少妇厨房愉情理9仑片视频 | 亚洲一区二区观看播放 | 亚洲精品一区二区三区大桥未久 | 亚洲天堂2017无码 | 内射欧美老妇wbb | 久久久久久a亚洲欧洲av冫 | 夜夜躁日日躁狠狠久久av | 欧美日韩在线亚洲综合国产人 | aⅴ亚洲 日韩 色 图网站 播放 | 天天燥日日燥 | 成 人 免费观看网站 | 日本xxxx色视频在线观看免费 | 无码人妻精品一区二区三区下载 | 国产麻豆精品精东影业av网站 | 精品无码国产一区二区三区av | 亚洲一区二区观看播放 | 精品 日韩 国产 欧美 视频 | 牛和人交xxxx欧美 | 国产午夜无码视频在线观看 | 国产乱码精品一品二品 | 极品尤物被啪到呻吟喷水 | 欧美日韩一区二区免费视频 | 成在人线av无码免费 | 成人无码影片精品久久久 | 人人妻人人澡人人爽欧美精品 | 久久精品人人做人人综合试看 | 丰满人妻精品国产99aⅴ | 精品乱子伦一区二区三区 | 少妇一晚三次一区二区三区 | 丰满肥臀大屁股熟妇激情视频 | 国产性生大片免费观看性 | 精品国产成人一区二区三区 | 在线播放亚洲第一字幕 | а√天堂www在线天堂小说 | 成人女人看片免费视频放人 | 99精品久久毛片a片 | 国产精品久久久一区二区三区 | a片免费视频在线观看 | 野狼第一精品社区 | 欧美老妇交乱视频在线观看 | 一本一道久久综合久久 | 正在播放东北夫妻内射 | 国产精品永久免费视频 | 又大又硬又黄的免费视频 | 国产高清av在线播放 | 久久国产自偷自偷免费一区调 | 两性色午夜免费视频 | 国内老熟妇对白xxxxhd | 大屁股大乳丰满人妻 | 无码成人精品区在线观看 | 国产两女互慰高潮视频在线观看 | 久久国内精品自在自线 | 婷婷色婷婷开心五月四房播播 | 亚洲乱码国产乱码精品精 | 中文字幕av无码一区二区三区电影 | 中文字幕人成乱码熟女app | 欧美日韩色另类综合 | 国产精品国产自线拍免费软件 | 国产两女互慰高潮视频在线观看 | 日本一区二区三区免费高清 | 国内精品九九久久久精品 | 人人妻人人澡人人爽欧美一区九九 | 国产一区二区不卡老阿姨 | 国产sm调教视频在线观看 | 欧洲vodafone精品性 | 精品国产av色一区二区深夜久久 | 丰满人妻精品国产99aⅴ | 久久aⅴ免费观看 | 好屌草这里只有精品 | www一区二区www免费 | 极品尤物被啪到呻吟喷水 | 国产超碰人人爽人人做人人添 | 国产精品人妻一区二区三区四 | 国产高清av在线播放 | 久久精品女人天堂av免费观看 | 无码乱肉视频免费大全合集 | 国产真实夫妇视频 | 天堂а√在线地址中文在线 | 久久久精品成人免费观看 | 久久精品人人做人人综合试看 | 婷婷丁香六月激情综合啪 | 欧美日韩人成综合在线播放 | 国内揄拍国内精品人妻 | 性生交大片免费看女人按摩摩 | 无码精品人妻一区二区三区av | 亚洲精品成人av在线 | 波多野结衣高清一区二区三区 | 一本久久伊人热热精品中文字幕 | 老熟女乱子伦 | 国产97在线 | 亚洲 | 欧美freesex黑人又粗又大 | 亚洲 高清 成人 动漫 | 女人被男人爽到呻吟的视频 | 波多野结衣一区二区三区av免费 | 99er热精品视频 | 久久亚洲中文字幕无码 | 精品无码国产自产拍在线观看蜜 | 在线观看国产一区二区三区 | 亚洲综合伊人久久大杳蕉 | 精品亚洲韩国一区二区三区 | 亚洲熟悉妇女xxx妇女av | 伊人久久大香线焦av综合影院 | 少妇性l交大片欧洲热妇乱xxx | 亚洲精品国偷拍自产在线观看蜜桃 | av无码久久久久不卡免费网站 | 国产精品第一区揄拍无码 | 欧美激情综合亚洲一二区 | 亚洲国产精品久久久天堂 | 亚洲成a人一区二区三区 | 东京热无码av男人的天堂 | 国产人妻人伦精品 | 日韩精品乱码av一区二区 | 成 人 网 站国产免费观看 | 久久五月精品中文字幕 | 亚洲大尺度无码无码专区 | 人妻尝试又大又粗久久 | 色一情一乱一伦一视频免费看 | 国产精品视频免费播放 | 精品亚洲韩国一区二区三区 | 日本大乳高潮视频在线观看 | 国产成人综合在线女婷五月99播放 | 超碰97人人做人人爱少妇 | 高清不卡一区二区三区 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 永久免费精品精品永久-夜色 | 狠狠色欧美亚洲狠狠色www | 无码av岛国片在线播放 | 亚洲中文字幕在线无码一区二区 | 熟妇人妻激情偷爽文 | 日本一本二本三区免费 | 鲁一鲁av2019在线 | 色老头在线一区二区三区 | 蜜臀aⅴ国产精品久久久国产老师 | 国产成人午夜福利在线播放 | 青青草原综合久久大伊人精品 | 最近中文2019字幕第二页 | 国产精品久久久久久亚洲影视内衣 | 99久久久无码国产精品免费 | 国产亚洲精品久久久久久 | 欧美一区二区三区视频在线观看 | 亚洲色欲色欲天天天www | 一本大道久久东京热无码av | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 欧美成人高清在线播放 | 熟女少妇人妻中文字幕 | 国产卡一卡二卡三 | 中文字幕人妻无码一夲道 | 成人av无码一区二区三区 | 午夜精品一区二区三区在线观看 | 日本一区二区三区免费播放 | 亚洲国产午夜精品理论片 | 久久国产36精品色熟妇 | 少妇一晚三次一区二区三区 | 久热国产vs视频在线观看 | 美女张开腿让人桶 | 国产成人一区二区三区在线观看 | 无码国产激情在线观看 | 欧美人与物videos另类 | 日本在线高清不卡免费播放 | 国产乱子伦视频在线播放 | 无码人妻精品一区二区三区下载 | 国产亚洲精品久久久ai换 | 少妇人妻av毛片在线看 | 中文字幕中文有码在线 | 久久久久亚洲精品中文字幕 | 国产sm调教视频在线观看 | 日本在线高清不卡免费播放 | 日本一本二本三区免费 | 国产乱人伦偷精品视频 | 亚洲综合无码一区二区三区 | 18禁黄网站男男禁片免费观看 | 大肉大捧一进一出视频出来呀 | 国产精品久久久久9999小说 | 少妇人妻偷人精品无码视频 | 国产97色在线 | 免 | 正在播放老肥熟妇露脸 | 精品乱码久久久久久久 | 婷婷五月综合激情中文字幕 | 九九综合va免费看 | 日本一区二区三区免费高清 | 亚洲色欲色欲欲www在线 | 日韩成人一区二区三区在线观看 | 日韩人妻少妇一区二区三区 | 在线a亚洲视频播放在线观看 | 亚洲欧美国产精品专区久久 | 亚洲日韩av一区二区三区中文 | 精品国精品国产自在久国产87 | 久久久久久亚洲精品a片成人 | 亚洲爆乳大丰满无码专区 | 少妇性l交大片欧洲热妇乱xxx | 色综合久久88色综合天天 | 无码人妻av免费一区二区三区 | 精品无码国产自产拍在线观看蜜 | 女人被男人躁得好爽免费视频 | 欧洲美熟女乱又伦 | a在线观看免费网站大全 | 国产av无码专区亚洲a∨毛片 | 国产精品久久久久7777 | 中文字幕亚洲情99在线 | 久精品国产欧美亚洲色aⅴ大片 | 人人妻人人澡人人爽人人精品 | 欧美性生交活xxxxxdddd | 国产成人综合美国十次 | 精品厕所偷拍各类美女tp嘘嘘 | 六月丁香婷婷色狠狠久久 | 日本一本二本三区免费 | 性做久久久久久久免费看 | 日本免费一区二区三区最新 | 18禁黄网站男男禁片免费观看 | 中文字幕日韩精品一区二区三区 | √8天堂资源地址中文在线 | 女人被男人爽到呻吟的视频 | 国内丰满熟女出轨videos | 一个人看的www免费视频在线观看 | 中文字幕中文有码在线 | 欧美高清在线精品一区 | 亚洲另类伦春色综合小说 | aⅴ在线视频男人的天堂 | 亚洲综合精品香蕉久久网 | 亚洲熟妇色xxxxx亚洲 | 久久久久久av无码免费看大片 | 丰满妇女强制高潮18xxxx | 99久久99久久免费精品蜜桃 | 十八禁真人啪啪免费网站 | 亚洲精品美女久久久久久久 | 国产精品丝袜黑色高跟鞋 | 性做久久久久久久免费看 | 一本一道久久综合久久 | 亚洲精品一区二区三区在线 | 成人无码视频在线观看网站 | 18无码粉嫩小泬无套在线观看 | 久久亚洲中文字幕无码 | 日本又色又爽又黄的a片18禁 | 亚洲一区二区三区国产精华液 | 女人被爽到呻吟gif动态图视看 | 日本熟妇人妻xxxxx人hd | 亚洲精品一区三区三区在线观看 | 久久国产精品_国产精品 | 女人高潮内射99精品 | 四虎国产精品免费久久 | 亚洲国产精品久久久久久 | 亚洲一区二区三区偷拍女厕 | 久久久久久国产精品无码下载 | 无码国产色欲xxxxx视频 | 一本久道久久综合婷婷五月 | 乌克兰少妇xxxx做受 | 大地资源中文第3页 | 狠狠色噜噜狠狠狠狠7777米奇 | 无套内射视频囯产 | 成 人 免费观看网站 | 国产精品无码成人午夜电影 | 激情爆乳一区二区三区 | 伊人久久大香线蕉av一区二区 | 国产香蕉尹人综合在线观看 | 欧洲欧美人成视频在线 | 国产成人无码一二三区视频 | 成人女人看片免费视频放人 | 欧美自拍另类欧美综合图片区 | 人人澡人摸人人添 | 日本一卡2卡3卡四卡精品网站 | 亚洲a无码综合a国产av中文 | 内射老妇bbwx0c0ck | 小sao货水好多真紧h无码视频 | 强开小婷嫩苞又嫩又紧视频 | 免费中文字幕日韩欧美 | 成人亚洲精品久久久久 | 无码人妻av免费一区二区三区 | 一本久久a久久精品亚洲 | 亚洲中文字幕乱码av波多ji | 网友自拍区视频精品 | 性色欲情网站iwww九文堂 | 国产午夜福利亚洲第一 | 99er热精品视频 | 精品国产国产综合精品 | 人妻体内射精一区二区三四 | 四虎影视成人永久免费观看视频 | 午夜精品久久久久久久久 | 天堂亚洲免费视频 | 任你躁在线精品免费 | 婷婷综合久久中文字幕蜜桃三电影 | 永久黄网站色视频免费直播 | 18禁止看的免费污网站 | 98国产精品综合一区二区三区 | 日本一区二区更新不卡 | 未满成年国产在线观看 | 理论片87福利理论电影 | 久久久久国色av免费观看性色 | 精品国产麻豆免费人成网站 | 蜜桃视频韩日免费播放 | 国产又爽又黄又刺激的视频 | 国产三级精品三级男人的天堂 | 成人精品一区二区三区中文字幕 | 国产精品久久久一区二区三区 | 少妇无码av无码专区在线观看 | 久久久久久久女国产乱让韩 | 乌克兰少妇xxxx做受 | 麻豆精产国品 | 男人扒开女人内裤强吻桶进去 | 领导边摸边吃奶边做爽在线观看 | 中文字幕av日韩精品一区二区 | 清纯唯美经典一区二区 | 东京热一精品无码av | 97精品国产97久久久久久免费 | 欧美亚洲国产一区二区三区 | 中文久久乱码一区二区 | 小泽玛莉亚一区二区视频在线 | 又大又紧又粉嫩18p少妇 | 性生交片免费无码看人 | 久久久久亚洲精品中文字幕 | 美女黄网站人色视频免费国产 | 国产精品久久精品三级 | 人人妻人人藻人人爽欧美一区 | 国内揄拍国内精品少妇国语 | 激情内射日本一区二区三区 | 好屌草这里只有精品 | 国产精品福利视频导航 | 中文字幕无码人妻少妇免费 | 99久久99久久免费精品蜜桃 | 国产精品无码永久免费888 | 精品久久久久久亚洲精品 | 日本精品久久久久中文字幕 | 亚洲s色大片在线观看 | 日本爽爽爽爽爽爽在线观看免 | 人妻中文无码久热丝袜 | 久久97精品久久久久久久不卡 | 色一情一乱一伦一区二区三欧美 | 久久精品成人欧美大片 | 日韩精品一区二区av在线 | 欧美自拍另类欧美综合图片区 | 综合人妻久久一区二区精品 | 最新国产乱人伦偷精品免费网站 | 亚洲国产午夜精品理论片 | 亚洲精品成人av在线 | 国产香蕉尹人综合在线观看 | 国产麻豆精品一区二区三区v视界 | 日本www一道久久久免费榴莲 | 中文字幕无码热在线视频 | 人人妻在人人 | 亚洲日韩av片在线观看 | 久久久久亚洲精品男人的天堂 | 狂野欧美激情性xxxx | 国产精品久久久久久亚洲毛片 | 高潮毛片无遮挡高清免费视频 | 亚洲人成影院在线无码按摩店 | 最新版天堂资源中文官网 | 久久精品丝袜高跟鞋 | 国色天香社区在线视频 | 人人妻人人澡人人爽欧美精品 | 51国偷自产一区二区三区 | 亚洲第一网站男人都懂 | 久久久久人妻一区精品色欧美 | 久久综合给合久久狠狠狠97色 | 人人妻人人藻人人爽欧美一区 | 中文字幕无线码 | 香蕉久久久久久av成人 | 国产av一区二区精品久久凹凸 | 中文字幕乱妇无码av在线 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | www国产亚洲精品久久久日本 | 久久综合九色综合97网 | 久久人人爽人人爽人人片ⅴ | 激情综合激情五月俺也去 | 人妻无码久久精品人妻 | 精品无码av一区二区三区 | 未满小14洗澡无码视频网站 | 麻豆md0077饥渴少妇 | 亚洲日本在线电影 | 国产精品久久国产精品99 | 国产深夜福利视频在线 | 亚洲熟悉妇女xxx妇女av | 人妻无码αv中文字幕久久琪琪布 | 国产69精品久久久久app下载 | 99久久精品午夜一区二区 | 999久久久国产精品消防器材 | 狠狠躁日日躁夜夜躁2020 | 国产特级毛片aaaaaaa高清 | 国产亚洲日韩欧美另类第八页 | 国产香蕉尹人综合在线观看 | 国产精品国产三级国产专播 | 国产艳妇av在线观看果冻传媒 | 日日鲁鲁鲁夜夜爽爽狠狠 | 人人爽人人澡人人人妻 | 天天摸天天透天天添 | 亚洲精品国产精品乱码不卡 | 精品成在人线av无码免费看 | 国产高清不卡无码视频 | 丝袜美腿亚洲一区二区 | 成人欧美一区二区三区 | 国产精品人妻一区二区三区四 | 无码乱肉视频免费大全合集 | 帮老师解开蕾丝奶罩吸乳网站 | 少妇高潮一区二区三区99 | 精品亚洲成av人在线观看 | 亚洲日韩一区二区三区 | 日本精品久久久久中文字幕 | 欧美人与牲动交xxxx | 丰满人妻被黑人猛烈进入 | 夜夜躁日日躁狠狠久久av | 国产精品第一国产精品 | 日韩欧美成人免费观看 | 久久精品女人天堂av免费观看 | 欧美老熟妇乱xxxxx | 中文字幕 人妻熟女 | 大胆欧美熟妇xx | 久久精品国产一区二区三区肥胖 | 国产精品久久久久久亚洲毛片 | 任你躁国产自任一区二区三区 | 人妻尝试又大又粗久久 | 精品欧洲av无码一区二区三区 | 奇米影视7777久久精品人人爽 | 国产黑色丝袜在线播放 | 夜夜高潮次次欢爽av女 | 亚洲天堂2017无码 | 装睡被陌生人摸出水好爽 | 亚洲色欲色欲欲www在线 | 成人影院yy111111在线观看 | 日韩人妻无码一区二区三区久久99 | 亚洲中文字幕无码中字 | 欧美怡红院免费全部视频 | 精品无码成人片一区二区98 | 98国产精品综合一区二区三区 | 国产亚洲精品久久久闺蜜 | 久久久国产精品无码免费专区 | 国产美女极度色诱视频www | 国产无遮挡又黄又爽又色 | 欧美日韩精品 | 国产极品视觉盛宴 | 鲁一鲁av2019在线 | 人妻少妇精品无码专区二区 | 久久综合给合久久狠狠狠97色 | 97资源共享在线视频 | 捆绑白丝粉色jk震动捧喷白浆 | 免费国产成人高清在线观看网站 | 在线欧美精品一区二区三区 | 亚洲精品成人av在线 | 亚洲娇小与黑人巨大交 | 久久久久国色av免费观看性色 | 亚洲精品中文字幕久久久久 | 精品久久8x国产免费观看 | 福利一区二区三区视频在线观看 | 亚洲熟悉妇女xxx妇女av | 日韩人妻无码中文字幕视频 | 国产人妻精品一区二区三区 | 国产精品人人妻人人爽 | 中文字幕av无码一区二区三区电影 | 国产av无码专区亚洲a∨毛片 | 青青草原综合久久大伊人精品 | 奇米影视7777久久精品人人爽 | 国产色精品久久人妻 | 久久视频在线观看精品 | 99国产欧美久久久精品 | 久久久精品456亚洲影院 | 一本无码人妻在中文字幕免费 | 中文字幕乱妇无码av在线 | 日韩亚洲欧美中文高清在线 | 国产内射爽爽大片视频社区在线 | 97精品人妻一区二区三区香蕉 | 亚洲一区二区三区四区 | 午夜精品久久久久久久 | 久久久婷婷五月亚洲97号色 | 正在播放东北夫妻内射 | 又大又紧又粉嫩18p少妇 | 国产精品久久久久9999小说 | 天天躁日日躁狠狠躁免费麻豆 | 国产亚洲精品久久久闺蜜 | 久久国产精品_国产精品 | 国产人妻精品一区二区三区 | 少妇久久久久久人妻无码 | 天堂在线观看www | 精品国产一区二区三区四区在线看 | 中文字幕无码免费久久99 | 中文字幕乱妇无码av在线 | 老熟女重囗味hdxx69 | 国产精品无码mv在线观看 | 国产乱人伦偷精品视频 | 波多野结衣aⅴ在线 | 久久国产精品二国产精品 | 亚洲综合伊人久久大杳蕉 | 欧美日韩色另类综合 | 最新国产麻豆aⅴ精品无码 | 秋霞成人午夜鲁丝一区二区三区 | 日韩精品一区二区av在线 | 国产成人综合色在线观看网站 | 乱码午夜-极国产极内射 | 一本久久a久久精品vr综合 | 国内精品久久久久久中文字幕 | 国产乱人伦偷精品视频 | 亚洲欧美中文字幕5发布 | 国产深夜福利视频在线 | 国产suv精品一区二区五 | 亚洲熟妇自偷自拍另类 | 欧美日韩在线亚洲综合国产人 | 理论片87福利理论电影 | 午夜无码区在线观看 | 一个人看的www免费视频在线观看 | 亚洲国产日韩a在线播放 | 欧洲精品码一区二区三区免费看 | 色综合视频一区二区三区 | 日本熟妇浓毛 | 亚洲啪av永久无码精品放毛片 | 爆乳一区二区三区无码 | 中文字幕日产无线码一区 | 久久精品99久久香蕉国产色戒 | 国产xxx69麻豆国语对白 | 少妇邻居内射在线 | 狠狠cao日日穞夜夜穞av | 性生交片免费无码看人 | 国产精品亚洲а∨无码播放麻豆 | 国产偷抇久久精品a片69 | 99久久婷婷国产综合精品青草免费 | 亚洲国产成人a精品不卡在线 | 性色欲网站人妻丰满中文久久不卡 | 色爱情人网站 | 欧美日本免费一区二区三区 | 精品人妻人人做人人爽夜夜爽 | 中文字幕人妻无码一区二区三区 | 天堂久久天堂av色综合 | 久久zyz资源站无码中文动漫 | 亚洲国产精品久久久天堂 | 男女猛烈xx00免费视频试看 | 牲欲强的熟妇农村老妇女 | 成人免费无码大片a毛片 | 99精品无人区乱码1区2区3区 | 亚洲第一无码av无码专区 | 久久99精品久久久久久 | 四十如虎的丰满熟妇啪啪 | 欧美日韩色另类综合 | 国产亚洲人成在线播放 | 亚洲第一无码av无码专区 | 色诱久久久久综合网ywww | 无码av中文字幕免费放 | 亚洲男人av天堂午夜在 | 精品无码国产一区二区三区av | 精品少妇爆乳无码av无码专区 | 乱中年女人伦av三区 | 国产婷婷色一区二区三区在线 | 成人免费视频视频在线观看 免费 | 亚洲国精产品一二二线 | 欧美35页视频在线观看 | 国内精品一区二区三区不卡 | 久久国内精品自在自线 | 人妻有码中文字幕在线 | 97夜夜澡人人爽人人喊中国片 | 日产国产精品亚洲系列 | 扒开双腿疯狂进出爽爽爽视频 | 在线观看欧美一区二区三区 | 亚洲aⅴ无码成人网站国产app | 国产精品.xx视频.xxtv | 扒开双腿疯狂进出爽爽爽视频 | 欧美喷潮久久久xxxxx | 亚洲欧美精品伊人久久 | 亚洲人亚洲人成电影网站色 | 亚洲乱码日产精品bd | 亚洲男女内射在线播放 | 亚洲中文无码av永久不收费 | 国产av久久久久精东av | 成人一区二区免费视频 | 久久久精品成人免费观看 | 亚洲国产精品毛片av不卡在线 | 国产精品无码mv在线观看 | 亚洲欧美综合区丁香五月小说 | 2019nv天堂香蕉在线观看 | 内射后入在线观看一区 | 牲欲强的熟妇农村老妇女视频 | 国产sm调教视频在线观看 | 嫩b人妻精品一区二区三区 | 香蕉久久久久久av成人 | 亚洲日韩一区二区 | 55夜色66夜色国产精品视频 | 欧美第一黄网免费网站 | 国产两女互慰高潮视频在线观看 | 性欧美疯狂xxxxbbbb | 中文字幕精品av一区二区五区 | 亚洲高清偷拍一区二区三区 | 麻豆精品国产精华精华液好用吗 | 日韩人妻少妇一区二区三区 | 久久精品无码一区二区三区 | 狠狠躁日日躁夜夜躁2020 | 久久久久久久人妻无码中文字幕爆 | 蜜桃视频韩日免费播放 | 国产午夜亚洲精品不卡 | 性欧美大战久久久久久久 | 日本护士毛茸茸高潮 | 国产成人精品必看 | 中文字幕人妻无码一夲道 | 无码国产激情在线观看 | 欧美成人免费全部网站 | 性生交片免费无码看人 | 久久久久久国产精品无码下载 | aa片在线观看视频在线播放 | 99久久久国产精品无码免费 | 精品国产乱码久久久久乱码 | 欧美成人午夜精品久久久 | 无码av岛国片在线播放 | 精品成在人线av无码免费看 | 日本大香伊一区二区三区 | 亚洲阿v天堂在线 | 亚洲 a v无 码免 费 成 人 a v | 日韩av无码一区二区三区不卡 | 丰满少妇女裸体bbw | 久久久久成人精品免费播放动漫 | 蜜桃av抽搐高潮一区二区 | 国产精品美女久久久久av爽李琼 | v一区无码内射国产 | 在线а√天堂中文官网 | 亚洲经典千人经典日产 | 少妇高潮一区二区三区99 | 欧美日韩精品 | 日韩精品a片一区二区三区妖精 | 2020最新国产自产精品 | 日韩欧美成人免费观看 | 精品久久久久久亚洲精品 | 天堂а√在线地址中文在线 | 国产激情一区二区三区 | 台湾无码一区二区 | 无码免费一区二区三区 | 亚洲无人区午夜福利码高清完整版 | 麻豆精品国产精华精华液好用吗 | 亚洲成a人片在线观看无码3d | 无遮挡啪啪摇乳动态图 | 欧美性色19p | 草草网站影院白丝内射 | 老司机亚洲精品影院 | 亚洲熟妇色xxxxx欧美老妇 | 亚洲欧美精品aaaaaa片 | 激情五月综合色婷婷一区二区 | 久久亚洲日韩精品一区二区三区 | 双乳奶水饱满少妇呻吟 | 免费无码av一区二区 | 久久国产精品萌白酱免费 | 人妻少妇精品久久 | 人人妻人人澡人人爽欧美精品 | 少妇性荡欲午夜性开放视频剧场 | 宝宝好涨水快流出来免费视频 | 国产精品资源一区二区 | 国产猛烈高潮尖叫视频免费 | 久久精品国产日本波多野结衣 | 亚洲天堂2017无码中文 | 色一情一乱一伦 | 国产精品内射视频免费 | 久久精品国产99久久6动漫 | 强辱丰满人妻hd中文字幕 | 精品国产一区av天美传媒 | 亚洲综合另类小说色区 | 熟妇激情内射com | 欧美放荡的少妇 | 亚洲综合精品香蕉久久网 | a片免费视频在线观看 | 小泽玛莉亚一区二区视频在线 | 粉嫩少妇内射浓精videos | 国产精品内射视频免费 | 国产农村妇女高潮大叫 | 免费看男女做好爽好硬视频 | 内射欧美老妇wbb | 免费人成网站视频在线观看 | 色欲人妻aaaaaaa无码 | 国产激情无码一区二区 | 亚洲色欲色欲欲www在线 | 色噜噜亚洲男人的天堂 | 无码中文字幕色专区 | 日韩在线不卡免费视频一区 | 午夜性刺激在线视频免费 | 欧美三级a做爰在线观看 | 免费无码肉片在线观看 | 国产亚洲精品久久久久久大师 | 欧美 日韩 亚洲 在线 | 久久成人a毛片免费观看网站 | 曰韩少妇内射免费播放 | 在线欧美精品一区二区三区 | 天海翼激烈高潮到腰振不止 | 亚洲国产精品成人久久蜜臀 | 狠狠色色综合网站 | 丝袜足控一区二区三区 | 午夜福利试看120秒体验区 | 国产偷国产偷精品高清尤物 | 色爱情人网站 | 国产乱子伦视频在线播放 | 狠狠色丁香久久婷婷综合五月 | 中文字幕乱码中文乱码51精品 | 在线观看国产一区二区三区 | 婷婷五月综合缴情在线视频 | 嫩b人妻精品一区二区三区 | 午夜无码人妻av大片色欲 | 99视频精品全部免费免费观看 | 国产极品视觉盛宴 | 捆绑白丝粉色jk震动捧喷白浆 | 性欧美videos高清精品 | 日本又色又爽又黄的a片18禁 | 精品成在人线av无码免费看 | 中文亚洲成a人片在线观看 | 曰本女人与公拘交酡免费视频 | 熟女俱乐部五十路六十路av | 人妻少妇精品无码专区动漫 | 内射爽无广熟女亚洲 | 国产麻豆精品精东影业av网站 | 免费人成在线观看网站 | 国产精品99爱免费视频 | 欧美怡红院免费全部视频 | 久久精品中文闷骚内射 | 99久久精品日本一区二区免费 | 国产偷国产偷精品高清尤物 | 国内精品九九久久久精品 | 欧美激情一区二区三区成人 | 欧美freesex黑人又粗又大 | 亚洲小说图区综合在线 | 日日碰狠狠丁香久燥 | 天天av天天av天天透 | 在线精品亚洲一区二区 | 精品国产一区二区三区四区在线看 | 国产色在线 | 国产 | 妺妺窝人体色www在线小说 | 久久久久久久久蜜桃 | 国产口爆吞精在线视频 | 天堂亚洲免费视频 | 任你躁在线精品免费 | 永久黄网站色视频免费直播 | 国产午夜无码精品免费看 | 特黄特色大片免费播放器图片 | 欧美变态另类xxxx | 全黄性性激高免费视频 | 精品乱码久久久久久久 | 亚洲国产综合无码一区 | 国产亚洲精品久久久久久久久动漫 | 亚洲国产成人av在线观看 | 亚洲男人av天堂午夜在 | 两性色午夜免费视频 | 又大又黄又粗又爽的免费视频 | 美女毛片一区二区三区四区 | 亚洲欧美精品aaaaaa片 | 国产精品无码一区二区桃花视频 | 99精品国产综合久久久久五月天 | 日产精品高潮呻吟av久久 | 99在线 | 亚洲 | 日本肉体xxxx裸交 | 国产人妻精品一区二区三区不卡 | 精品一区二区三区波多野结衣 | 18禁止看的免费污网站 | 荫蒂被男人添的好舒服爽免费视频 | 日韩av无码一区二区三区 | 欧美三级不卡在线观看 | av无码久久久久不卡免费网站 | 天天做天天爱天天爽综合网 | 四虎影视成人永久免费观看视频 | 熟妇女人妻丰满少妇中文字幕 | 久久精品无码一区二区三区 | 精品一区二区三区无码免费视频 | 免费观看激色视频网站 | 久久精品国产精品国产精品污 | 青春草在线视频免费观看 | 性欧美熟妇videofreesex | 少妇一晚三次一区二区三区 | 免费播放一区二区三区 | 国产国产精品人在线视 | 小sao货水好多真紧h无码视频 | 久久久婷婷五月亚洲97号色 | 国产欧美精品一区二区三区 | 国产片av国语在线观看 | 国产欧美精品一区二区三区 | 国产成人精品无码播放 | 巨爆乳无码视频在线观看 | 2019nv天堂香蕉在线观看 | 77777熟女视频在线观看 а天堂中文在线官网 | 久久国语露脸国产精品电影 | 免费无码的av片在线观看 | 亚洲а∨天堂久久精品2021 | 亚洲码国产精品高潮在线 | 国产亚洲欧美日韩亚洲中文色 | 亚洲成av人影院在线观看 | 欧美日韩在线亚洲综合国产人 | 初尝人妻少妇中文字幕 | aa片在线观看视频在线播放 | 国产精品第一区揄拍无码 | 国产精品久久久久久亚洲影视内衣 | 国产精品久久久久久亚洲影视内衣 | 在线播放无码字幕亚洲 | 日本一区二区三区免费播放 | 国产一区二区三区精品视频 | 日日橹狠狠爱欧美视频 | 亚洲码国产精品高潮在线 | 少妇高潮喷潮久久久影院 | 国产人成高清在线视频99最全资源 | 老熟女乱子伦 | 青春草在线视频免费观看 | 装睡被陌生人摸出水好爽 | 欧美日韩综合一区二区三区 | 97久久国产亚洲精品超碰热 | 老太婆性杂交欧美肥老太 | 欧美喷潮久久久xxxxx | 丝袜人妻一区二区三区 | 纯爱无遮挡h肉动漫在线播放 | a片免费视频在线观看 | 中文字幕无码av波多野吉衣 | 亚洲娇小与黑人巨大交 | 三级4级全黄60分钟 | 亚洲va中文字幕无码久久不卡 | 欧美日韩视频无码一区二区三 | 久久无码专区国产精品s | 无遮挡啪啪摇乳动态图 | 女人被爽到呻吟gif动态图视看 | 久久精品人妻少妇一区二区三区 | 国产办公室秘书无码精品99 | 精品国精品国产自在久国产87 | 日日麻批免费40分钟无码 | 色综合久久88色综合天天 | 一本久久a久久精品vr综合 | 亚洲中文字幕乱码av波多ji | 国产色xx群视频射精 | 久久精品人人做人人综合试看 | 亚洲精品中文字幕 | 中国女人内谢69xxxxxa片 | 乱人伦人妻中文字幕无码久久网 | 无码毛片视频一区二区本码 | 国产精品办公室沙发 | 亚洲中文字幕av在天堂 | 精品久久综合1区2区3区激情 | 亚洲综合在线一区二区三区 | 国产午夜福利100集发布 | 无遮挡国产高潮视频免费观看 | 久久亚洲国产成人精品性色 | 好爽又高潮了毛片免费下载 | 亚洲成a人片在线观看日本 | 亚洲七七久久桃花影院 | 99精品无人区乱码1区2区3区 | 国产激情无码一区二区app | 少妇高潮喷潮久久久影院 | 中文字幕 人妻熟女 | 中文亚洲成a人片在线观看 | 99精品国产综合久久久久五月天 | 少妇高潮一区二区三区99 | 欧美一区二区三区视频在线观看 | 国产熟女一区二区三区四区五区 | 精品无码国产一区二区三区av | 国产午夜福利亚洲第一 | 久久久国产精品无码免费专区 | 内射后入在线观看一区 | 亚洲大尺度无码无码专区 | 精品国产国产综合精品 | 亚洲一区二区三区无码久久 | 无码成人精品区在线观看 | 久久综合久久自在自线精品自 | 国产乱码精品一品二品 | 国产精品国产三级国产专播 | 亚洲热妇无码av在线播放 | 亚洲欧洲日本综合aⅴ在线 | 天天摸天天透天天添 | 美女极度色诱视频国产 |