日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

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

编程问答

在美团呆了7年的架构师带你解读Disruptor系列并发框架

發布時間:2024/1/18 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 在美团呆了7年的架构师带你解读Disruptor系列并发框架 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

前言

理解Disruptor的最佳方式是,將其與一些容易理解和目的相似的東西比較。這里的參照物就是java里的阻塞隊列(BlockingQueue)。

與BlockingQueue的異同:
同:目的相同,都是為了在同一進程的線程間傳輸數據。
異:對消費者多播事件;預分配事件內存;可選無鎖。

核心概念

  • Ring Buffer : 曾經的核心。自從3.0以上,環形緩沖器只作為Disruptor存儲和更新數據(事件)的容器。對于一些高級用法,可以完全替換為用戶提供的容器。
  • Sequence:Disruptor使用Sequence作為一種確定特定組件位置的方法。每個消費者(EventProcessor)都維護一個Sequence,Disruptor自己也是一樣。大部分并發代碼以來這些Sequence值的移動,因此Sequence支持AtomicLong的當前許多特性。事實上,兩者唯一的區別是Sequence包含了附加功能來防止Sequence和其他值的偽共享。
  • Sequencer:Disruptor的真正核心。此接口的兩個實現(單生產者和多生產者)都實現了用于在生產者和消費者間快速準確傳遞數據的并發算法。
  • Sequence Barrier:由Sequencer產生,持有Sequencer的主要發布Sequence和任意獨立消費者的Sequence的索引。它包含判斷是否有可供消費者處理的可用事件的邏輯。
  • Wait Strategy:等待策略決定了一個消費者如何等待生產者發布到Disruptor的事件。
  • Event:生產者傳遞給消費者的數據單元。用戶自定義。
  • EventProcessor:處理Disruptor事件的主要循環,擁有消費者的Sequence。有一個BatchEventProcessor包含了一個事件循環的高效實現,會在事件可用時回調用戶提供的EventHandler接口實現。
  • EventHandler:用戶實現接口,代表Disruptor的一個消費者。
  • Producer:用戶調用Disruptor進行入隊的代碼。在框架中沒有代碼表示。

多播事件

這是queue和Disruptor最大的行為區別。隊列中的一個事件只能被一個消費者消費,而Disruptor中的時間會發布給所有消費者。這是由于Disruptor意圖處理同一數據的獨立并行處理操作(譯注:類似JMS的topic模式)。比如LMAX中同一數據需要進行記錄日志、復制和業務邏輯操作。當然,在Disruptor中同時并行處理不同事件可以使用WorkerPool(譯注:類似JMS的queue模式中的多消費者實現)。但需要注意的是,由于這種特性并非是Disruptor的首要工作,所以使用WorkerPool可能并不是最高效的做法。
查看上圖,三個消費者JournalConsumer、ReplicationConsumer和ApplicationConsumer將會以相同順序接收Disruptor所有可用消息。這實現了這些消費者的并行工作。

消費者依賴圖

為了支持并發處理的真實世界應用,很有必要支持消費者間的協調工作。回顧上圖,在日志記錄和復制消費者完成工作前,有必要阻止業務邏輯消費者的進一步工作。我們稱這個概念為gating,更準確的說是這種行為的超集稱為gating。Gating發生在兩個地方:第一用來保證生產者不能超過消費者。這通過調用RingBuffer.addGatingConsumers()把相關消費者添加到Disruptor實現。第二,先前提到的情況是通過從必須首先完成其處理的組件構造包含序列的SequenceBarrier來實現的。
回顧圖1,有三個消費者監聽RingBuffer的事件。在這個例子中,有一個依賴圖。ApplicationConsumer依賴JournalConsumer和ReplicationConsumer。這意味著JournalConsumer和ReplicationConsumer可以相互并行運行。依賴關系可以從ApplicationConsumer的SequenceBarrier和JournalConsumer及ReplicationConsumer的Sequence觀察到。同時引起注意的是Sequencer和下游消費者的關系。它的一個角色是保證發布不會環繞RingBuffer。為了做到這點,下游消費者的Sequence不能小于RingBuffer的Sequence。然而,使用依賴圖會發生一個有趣的優化。由于ApplicationConsumer Sequence保證小于等于JournalConsumer和ReplicationConsumer(由依賴關系保證),Sequencer只需要觀察ApplicationConsumer的Sequence。從廣義上來說,Sequencer只需要關注依賴樹種葉子節點的消費者Sequence。

事件預分配

Disruptor的一個目標是可以用于低延遲環境中。在低延遲系統中,有必要減少或消除內存分配。在Java系統中,目標是減少由于垃圾回收造成的停頓次數(在低延遲的C/C++系統中,重內存分配會由于內存分配器的征用也可能導致問題)。
為了支持這個目標,用戶可以預分配Disruptor中事件的存儲。用戶提供的EventFactory會在Disruptor中RingBuffer每個條目構建時調用。當發布新數據到Disruptor時,有API供用戶調用來持有構建出的對象,這樣可以調用對象的方法或更新對象屬性。在正確實現下,Disruptor保證這些操作操作是并發安全的。

可選的無鎖

對低延遲的渴望造就的另一個實現細節是無鎖算法在Disruptor中的大量使用。所有內存可見性和正確性保證使用內存屏障和/或CAS操作實現。真正使用鎖的場景只有一個,那就是使用BlockingWatiStrategy。這樣做只為了使用Condition讓消費線程可以在等待新事件到達前進行park操作。許多低延遲系統使用忙等待(busy-wait)來避免使用Condition可能導致的抖動,然而一些系統的忙等待操作會導致性能的急劇下降,尤其是CPU資源被嚴重制約時。比方說在虛擬環境下的web服務器。

入門指南

基本的事件生產和消費

從簡單的事件開始:

public class LongEvent {private long value;public void set(long value){this.value = value;} }

為了讓Disruptor能夠預分配事件,我們需要提供一個EventFactory完成構建:

import com.lmax.disruptor.EventFactory;public class LongEventFactory implements EventFactory<LongEvent> {public LongEvent newInstance(){return new LongEvent();} }

事件定義好后,需要創建消費者處理這些事件。這里只做簡單的打印:

import com.lmax.disruptor.EventHandler;public class LongEventHandler implements EventHandler<LongEvent> {public void onEvent(LongEvent event, long sequence, boolean endOfBatch){System.out.println("Event: " + event);} }

我們還需要一個事件的生產源,舉個例子,假定數據是來自某種I/O設備,如網絡或文件的字節緩沖(ByteBuffer)。

import com.lmax.disruptor.RingBuffer;public class LongEventProducer {private final RingBuffer<LongEvent> ringBuffer;public LongEventProducer(RingBuffer<LongEvent> ringBuffer){this.ringBuffer = ringBuffer;}public void onData(ByteBuffer bb){long sequence = ringBuffer.next(); // Grab the next sequencetry{LongEvent event = ringBuffer.get(sequence); // Get the entry in the Disruptor// for the sequenceevent.set(bb.getLong(0)); // Fill with data}finally{ringBuffer.publish(sequence);}} }

可以發現,相比使用簡單的queue,事件的發布更具有相關性。這是由于需要事件預分配。事件發布需要(最低)2階段方式,先聲明環形緩沖器中的槽位,再發布可用數據。同時也需要把發布過程使用try/finally塊包裹起來。如果聲明了環形緩沖的一個槽位(通過調用RingBuffer.next())然后必須發布這個序列。如果沒有這么做,會導致Disruptor的狀態損壞(corruption)。特別地,在多生產者的情況下,這將會導致消費者阻塞,只能通過重啟解決。

使用3.x版本的Translator

Disruptor3.0提供了一種富Lambda風格的API,旨在幫助開發者屏蔽直接操作RingBuffer的復雜性,所以3.0以上版本發布消息更好的辦法是通過事件發布者(Event Publisher)或事件翻譯器(Event Translator)API。如下

import com.lmax.disruptor.RingBuffer; import com.lmax.disruptor.EventTranslatorOneArg;public class LongEventProducerWithTranslator {private final RingBuffer<LongEvent> ringBuffer;public LongEventProducerWithTranslator(RingBuffer<LongEvent> ringBuffer){this.ringBuffer = ringBuffer;}private static final EventTranslatorOneArg<LongEvent, ByteBuffer> TRANSLATOR =new EventTranslatorOneArg<LongEvent, ByteBuffer>(){public void translateTo(LongEvent event, long sequence, ByteBuffer bb){event.set(bb.getLong(0));}};public void onData(ByteBuffer bb){ringBuffer.publishEvent(TRANSLATOR, bb);} }

這種方法另一個好處是翻譯器代碼可以放到一個單獨的類中,以便于更容易進行單元測試。Disruptor提供了一些用于翻譯器的不同的接口(EventTranslator,EventTranslatorOneArg,EventTranslatorTwoArg,等)。這樣做的原因是,允許翻譯器表示為靜態類,或以非捕獲lambda表達式(使用java8時)作為翻譯方法參數,通過調用RingBuffer上的翻譯器進行傳遞。
最后一步是把上面這些步驟統一到一起。可以手工把這些組件都組裝到一起,但還是有點復雜,所以引入了DSL來簡化構建。盡管通過DSL的方式不能使用有些復雜選項,但這種方式還是適合絕大多數場景。

import com.lmax.disruptor.dsl.Disruptor; import com.lmax.disruptor.RingBuffer; import java.nio.ByteBuffer; import java.util.concurrent.Executor; import java.util.concurrent.Executors;public class LongEventMain {public static void main(String[] args) throws Exception{// Executor that will be used to construct new threads for consumersExecutor executor = Executors.newCachedThreadPool();// The factory for the eventLongEventFactory factory = new LongEventFactory();// Specify the size of the ring buffer, must be power of 2.int bufferSize = 1024;// Construct the DisruptorDisruptor<LongEvent> disruptor = new Disruptor<>(factory, bufferSize, executor);// Connect the handlerdisruptor.handleEventsWith(new LongEventHandler());// Start the Disruptor, starts all threads runningdisruptor.start();// Get the ring buffer from the Disruptor to be used for publishing.RingBuffer<LongEvent> ringBuffer = disruptor.getRingBuffer();LongEventProducer producer = new LongEventProducer(ringBuffer);ByteBuffer bb = ByteBuffer.allocate(8);for (long l = 0; true; l++){bb.putLong(0, l);producer.onData(bb);Thread.sleep(1000);}} }

使用Java8

Disruptor API的設計影響之一是Java 8將依靠功能接口的概念作為Java Lambdas的類型聲明。 Disruptor API中的大多數接口定義符合功能接口的要求,因此可以使用Lambda而不是自定義類,這樣可以減少所需的重復代碼(boiler place)。

import com.lmax.disruptor.dsl.Disruptor; import com.lmax.disruptor.RingBuffer; import java.nio.ByteBuffer; import java.util.concurrent.Executor; import java.util.concurrent.Executors;public class LongEventMain {public static void main(String[] args) throws Exception{// Executor that will be used to construct new threads for consumersExecutor executor = Executors.newCachedThreadPool();// Specify the size of the ring buffer, must be power of 2.int bufferSize = 1024;// Construct the DisruptorDisruptor<LongEvent> disruptor = new Disruptor<>(LongEvent::new, bufferSize, executor);// Connect the handlerdisruptor.handleEventsWith((event, sequence, endOfBatch) -> System.out.println("Event: " + event));// Start the Disruptor, starts all threads runningdisruptor.start();// Get the ring buffer from the Disruptor to be used for publishing.RingBuffer<LongEvent> ringBuffer = disruptor.getRingBuffer();ByteBuffer bb = ByteBuffer.allocate(8);for (long l = 0; true; l++){bb.putLong(0, l);ringBuffer.publishEvent((event, sequence, buffer) -> event.set(buffer.getLong(0)), bb);Thread.sleep(1000);}} }

注意有一些類(如handler,translator)不再需要了。還要注意用于publishEvent()的lambda是如何引用傳入的參數的。如果使用如下代碼代替:

ByteBuffer bb = ByteBuffer.allocate(8); for (long l = 0; true; l++) {bb.putLong(0, l);ringBuffer.publishEvent((event, sequence) -> event.set(bb.getLong(0)));Thread.sleep(1000); }

這會創建一個capturing lambda,意味著需要實例化一個對象來持有ByteBuffer bb變量,通過調用publishEvent()來傳遞lambda。這樣會創建額外不必須的垃圾,所以如果需要低GC壓力就需要傳遞參數給lambda。
使用這種方法引用可以代替匿名的lamdba,以這種方式重寫這個例子是可能的。

import com.lmax.disruptor.dsl.Disruptor; import com.lmax.disruptor.RingBuffer; import java.nio.ByteBuffer; import java.util.concurrent.Executor; import java.util.concurrent.Executors;public class LongEventMain {public static void handleEvent(LongEvent event, long sequence, boolean endOfBatch){System.out.println(event);}public static void translate(LongEvent event, long sequence, ByteBuffer buffer){event.set(buffer.getLong(0));}public static void main(String[] args) throws Exception{// Executor that will be used to construct new threads for consumersExecutor executor = Executors.newCachedThreadPool();// Specify the size of the ring buffer, must be power of 2.int bufferSize = 1024;// Construct the DisruptorDisruptor<LongEvent> disruptor = new Disruptor<>(LongEvent::new, bufferSize, executor);// Connect the handlerdisruptor.handleEventsWith(LongEventMain::handleEvent);// Start the Disruptor, starts all threads runningdisruptor.start();// Get the ring buffer from the Disruptor to be used for publishing.RingBuffer<LongEvent> ringBuffer = disruptor.getRingBuffer();ByteBuffer bb = ByteBuffer.allocate(8);for (long l = 0; true; l++){bb.putLong(0, l);ringBuffer.publishEvent(LongEventMain::translate, bb);Thread.sleep(1000);}} }

基本調優選項

使用上述的方法可以在最廣泛的部署場景中工作正常。然而,如果你能夠確定Disruptor將要運行的硬件和軟件環境,就可以調整參數提升性能。主要有以下兩種調優方式:單vs.多生產者和替換等待策略。

單vs.多生產者

提高并發系統性能的最佳方法之一就是遵守單作者原則(Single Writer Principle https://mechanical-sympathy.blogspot.tw/2011/09/single-writer-principle.html,這適用于Disruptor。如果你的情況是只有一個線程會在Disruptor中發布事件,那就可以利用此功能獲得額外的性能提升。

public class LongEventMain {public static void main(String[] args) throws Exception{//.....// Construct the Disruptor with a SingleProducerSequencerDisruptor<LongEvent> disruptor = new Disruptor(factory, bufferSize, ProducerType.SINGLE, new BlockingWaitStrategy(), executor);//.....} }

OneToOne 性能測試(https://github.com/LMAX-Exchange/disruptor/blob/master/src/perftest/java/com/lmax/disruptor/sequenced/OneToOneSequencedThroughputTest.java)可以說明這種技術能夠提升多少性能。以下測試使用i7 Sandy Bridge MacBook Air。
多生產者

Run 0, Disruptor=26,553,372 ops/sec
Run 1, Disruptor=28,727,377 ops/sec
Run 2, Disruptor=29,806,259 ops/sec
Run 3, Disruptor=29,717,682 ops/sec
Run 4, Disruptor=28,818,443 ops/sec
Run 5, Disruptor=29,103,608 ops/sec
Run 6, Disruptor=29,239,766 ops/sec

單生產者

Run 0, Disruptor=89,365,504 ops/sec
Run 1, Disruptor=77,579,519 ops/sec
Run 2, Disruptor=78,678,206 ops/sec
Run 3, Disruptor=80,840,743 ops/sec
Run 4, Disruptor=81,037,277 ops/sec
Run 5, Disruptor=81,168,831 ops/sec
Run 6, Disruptor=81,699,346 ops/sec

替換等待策略

BlockingWaitStategy

Disruptor默認的等待策略是BlockingWaitStategy。在BlockingWaitStategy內部使用一個典型的鎖和條件(a typical lock and condition)變量處理線程喚醒。BlockingWaitStategy是可用等待策略中最慢的,但也是在CPU使用上最保守的,同時也將在最廣泛的部署選項中提供最一致的行為。然而,再說一次,了解部署系統可以獲得額外的性能提升。

SleepingWaitStrategy

類似BlockingWaitStategy,SleepingWaitStrategy也試圖在CPU使用上保持保守,這通過一個忙等待(busy wait loop)循環實現,但在循環中間會調用LockSupport.parkNanos(1)。在一個典型的Linux系統,這樣會暫停線程大概60μs(譯注1μs=1000ns)。但它的好處是生產者線程除了增加響應的計數器外,不需要采取任何行動,而且不需要給條件變量發信號的成本(cost of signalling a condition variable)。然而,生產者和消費者轉移事件的平均延遲會增加。這種方式最好工作在不需要低延遲,但對生產者線程影響最小的情況下。一個常見的使用場景是異步日志。

YieldingWaitStrategy

可用于低延遲系統的兩種等待策略其中之一,這種策略通過消耗CPU時鐘周期來達到優化延遲的目的。這種策略使用忙循環(busy spin)等待正確的序號到達。在循環內部,Thread.yield()將被調用,來允許其他排隊中的線程運行。當需要很高的性能,而且事件處理者EventHandler的線程數少于CPU邏輯核心數時(比如使用超線程時),推薦使用這種策略。

BusySpinWaitStrategy

這種策略有最高的性能,但也有最高的部署邊境限制。這種等待策略應該只用于事件處理者線程小于CPU物理核心數。

清除環形緩沖的對象

使用Disruptor傳輸數據時,對象的存活周期有可能比預期更長。為了避免發生這種情況,有必要在事件處理完畢后做清理。如果有一個事件處理器,在這個事件處理器中做清理就足夠了。如果有一個事件處理鏈,那就可能會在鏈尾需要一個特定的處理器來清理這個對象。

class ObjectEvent<T> {T val;void clear(){val = null;} }public class ClearingEventHandler<T> implements EventHandler<ObjectEvent<T>> {public void onEvent(ObjectEvent<T> event, long sequence, boolean endOfBatch){// Failing to call clear here will result in the// object associated with the event to live until// it is overwritten once the ring buffer has wrapped// around to the beginning.event.clear();} }public static void main(String[] args) {Disruptor<ObjectEvent<String>> disruptor = new Disruptor<>(() -> ObjectEvent<String>(), bufferSize, executor);disruptor.handleEventsWith(new ProcessingEventHandler()).then(new ClearingObjectHandler()); }

總結

以上是生活随笔為你收集整理的在美团呆了7年的架构师带你解读Disruptor系列并发框架的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

97在线观 | 国产精品成人一区二区 | 天天躁日日躁狠狠躁av中文 | 精品国产成人 | 国产精美视频 | 欧美成年人在线视频 | 中文字幕麻豆 | 日本中文字幕在线电影 | a视频免费 | 亚洲视频在线观看网站 | 激情综合五月天 | av久久久久久 | 久久手机看片 | 免费视频黄色 | av电影在线免费 | 欧美日韩精品二区第二页 | 在线观av | 日韩黄色中文字幕 | 日韩大片在线免费观看 | 国产乱码精品一区二区三区介绍 | 久久午夜电影网 | 日韩精品大片 | 最新国产在线视频 | 亚洲精品在线一区二区三区 | 免费观看www视频 | 高清不卡一区二区在线 | 欧美天天综合网 | 国产福利91精品一区二区三区 | 久久国产精品99久久久久久进口 | 午夜.dj高清免费观看视频 | 天天天插 | 国产精品24小时在线观看 | 久久热首页| 天天射天天操天天色 | 91日本在线播放 | 最近中文字幕完整视频高清1 | 天堂av在线免费 | 色视频在线看 | 国内精品久久久久久久 | 91av视频在线观看 | 国产 日韩 欧美 自拍 | 999久久久久久久久6666 | 亚洲视频 在线观看 | 日韩黄色一级电影 | 色婷五月| av在线一二三区 | 午夜国产福利在线 | 久热电影 | 欧美性天天 | 热久精品| 国产专区视频在线观看 | 又紧又大又爽精品一区二区 | 国产免费三级在线观看 | 综合色在线观看 | 四虎4hu永久免费 | 手机看片99| 欧美精品免费一区二区 | 人人澡超碰碰97碰碰碰软件 | 西西人体4444www高清视频 | 中文字幕在线观看第一页 | 国产精品免费不卡 | 成人午夜电影免费在线观看 | 日韩免费视频 | 中文在线天堂资源 | 国产99久久精品一区二区300 | 超碰免费公开 | www.888.av | 91精品欧美一区二区三区 | 久久久久亚洲国产精品 | 亚洲va欧美| 波多野结衣久久资源 | 国产中文字幕一区二区三区 | 最新日韩在线观看 | 在线观看日本高清mv视频 | 狠狠色狠狠色 | 97视频人人澡人人爽 | 狠狠激情中文字幕 | 久久精品3 | 日韩在线视频精品 | 中文一区二区三区在线观看 | 久久曰视频 | 六月婷婷久香在线视频 | 国产精品一区二区电影 | 香蕉视频一级 | 一级大片在线观看 | 欧美国产精品久久久久久免费 | 在线视频欧美日韩 | 久久国产精品一二三区 | av在线免费播放网站 | 精品五月天 | 中文字幕av电影下载 | 中文av网 | 91porny九色91啦中文 | 国产精品久久久久久久久久99 | www.天天色| 午夜影院三级 | av成年人电影 | 奇米网777| 美州a亚洲一视本频v色道 | 久久久夜色 | 婷婷5月激情5月 | 国产精品乱码久久久 | 亚洲视频精选 | 天天干,天天射,天天操,天天摸 | 久久国产精品99久久久久久老狼 | 综合国产在线 | 国产免费又粗又猛又爽 | 97热久久免费频精品99 | 亚洲综合成人婷婷小说 | 蜜臀av夜夜澡人人爽人人 | 亚洲一区尤物 | 国产精品一区二区在线播放 | 911久久 | 久久香蕉国产精品麻豆粉嫩av | 久久黄网站 | 福利视频午夜 | 欧美91在线| 久久爱www.| 亚洲精品国精品久久99热一 | 精品三级av | 亚洲免费av片 | 久久久国产一区二区三区 | 人人射人人爱 | 少妇bbw撒尿| 三级视频日韩 | 亚洲最大免费成人网 | 夜夜骑日日 | 亚洲一区欧美精品 | 蜜臀av性久久久久蜜臀aⅴ流畅 | 91精品一区二区三区蜜臀 | 天天干人人干 | 在线观看亚洲电影 | 中文字幕综合在线 | 日韩精品观看 | 久久不射影院 | 麻豆视频免费 | 久久婷婷一区二区三区 | 国产黄免费在线观看 | 久草免费在线 | 美女视频黄免费网站 | 日韩视频一区二区三区在线播放免费观看 | 国内精品久久久久影院一蜜桃 | 成x99人av在线www | 日韩成人免费观看 | 亚洲日本va中文字幕 | 欧美久久久久久久久久 | 国产在线视频一区 | av短片在线观看 | 精品一区二区久久久久久久网站 | 成人免费在线视频 | 亚洲va在线va天堂va偷拍 | 国产福利不卡视频 | 国产精品乱码久久久 | 天天做天天爱天天爽综合网 | 人人干人人艹 | 日本精品中文字幕在线观看 | 日韩在线观看 | 亚洲精品乱码久久久久久蜜桃欧美 | 亚洲精品午夜久久久 | 免费av片在线 | 中文字幕一区二区三区四区视频 | 亚洲精品自在在线观看 | www99久久 | 97在线观看免费观看高清 | 亚洲va天堂va欧美ⅴa在线 | 91看片在线观看 | 日日夜夜av| 国产高清免费在线观看 | 伊人狠狠色 | 插婷婷 | 久久伊人免费视频 | 日日爽| av黄色成人 | 精品999在线观看 | 区一区二区三在线观看 | 日韩免费观看av | 国产一级二级在线 | 亚洲v精品| 高清免费在线视频 | 在线免费观看视频一区 | 久久精品aaa | 伊人首页| 精品视频一区在线 | 欧美一区二区视频97 | 国产日韩欧美综合在线 | 91香蕉视频 mp4| a午夜在线| www.色的 | 免费观看视频的网站 | 亚洲高清激情 | 999久久久久久久久 69av视频在线观看 | 日韩黄色大片在线观看 | 在线播放视频一区 | a v在线视频| 国产九九九九九 | 欧美一区二区三区激情视频 | 黄色av免费 | 天天天天色综合 | 狠狠操夜夜 | 免费毛片一区二区三区久久久 | 日本资源中文字幕在线 | 国产一区二区三区久久久 | 在线黄色av| 国产va饥渴难耐女保洁员在线观看 | 91精品国产99久久久久久红楼 | 在线观看日韩av | 97激情影院| 国产亚洲精品v | 日韩最新理论电影 | 久久国产视频网站 | 999毛片| a午夜在线 | 久久精品91久久久久久再现 | 国产综合91 | 欧美在线a视频 | 丁香五月亚洲综合在线 | 日韩av进入 | 久草视频在线播放 | 五月激情丁香 | 99视频免费| 欧美性性网 | 日韩免费电影一区二区三区 | 黄网站app在线观看免费视频 | 九九综合久久 | 久久精品视频日本 | 中文字幕亚洲欧美日韩2019 | 91精品视频播放 | 欧美色图p| 91精品毛片| 一级黄色毛片 | 免费在线观看黄色网 | 亚洲一级黄色 | 激情综合久久 | 日韩av电影中文字幕在线观看 | 久草视频在线观 | 国产免费二区 | 久久成人免费 | 国产成人精品999 | 国产精品福利午夜在线观看 | 丁香5月婷婷久久 | 激情综合色图 | 在线v片 | 国产一级黄色免费看 | 国产精品一区二区三区四 | 久久国产日韩 | 国产v在线 | 日韩在线视频免费看 | 久久精品这里热有精品 | 久久激情精品 | 天天草av | a级国产乱理论片在线观看 特级毛片在线观看 | 天天操天天曰 | 亚洲国产精品日韩 | 99在线视频播放 | 婷婷久操| 国产精品久久久久久久久久不蜜月 | 国产一区二区在线精品 | 久久99精品久久久久久 | 免费99精品国产自在在线 | 久久xxxx| 久久久久久久久久久久国产精品 | 国产原创中文在线 | 国内精品国产三级国产aⅴ久 | 日韩欧美99 | 久久国产色 | 久久99精品久久久久久久久久久久 | 日日干天天操 | 三上悠亚在线免费 | 久草网在线观看 | 日韩免费观看一区二区三区 | 深爱五月激情网 | 狠狠网亚洲精品 | 999久久| 一区二区男女 | 97成人在线观看视频 | 五月天亚洲婷婷 | 国产视频在线观看一区 | 在线亚洲精品 | 欧美福利久久 | 欧美日韩成人 | 久热免费在线 | 超碰97国产在线 | 日韩电影在线观看中文字幕 | 五月婷婷色丁香 | 日韩欧美有码在线 | 狠狠躁夜夜av | 天天色天天色 | 在线免费av电影 | 日韩免费网站 | 丝袜美腿在线视频 | 在线影院 国内精品 | 免费一级日韩欧美性大片 | 婷婷色五| 美女天天操 | 久久久久久久久久久久久久av | 成人福利在线观看 | 国产一区二区三区免费观看视频 | 欧女人精69xxxxxx | 日韩精品在线视频免费观看 | 免费h在线观看 | 国产欧美最新羞羞视频在线观看 | 色就色,综合激情 | 天天曰夜夜操 | 伊人影院在线观看 | 香蕉影视app | 亚洲精品一区二区在线观看 | 中文字幕国语官网在线视频 | 在线网址你懂得 | 四虎免费av | 国产精品理论在线观看 | 婷婷丁香社区 | 在线av资源 | 玖玖精品在线 | 精品久久久久免费极品大片 | 97超碰中文字幕 | 欧美日韩久久一区 | 婷香五月| 久久a久久 | 国产资源在线免费观看 | 婷婷久久精品 | 九九久久婷婷 | 91漂亮少妇露脸在线播放 | 91在线影视| 天天射色综合 | 日韩精品中文字幕av | 欧美精品网站 | 亚洲欧美综合精品久久成人 | 成人亚洲精品国产www | av在线收看 | 久久久99精品免费观看 | 日韩免费高清在线 | 麻豆91精品91久久久 | 中文字幕在线播放av | 美女视频一区 | 亚洲 欧美 日韩 综合 | 在线成人中文字幕 | 国产精品一区二区三区在线看 | 国产高清绿奴videos | 美女视频黄频大全免费 | 国产福利91精品一区二区三区 | 亚洲精品一区二区精华 | 国产精品第52页 | 2022中文字幕在线观看 | 免费网址你懂的 | 亚洲国产天堂av | 色综合久久88色综合天天免费 | 日韩av网站在线播放 | www.综合网.com | 久久一区二区三区国产精品 | 999久久国产精品免费观看网站 | 欧美二区在线播放 | 最新av网址大全 | 久久久久久久久久电影 | 国产伦理精品一区二区 | 91精品国产麻豆 | 天天天天天干 | 久久久久久蜜av免费网站 | 999在线观看视频 | 久久精品一区二区三区国产主播 | 久久成人综合视频 | 久久精品99| av网站在线免费观看 | 免费亚洲精品视频 | 欧美日韩精品久久久 | 婷婷色亚洲 | 欧美一区二视频在线免费观看 | 久久久免费高清视频 | 成人资源在线播放 | 国产精品麻 | av电影 一区二区 | 日韩精品中文字幕在线不卡尤物 | 91成人在线观看喷潮 | 免费观看一级一片 | 久久精品视频播放 | 久久久国产精品视频 | 久久99视频免费 | www久久九 | 91人人澡人人爽人人精品 | 2019中文字幕网站 | 91久久精品一区 | 色综合在| 国产精品亚洲片夜色在线 | 黄色毛片在线 | 日日精品 | a在线观看国产 | 国产护士在线 | 久久久久久免费毛片精品 | 亚洲高清在线视频 | 亚洲精品黄色 | 国产精品久久久久久久久久三级 | 国产黄色视 | 91秒拍国产福利一区 | 最近av在线 | 西西444www高清大胆 | 一区二区视频电影在线观看 | 国产精品美女久久久久久2018 | 视频精品一区二区三区 | 国产视频在线观看一区 | 久久久精品成人 | 亚洲欧美视频网站 | 丝袜美女在线观看 | 欧美在线一级片 | 97超碰人人澡人人爱学生 | 亚洲精品国产精品国自产 | 少妇bbb搡bbbb搡bbbb′ | 一本一本久久a久久精品综合 | 日韩精品在线观看视频 | 中文字幕一区二区三区四区在线视频 | 国产精品99在线播放 | www.99久久.com | 国产精品免费久久久久 | 探花视频免费观看高清视频 | 四虎在线观看 | 99操视频 | av在线进入 | 亚洲精品国产第一综合99久久 | 日韩精品一区二区三区免费观看视频 | 日本黄色大片免费看 | 免费av高清 | 国产一二三四在线观看视频 | 亚洲情影院 | 国产成人免费在线观看 | 久久精品99 | 丁香色综合 | 国产在线免费av | 国产成人av一区二区三区在线观看 | 免费精品国产 | 丁香久久激情 | 韩日精品在线观看 | 国产91aaa| 伊人久久婷婷 | 九九热免费观看 | 午夜精品久久久久久中宇69 | 一区二区免费不卡在线 | 六月色丁香 | 91精品蜜桃 | 日韩福利在线观看 | 激情深爱 | 激情视频一区 | 色婷婷av国产精品 | 免费在线观看av网站 | 天天操天天曰 | 中文字幕一区在线观看视频 | 香蕉网在线| 91丨九色丨国产丨porny精品 | 久久综合狠狠综合久久激情 | 亚洲免费国产视频 | 久久97久久97精品免视看 | 日韩久久午夜一级啪啪 | 最新99热 | 免费a现在观看 | 日韩久久精品一区二区三区 | 97在线精品视频 | 91av视频导航 | 黄网站色视频免费观看 | 亚州激情视频 | 国产精品美女久久久久久久久久久 | 亚洲成人黄色网址 | 91视频免费看片 | 500部大龄熟乱视频 欧美日本三级 | 成人免费电影 | 激情av五月婷婷 | 亚洲日本在线视频观看 | 看全黄大色黄大片 | 在线观看自拍 | 亚洲精品国产精品久久99热 | 一区二区三区播放 | 日韩av电影免费观看 | 日韩精品在线看 | 最近中文字幕大全 | 9草在线| 九九视频精品在线 | 草久在线视频 | 最新国产一区二区三区 | 国内精品久久久久影院优 | 精品uu| 久久久91精品国产 | 亚洲一区二区三区在线看 | 中文在线免费一区三区 | 精品国产伦一区二区三区免费 | 热久久免费视频精品 | 99国产精品免费网站 | 美女视频黄在线观看 | 欧美视频18 | 欧美一区在线看 | 天天玩夜夜操 | www五月天婷婷 | 爱情影院aqdy鲁丝片二区 | 国产区欧美| 精品色999 | 国产成人精品久久 | 深夜成人av | 日韩经典一区二区三区 | 视频在线日韩 | 亚洲高清在线视频 | av一级在线观看 | 最新99热 | 亚洲国产视频直播 | 国产日产精品久久久久快鸭 | 国产成人久久精品一区二区三区 | av在线免费在线 | 成人免费在线看片 | 日韩久久影院 | 久久久精品国产免费观看一区二区 | 成人欧美一区二区三区在线观看 | 亚洲精品美女在线观看播放 | 91麻豆操| 日日干干夜夜 | 狠狠地日| 亚洲欧美日韩国产一区二区三区 | av高清网站在线观看 | 亚州人成在线播放 | 天天综合导航 | 五月天六月丁香 | 久久久久综合视频 | 国产亚洲va综合人人澡精品 | 国产成人精品久久久 | av免费观看网址 | 国产老太婆免费交性大片 | 月丁香婷婷 | 久久婷亚洲五月一区天天躁 | 91夜夜夜 | 97精品国产97久久久久久粉红 | 992tv在线成人免费观看 | 成人永久免费 | 丁香视频免费观看 | 国产拍揄自揄精品视频麻豆 | 国产精品永久免费观看 | 久草视频在线播放 | 国内精品在线一区 | 久久久久久国产精品久久 | 久久国产精品精品国产色婷婷 | 亚洲九九精品 | 日韩电影在线一区二区 | 久久福利小视频 | 韩国av免费观看 | 天天干天天干天天干天天干天天干天天干 | 色多多在线观看 | 亚洲另类交 | 不卡的一区二区三区 | 国产小视频你懂的 | 久久玖 | 色网站在线看 | 麻豆观看| 亚洲一区免费在线 | 国产精品毛片一区二区在线看 | 精品国产一区二区三区久久 | 国产黄色免费在线观看 | 免费看十八岁美女 | 色.com| 日韩免费高清在线观看 | 国产美女精品视频免费观看 | 亚洲精品国精品久久99热一 | 日日干天天操 | 日韩动态视频 | 精品福利网站 | 久久99这里只有精品 | 日韩成人免费在线电影 | 最近中文字幕高清字幕在线视频 | 中文字幕一区二区三区乱码在线 | 中文字幕在线视频一区二区 | 中日韩在线 | 国产裸体bbb视频 | 婷婷六月丁 | 精品久久久久久久久久久久久久久久 | 欧美日韩精品国产 | 日韩一区二区免费视频 | 国产一级电影在线 | 一级黄色片在线观看 | 亚洲成成品网站 | 国内精品久久久久久中文字幕 | 西西www4444大胆在线 | 国产成人一区二区三区久久精品 | 97超碰人人模人人人爽人人爱 | 国产艹b视频| 亚洲成熟女人毛片在线 | 国产破处在线视频 | 中文字幕影视 | 欧美污污视频 | 久久99精品波多结衣一区 | 韩日精品中文字幕 | av综合av | 日韩精品五月天 | av成人免费网站 | 在线观看一区二区精品 | www在线免费观看 | 高清av在线| 成年人免费看片 | www五月天com | 国产va饥渴难耐女保洁员在线观看 | 欧美有色 | 中文一二区 | japanesexxxhd奶水| 国产亚洲久一区二区 | 免费国产黄线在线观看视频 | 国内精品福利视频 | 午夜精品久久久久久久99水蜜桃 | 中文在线8资源库 | 国产在线精品视频 | 91九色国产蝌蚪 | 中文字幕黄色网 | 精品99免费视频 | 在线小视频国产 | 999精品在线 | 亚洲日韩中文字幕 | 狠狠色婷婷丁香六月 | 成片免费观看视频大全 | 国产一级在线观看 | 丁香导航| 九九交易行官网 | 中文字幕在线观看第三页 | 麻豆一级视频 | 国产精品入口a级 | 综合久久五月天 | 麻豆视频国产 | 人人爱夜夜操 | 狠狠色噜噜狠狠狠合久 | 久久久免费av | 五月婷婷丁香六月 | 精壮的侍卫呻吟h | 九九热精品在线 | 国产精品乱码久久久久 | 91精品视频导航 | 视频成人永久免费视频 | 国产精品久久久久永久免费观看 | www91在线| 国产日韩精品一区二区 | 97超碰在线视 | 婷婷电影在线观看 | 中文字幕亚洲五码 | 草久在线 | 亚洲欧洲国产精品 | 精品一区二区亚洲 | 久久久久久久久国产 | 免费在线观看av网站 | 91丨精品丨蝌蚪丨白丝jk | 天天躁日日| 日本精品一区二区三区在线观看 | 国产精品视频免费看 | av在线亚洲天堂 | 欧美另类交在线观看 | 国产成人精品综合久久久久99 | 狠狠色伊人亚洲综合成人 | 国外调教视频网站 | 亚洲va在线va天堂 | 在线成人中文字幕 | 国产精品毛片一区视频播不卡 | 成人av在线播放网站 | 国产麻豆剧果冻传媒视频播放量 | 久久久久久久网站 | 国产午夜亚洲精品 | 亚洲精品国产日韩 | 久精品视频在线 | 69av国产| 色天天久久| 国产成人精品一区二区 | 久久大视频 | 久久视频网址 | 在线亚洲小视频 | 国产亚洲精品久久久久久久久久 | 超碰在线网 | 欧美最新大片在线看 | 国产视频九色蝌蚪 | 91禁在线看 | 亚洲一级黄色av | 国产精品久久久久久久7电影 | 国产精品美乳一区二区免费 | 婷婷国产在线观看 | 91av播放| 亚洲精品午夜视频 | 国产一区二区成人 | 免费国产ww | 欧美黑人性猛交 | 国产成人福利片 | 成人免费网视频 | 国产91亚洲| 97福利| 久久激情小说 | 日本精品久久久久中文字幕5 | 久久精视频 | 96精品视频 | 成人黄色小说视频 | 亚洲精品高清在线 | 又黄又爽免费视频 | 久久视频二区 | 黄色国产精品 | 91爱看片 | 久久亚洲欧美日韩精品专区 | 一区二区三区在线免费播放 | 久久精选视频 | 偷拍精偷拍精品欧洲亚洲网站 | 综合色综合 | 亚州激情视频 | 亚洲免费av在线 | 成年人在线免费视频观看 | 国产精品女视频 | 香蕉视频网址 | 久草在线免费在线观看 | 亚洲无在线 | 九九综合久久 | 日韩午夜电影网 | 国产亚洲精品综合一区91 | 91观看视频 | 在线欧美中文字幕 | 波多野结衣理论片 | 91精彩视频| 亚州av成人 | 日日插日日干 | 九九热1| 玖玖爱在线观看 | 粉嫩av一区二区三区四区五区 | 国产 成人 久久 | 国产美女网站在线观看 | 国产精选在线 | 天天干夜夜夜 | 国产精品手机看片 | 免费视频久久久久久久 | 国产精品久久久久久久久久久久冷 | 亚洲精品自在在线观看 | 丁香婷婷综合网 | 99久久精品免费看国产一区二区三区 | 视频二区在线 | 一区二区三区四区在线免费观看 | 亚洲午夜精品一区 | 五月天久久久 | 97国产一区| 欧美色图88| 一本—道久久a久久精品蜜桃 | 欧美a影视 | 91成人精品在线 | 97超碰在线人人 | 国产精品爽爽久久久久久蜜臀 | 亚洲成人av一区二区 | 亚洲aⅴ乱码精品成人区 | 久久人人97超碰国产公开结果 | 久久综合九色欧美综合狠狠 | 久久一区二区三区四区 | 精品久久久久免费极品大片 | 亚洲国产日韩欧美 | 97超碰免费在线 | 国产在线观看不卡 | 日本中文字幕在线看 | 欧美日韩亚洲在线观看 | 91精品国产欧美一区二区 | 天天操天| 97在线观看免费高清完整版在线观看 | 中文av一区二区 | 91在线精品播放 | www.亚洲视频.com | 婷婷天天色 | 婷婷亚洲激情 | 亚洲精品视频网站在线观看 | www.天天射| 香蕉视频免费在线播放 | 我要看黄色一级片 | 91免费在线 | 国产福利在线不卡 | 亚洲在线视频播放 | 精品久久综合 | 中文一区在线 | 色视频 在线 | 国产精品一区二区av麻豆 | 日韩精品一区二区不卡 | 蜜臀av性久久久久av蜜臀三区 | 免费看的黄色录像 | 中文字幕在线观看免费高清电影 | 五月天色丁香 | 狠狠色丁香久久婷婷综合丁香 | 天天射天天 | 中文字幕一区二区三区四区 | 美女黄久久| 久久五月婷婷丁香社区 | 亚洲第一伊人 | 精品久久99| 日日夜夜噜噜噜 | 在线播放91 | 91久久国产综合精品女同国语 | 日韩av看片 | 午夜久久福利 | 日韩精品久久久久久中文字幕8 | 婷婷六月在线 | 日韩精品中文字幕在线播放 | 日韩在线三区 | 久久99免费 | 91一区啪爱嗯打偷拍欧美 | 亚洲天天在线日亚洲洲精 | 国产精品美女久久久久久免费 | 久久精品在线视频 | 国产一区二区综合 | www.天天操.com | 激情视频一区二区三区 | 日韩伦理片一区二区三区 | 激情五月婷婷综合 | 久久这里精品视频 | 中文字幕在线观看亚洲 | 美女黄频免费 | 在线观看中文字幕av | 狠狠干夜夜操天天爽 | 日韩天堂网 | 亚洲成av人片在线观看香蕉 | 天天干视频在线 | 狠狠狠狠干 | 黄色在线看网站 | 国产手机在线 | 日韩com| 免费激情在线电影 | 精产嫩模国品一二三区 | 精精国产xxxx视频在线播放 | 一区二区三区在线看 | 国产亚洲情侣一区二区无 | 国产精品精品久久久久久 | 日韩一级成人av | 成人一区不卡 | 国产精品久久嫩一区二区免费 | 日韩v在线91成人自拍 | 天堂va在线高清一区 | 国产精品久久久久久久久久了 | 伊人热 | 国产美女网 | 亚洲视频一 | 国产日韩精品在线 | 五月精品| 久久久久国产视频 | 欧美亚洲另类在线视频 | 日韩免费在线视频观看 | 一区二区激情视频 | 午夜精品久久久久久久久久久久久久 | 99精品视频免费在线观看 | 免费看成人av | 91成人免费在线视频 | 天天躁天天狠天天透 | 在线a亚洲视频播放在线观看 | 成年人国产视频 | 91香蕉视频好色先生 | 亚洲专区 国产精品 | 国产精品久99 | 久久久伦理 | 免费在线看v | 日本一区二区不卡高清 | 精品国产成人在线影院 | 国产成人久久精品77777 | 免费在线色电影 | 91精品婷婷国产综合久久蝌蚪 | 国产精品12345 | 2019天天干夜夜操 | 久久好看免费视频 | 婷婷激情在线 | 手机在线永久免费观看av片 | 91精品少妇偷拍99 | 夜夜躁狠狠燥 | av网站有哪些 | 狠狠色伊人亚洲综合网站色 | 国内精品毛片 | 亚洲欧美经典 | 欧美一级片在线 | 午夜性生活 | 91理论电影 | 超碰资源在线 | 久久不色 | 免费看片成人 | 亚洲一级黄色片 | 在线观看免费成人av | 国产免费视频一区二区裸体 | 99精品国产福利在线观看免费 | 国产亚洲精品久久19p | 91精品国产乱码 | 久久成人欧美 | 国产福利一区二区三区视频 | 色噜噜噜噜 | 夜夜嗨av色一区二区不卡 | 免费久久网站 | 99视频在线免费播放 | 日本中文乱码卡一卡二新区 | 99国产在线观看 | 国产色女| 久久国产视频网 | 天天干天天怕 | 中文在线天堂资源 | 久久久久久国产一区二区三区 | www.色就是色| 国产小视频在线 | 日韩专区一区二区 | 天天操天天色天天射 | 日日夜夜爱 | 亚洲男人天堂a | 日本午夜在线观看 | 久久五月天婷婷 | 在线视频你懂得 | 蜜臀av免费一区二区三区 | 国产又粗又猛又爽又黄的视频免费 | 91精品国产自产91精品 | 操操操天天操 | 少妇视频一区 | 亚洲色视频 | 丁香影院在线 | 黄色a大片| 美女一二三区 | 在线观看免费91 | 久草在线 | 国产日产高清dvd碟片 | 国产一区二区在线免费播放 | 亚洲精品欧美精品 | 久久久久区 | 国产精品久久久久久久久久久杏吧 | 人成在线免费视频 | 国产夫妻自拍av | 日本最新一区二区三区 | 成年人视频在线免费观看 | 免费一级特黄录像 | 精品久久久久久亚洲综合网站 | 黄色精品国产 | 久久99久久99 | 欧洲精品视频一区 | 天天人人 | 99精品国产高清在线观看 | 天天躁日日躁狠狠躁av中文 | 色婷婷激情综合 | 99免费| 国产aa免费视频 | 四虎成人精品永久免费av | 国产老太婆免费交性大片 | 日韩一级电影在线 | 亚洲日本成人网 | 中文字幕高清视频 | 国产一级高清 | 黄色片网站免费 | 日韩精品久久一区二区三区 | 日日夜夜天天操 | 亚洲国产中文在线 | 精品亚洲免费视频 | 国产视频2 | a电影在线观看 | 久久国产三级 | 国产青青青 | 国产区免费在线 | 亚洲精品在线观看的 | 欧美激情精品久久久久久 | 色综合五月 | 国产精品1区 | 国产黄av | 亚洲va在线va天堂va偷拍 | 国产精品99在线播放 | 国产精彩视频一区 | 蜜臀av性久久久久蜜臀aⅴ涩爱 | 亚洲国产无 | 亚洲精品美女在线观看 | 久久成人精品视频 | 在线看v片| 国产精品欧美久久久久三级 | av片在线观看 | 日韩成人在线免费观看 | 亚洲天堂网视频 | 在线亚洲免费视频 | 中文字幕视频一区 | www婷婷| 97视频免费看 | 亚洲男男gⅴgay双龙 | 日本深夜福利视频 | 天天插视频 | 欧美一区二区三区特黄 | 操操日 | 伊人狠狠干| 99在线视频观看 | 亚洲欧美视频网站 | 亚洲一级片| 人人干人人上 | 人人玩人人添人人 | 麻花传媒mv免费观看 | 国产系列 在线观看 | 在线免费视频你懂的 | 亚洲高清免费在线 | 在线观看免费中文字幕 | 国产精品美女久久久久久2018 | 97精品国产97久久久久久粉红 | 干狠狠 | 91人人爽人人爽人人精88v | 黄色一级免费电影 | 国产中文字幕在线观看 | 天天操天天爽天天干 | 国产精品麻豆99久久久久久 | 韩国av免费| 亚洲国产中文在线 | 亚洲伊人成综合网 | 国产999久久久 | 波多野结衣综合网 | 中文不卡视频在线 | 久久不卡av | 日韩欧美在线高清 | 日韩av中文字幕在线 | 中文字幕在线观看一区二区 | 激情综合中文娱乐网 | 99精品国产高清在线观看 | 日韩在线视频免费观看 | 狠狠色丁香婷婷综合 | 日韩精品中文字幕在线不卡尤物 | 中文字幕亚洲精品日韩 | 在线激情电影 | 久久免费视频4 |