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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

kata_小规模流处理kata。 第1部分:线程池

發布時間:2023/12/3 编程问答 54 豆豆
生活随笔 收集整理的這篇文章主要介紹了 kata_小规模流处理kata。 第1部分:线程池 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

kata

我再次為我的公司在GeeCON 2016上舉辦了編程競賽。 這次分配需要設計并根據以下要求選擇實施系統:

一個系統每秒發送大約一千個事件。 每個Event至少具有兩個屬性:

  • clientId –我們期望一個客戶端每秒最多可以處理幾個事件
  • UUID –全球唯一

消耗一個事件大約需要10毫秒。 設計此類流的使用者:

  • 允許實時處理事件
  • 與一個客戶端有關的事件應按順序進行處理,即,您不能并行處理同一clientId事件
  • 如果10秒鐘內出現重復的UUID ,請將其刪除。 假設10秒鐘后不會出現重復
  • 這些要求中沒有幾個重要的細節:

  • 1000個事件/秒和10毫秒消耗一個事件。 顯然,我們至少需要10個并發使用者才能實時消費。
  • 事件具有自然的聚合ID( clientId )。 在一秒鐘內,我們可以為給定的客戶端預期一些事件,并且不允許我們同時或無序處理它們。
  • 我們必須以某種方式忽略重復的消息,最有可能的是通過記住最近10秒鐘內的所有唯一ID。 這使大約一萬個UUID得以臨時保留。
  • 在本文中,我將指導您完成一些正確的解決方案,并嘗試一些失敗的嘗試。 您還將學習如何使用少量精確定位的指標來解決問題。

    天真的順序處理

    讓我們通過迭代解決這個問題。 首先,我們必須對API進行一些假設。 想象一下:

    interface EventStream {void consume(EventConsumer consumer);}@FunctionalInterface interface EventConsumer {Event consume(Event event); }@Value class Event {private final Instant created = Instant.now();private final int clientId;private final UUID uuid;}

    典型的基于推送的API,類似于JMS。 一個重要的注意事項是EventConsumer正在阻止,這意味著直到EventConsumer消耗了前一個Event ,它才交付新的Event 。 這只是我所做的一個假設,并沒有徹底改變需求。 這也是JMS中消息偵聽器的工作方式。 天真的實現只附加了一個偵聽器,該偵聽器需要大約10毫秒才能完成:

    class ClientProjection implements EventConsumer {@Overridepublic Event consume(Event event) {Sleeper.randSleep(10, 1);return event;}}

    當然,在現實生活中,這個使用者會在數據庫中存儲一些東西,進行遠程調用等。我在睡眠時間分配中添加了一些隨機性,以使手動測試更加實際:

    class Sleeper {private static final Random RANDOM = new Random();static void randSleep(double mean, double stdDev) {final double micros = 1_000 * (mean + RANDOM.nextGaussian() * stdDev);try {TimeUnit.MICROSECONDS.sleep((long) micros);} catch (InterruptedException e) {throw new RuntimeException(e);}}}//...EventStream es = new EventStream(); //some real implementation here es.consume(new ClientProjection());

    它可以編譯并運行,但是為了確定未滿足要求,我們必須插入少量指標。 最重要的指標是消息消耗的延遲,以消息創建到開始處理之間的時間來衡量。 我們將為此使用Dropwizard指標 :

    class ClientProjection implements EventConsumer {private final ProjectionMetrics metrics;ClientProjection(ProjectionMetrics metrics) {this.metrics = metrics;}@Overridepublic Event consume(Event event) {metrics.latency(Duration.between(event.getCreated(), Instant.now()));Sleeper.randSleep(10, 1);return event;}}

    提取ProjectionMetrics類以分離職責:

    import com.codahale.metrics.Histogram; import com.codahale.metrics.MetricRegistry; import com.codahale.metrics.Slf4jReporter; import lombok.extern.slf4j.Slf4j;import java.time.Duration; import java.util.concurrent.TimeUnit;@Slf4j class ProjectionMetrics {private final Histogram latencyHist;ProjectionMetrics(MetricRegistry metricRegistry) {final Slf4jReporter reporter = Slf4jReporter.forRegistry(metricRegistry).outputTo(log).convertRatesTo(TimeUnit.SECONDS).convertDurationsTo(TimeUnit.MILLISECONDS).build();reporter.start(1, TimeUnit.SECONDS);latencyHist = metricRegistry.histogram(MetricRegistry.name(ProjectionMetrics.class, "latency"));}void latency(Duration duration) {latencyHist.update(duration.toMillis());} }

    現在,當您運行樸素的解決方案時,您會Swift發現中值延遲以及99.9%的百分數無限增長:

    type=HISTOGRAM, [...] count=84, min=0, max=795, mean=404.88540608274104, [...]median=414.0, p75=602.0, p95=753.0, p98=783.0, p99=795.0, p999=795.0 type=HISTOGRAM, [...] count=182, min=0, max=1688, mean=861.1706371990878, [...]median=869.0, p75=1285.0, p95=1614.0, p98=1659.0, p99=1678.0, p999=1688.0[...30 seconds later...]type=HISTOGRAM, [...] count=2947, min=14, max=26945, mean=15308.138585757424, [...]median=16150.0, p75=21915.0, p95=25978.0, p98=26556.0, p99=26670.0, p999=26945.0

    30秒后,我們的應用程序平均會延遲15秒處理事件。 并非完全實時 。 顯然,缺少并發是任何原因。 我們的ClientProjection事件使用者大約需要10毫秒才能完成,因此每秒可以處理多達100個事件,而我們還需要一個數量級。 我們必須以某種方式擴展ClientProjection 。 而且我們甚至都沒有觸及其他要求!

    天真線程池

    最明顯的解決方案是從多個線程調用EventConsumer 。 最簡單的方法是利用ExecutorService :

    import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors;class NaivePool implements EventConsumer, Closeable {private final EventConsumer downstream;private final ExecutorService executorService;NaivePool(int size, EventConsumer downstream) {this.executorService = Executors.newFixedThreadPool(size);this.downstream = downstream;}@Overridepublic Event consume(Event event) {executorService.submit(() -> downstream.consume(event));return event;}@Overridepublic void close() throws IOException {executorService.shutdown();} }

    我們在這里使用裝飾器模式 。 實現EventConsumer的原始ClientProjection是正確的。 但是,我們將其與EventConsumer另一個實現并發包裝。 這將使我們能夠編寫復雜的行為而無需更改ClientProjection本身。 這樣的設計促進:

    • 松散耦合:各種EventConsumer彼此都不了解,可以自由組合
    • 單一責任:每個人都做一份工作,然后委派給下一個組成部分
    • 開放/封閉原則 :我們可以在不修改現有實現的情況下更改系統的行為。

    打開/關閉原理通常通過注入策略和模板方法模式來實現。 在這里,它甚至更簡單。 整體接線如下:

    MetricRegistry metricRegistry =new MetricRegistry(); ProjectionMetrics metrics =new ProjectionMetrics(metricRegistry); ClientProjection clientProjection =new ClientProjection(metrics); NaivePool naivePool =new NaivePool(10, clientProjection); EventStream es = new EventStream(); es.consume(naivePool);

    我們精心設計的指標表明情況確實好得多:

    type=HISToOGRAM, count=838, min=1, max=422, mean=38.80768197277468, [...]median=37.0, p75=45.0, p95=51.0, p98=52.0, p99=52.0, p999=422.0 type=HISTOGRAM, count=1814, min=1, max=281, mean=47.82642776789085, [...]median=51.0, p75=57.0, p95=61.0, p98=62.0, p99=63.0, p999=65.0[...30 seconds later...]type=HISTOGRAM, count=30564, min=5, max=3838, mean=364.2904915942238, [...]median=352.0, p75=496.0, p95=568.0, p98=574.0, p99=1251.0, p999=3531.0

    然而,我們仍然看到延遲的規模越來越小,在30秒后,延遲達到了364毫秒。 它一直在增長,所以問題是系統的。 我們……需要……更多……指標。 請注意, NaivePool (您很快就會知道為什么它是naive )有正好有10個線程NaivePool 。 這應該足以處理數千個事件,每個事件需要10毫秒來處理。 實際上,我們需要一點額外的處理能力,以避免垃圾收集后或負載高峰時出現問題。 為了證明線程池實際上是我們的瓶頸,最好監視其內部隊列。 這需要一些工作:

    class NaivePool implements EventConsumer, Closeable {private final EventConsumer downstream;private final ExecutorService executorService;NaivePool(int size, EventConsumer downstream, MetricRegistry metricRegistry) {LinkedBlockingQueue<Runnable> queue = new LinkedBlockingQueue<>();String name = MetricRegistry.name(ProjectionMetrics.class, "queue");Gauge<Integer> gauge = queue::size;metricRegistry.register(name, gauge);this.executorService = new ThreadPoolExecutor(size, size, 0L, TimeUnit.MILLISECONDS, queue);this.downstream = downstream;}@Overridepublic Event consume(Event event) {executorService.submit(() -> downstream.consume(event));return event;}@Overridepublic void close() throws IOException {executorService.shutdown();} }

    這里的想法是手動創建ThreadPoolExecutor ,以提供自定義的LinkedBlockingQueue實例。 我們稍后可以使用該隊列來監視其長度(請參閱: ExecutorService – 10個技巧 )。 Gauge將定期調用queue::size并將其報告給您需要的地方。 度量標準確認線程池大小確實是一個問題:

    type=GAUGE, name=[...].queue, value=35 type=GAUGE, name=[...].queue, value=52[...30 seconds later...]type=GAUGE, name=[...].queue, value=601

    容納待處理任務的隊列的大小不斷增加,這會損害延遲。 線程池大小從10增加到20最終報告了不錯的結果,并且沒有停頓。 但是,我們仍然沒有解決重復項,也沒有針對同一clientId防止事件的同時修改。

    晦澀的鎖定

    讓我們從避免對同一clientId的事件進行并發處理開始。 如果兩個事件接連發生,并且都與同一個clientId相關,那么NaivePool將選擇它們并開始同時處理它們。 首先,我們至少通過為每個clientId設置一個Lock來發現這種情況:

    @Slf4j class FailOnConcurrentModification implements EventConsumer {private final ConcurrentMap<Integer, Lock> clientLocks = new ConcurrentHashMap<>();private final EventConsumer downstream;FailOnConcurrentModification(EventConsumer downstream) {this.downstream = downstream;}@Overridepublic Event consume(Event event) {Lock lock = findClientLock(event);if (lock.tryLock()) {try {downstream.consume(event);} finally {lock.unlock();}} else {log.error("Client {} already being modified by another thread", event.getClientId());}return event;}private Lock findClientLock(Event event) {return clientLocks.computeIfAbsent(event.getClientId(),clientId -> new ReentrantLock());}}

    這肯定是朝錯誤的方向前進。 復雜程度不堪重負,但是運行此代碼至少表明存在問題。 事件處理管道如下所示,一個裝飾器包裝了另一個裝飾器:

    ClientProjection clientProjection =new ClientProjection(new ProjectionMetrics(metricRegistry)); FailOnConcurrentModification failOnConcurrentModification =new FailOnConcurrentModification(clientProjection); NaivePool naivePool =new NaivePool(10, failOnConcurrentModification, metricRegistry); EventStream es = new EventStream();es.consume(naivePool);

    偶爾會彈出錯誤消息,告訴我們其他一些線程已經在處理同一clientId事件。 對于每個clientId我們關聯一個檢查的Lock ,以便確定當前是否有另一個線程不在處理該客戶端。 盡管丑陋,但實際上我們已經接近殘酷的解決方案。 而不是因為另一個線程已經在處理某個事件而無法獲取Lock時失敗,讓我們稍等一下,希望Lock可以被釋放:

    @Slf4j class WaitOnConcurrentModification implements EventConsumer {private final ConcurrentMap<Integer, Lock> clientLocks = new ConcurrentHashMap<>();private final EventConsumer downstream;private final Timer lockWait;WaitOnConcurrentModification(EventConsumer downstream, MetricRegistry metricRegistry) {this.downstream = downstream;lockWait = metricRegistry.timer(MetricRegistry.name(WaitOnConcurrentModification.class, "lockWait"));}@Overridepublic Event consume(Event event) {try {final Lock lock = findClientLock(event);final Timer.Context time = lockWait.time();try {final boolean locked = lock.tryLock(1, TimeUnit.SECONDS);time.stop();if(locked) {downstream.consume(event);}} finally {lock.unlock();}} catch (InterruptedException e) {log.warn("Interrupted", e);}return event;}private Lock findClientLock(Event event) {return clientLocks.computeIfAbsent(event.getClientId(),clientId -> new ReentrantLock());}}

    這個想法非常相似。 但是, tryLock()失敗,它最多等待1秒,以希望釋放給定客戶端的Lock 。 如果兩個事件很快相繼發生,一個事件將獲得一個Lock并繼續執行,而另一個事件將阻止等待unlock()發生。

    不僅這些代碼確實令人費解,而且還可能以許多微妙的方式被破壞。 例如,如果幾乎同一時間發生同一客戶clientId兩個事件,但是顯然是第一個事件呢? 這兩個事件將同時請求Lock ,并且我們無法保證哪個事件會首先獲得不公平的Lock ,從而可能會亂序使用事件。 肯定有更好的辦法…

    專用線程

    讓我們退后一步,深吸一口氣。 您如何確保事情不會同時發生? 好吧,只需使用一個線程! 事實上,這是我們一開始所做的,但吞吐量并不令人滿意。 但是我們不關心不同的clientId的并發性,我們只需要確保具有相同clientId事件始終由同一線程處理即可!

    也許您會想到創建從clientId到Thread的映射? 好吧,這將過于簡單化。 我們將創建數千個線程,每個線程在大多數時間都根據需求空閑(對于給定的clientId每秒只有很少的事件)。 一個不錯的折衷方案是固定大小的線程池,每個線程負責clientId的眾所周知的子集。 這樣,兩個不同的clientId可能會終止在同一線程上,但是同一clientId將始終由同一線程處理。 如果出現同一clientId兩個事件,則它們都將被路由到同一線程,從而避免了并發處理。 實現非常簡單:

    class SmartPool implements EventConsumer, Closeable {private final List<ExecutorService> threadPools;private final EventConsumer downstream;SmartPool(int size, EventConsumer downstream, MetricRegistry metricRegistry) {this.downstream = downstream;List<ExecutorService> list = IntStream.range(0, size).mapToObj(i -> Executors.newSingleThreadExecutor()).collect(Collectors.toList());this.threadPools = new CopyOnWriteArrayList<>(list);}@Overridepublic void close() throws IOException {threadPools.forEach(ExecutorService::shutdown);}@Overridepublic Event consume(Event event) {final int threadIdx = event.getClientId() % threadPools.size();final ExecutorService executor = threadPools.get(threadIdx);executor.submit(() -> downstream.consume(event));return event;} }

    關鍵部分就在最后:

    int threadIdx = event.getClientId() % threadPools.size(); ExecutorService executor = threadPools.get(threadIdx);

    這個簡單的算法將始終對相同的clientId使用相同的單線程ExecutorService 。 不同的ID可在同一池中結束,例如,當池大小是20 ,客戶機7 , 27 , 47等,將使用相同的線程。 但這可以,只要一個clientId始終使用同一線程即可。 此時,不需要鎖定,并且可以保證順序調用,因為同一客戶端的事件始終由同一線程執行。 旁注:每個clientId一個線程無法擴展,但是每個clientId一個角色(例如,在Akka中)是一個很好的主意,它可以簡化很多工作。

    為了更加安全,我在每個線程池中插入了平均隊列大小的指標,從而使實現更長:

    class SmartPool implements EventConsumer, Closeable {private final List<LinkedBlockingQueue<Runnable>> queues;private final List<ExecutorService> threadPools;private final EventConsumer downstream;SmartPool(int size, EventConsumer downstream, MetricRegistry metricRegistry) {this.downstream = downstream;this.queues = IntStream.range(0, size).mapToObj(i -> new LinkedBlockingQueue<Runnable>()).collect(Collectors.toList());List<ThreadPoolExecutor> list = queues.stream().map(q -> new ThreadPoolExecutor(1, 1, 0L, TimeUnit.MILLISECONDS, q)).collect(Collectors.toList());this.threadPools = new CopyOnWriteArrayList<>(list);metricRegistry.register(MetricRegistry.name(ProjectionMetrics.class, "queue"), (Gauge<Double>) this::averageQueueLength);}private double averageQueueLength() {double totalLength =queues.stream().mapToDouble(LinkedBlockingQueue::size).sum();return totalLength / queues.size();}//...}

    如果您偏執狂,您甚至可以為每個隊列創建一個指標。

    重復數據刪除和冪等

    在分布式環境中,當生產者至少有一次保證時,接收重復事件是很常見的。 這種行為的原因不在本文討論范圍之內,但我們必須學習如何解決該問題。 一種方法是將全局唯一標識符( UUID )附加到每條消息,并確保在消費者方面不會對具有相同標識符的消息進行兩次處理。 每個Event都有這樣的UUID 。 根據我們的要求,最直接的解決方案是簡單地存儲所有可見的UUID并在到達時驗證接收到的UUID從未見過。 按原樣使用ConcurrentHashMap<UUID, UUID> (JDK中沒有ConcurrentHashSet )會導致內存泄漏,因為隨著時間的推移,我們將不斷積累越來越多的ID。 這就是為什么我們僅在最近10秒內查找重復項。 從技術上講,您可以擁有ConcurrentHashMap<UUID, Instant> ,當遇到該問題時,它會從UUID映射到時間戳。 通過使用后臺線程,我們可以刪除10秒鐘以上的元素。 但是,如果您是快樂的Guava用戶,則具有聲明性驅逐策略的Cache<UUID, UUID>將達到目的:

    import com.codahale.metrics.Gauge; import com.codahale.metrics.Meter; import com.codahale.metrics.MetricRegistry; import com.google.common.cache.Cache; import com.google.common.cache.CacheBuilder;import java.util.UUID; import java.util.concurrent.TimeUnit;class IgnoreDuplicates implements EventConsumer {private final EventConsumer downstream;private Cache<UUID, UUID> seenUuids = CacheBuilder.newBuilder().expireAfterWrite(10, TimeUnit.SECONDS).build();IgnoreDuplicates(EventConsumer downstream) {this.downstream = downstream;}@Overridepublic Event consume(Event event) {final UUID uuid = event.getUuid();if (seenUuids.asMap().putIfAbsent(uuid, uuid) == null) {return downstream.consume(event);} else {return event;}} }

    為了保證生產安全,我至少可以想到兩個指標可能會有用:緩存大小和發現的重復項數量。 讓我們也插入以下指標:

    class IgnoreDuplicates implements EventConsumer {private final EventConsumer downstream;private final Meter duplicates;private Cache<UUID, UUID> seenUuids = CacheBuilder.newBuilder().expireAfterWrite(10, TimeUnit.SECONDS).build();IgnoreDuplicates(EventConsumer downstream, MetricRegistry metricRegistry) {this.downstream = downstream;duplicates = metricRegistry.meter(MetricRegistry.name(IgnoreDuplicates.class, "duplicates"));metricRegistry.register(MetricRegistry.name(IgnoreDuplicates.class, "cacheSize"), (Gauge<Long>) seenUuids::size);}@Overridepublic Event consume(Event event) {final UUID uuid = event.getUuid();if (seenUuids.asMap().putIfAbsent(uuid, uuid) == null) {return downstream.consume(event);} else {duplicates.mark();return event;}} }

    最終,我們擁有了構建解決方案的所有要素。 這個想法是由彼此包裝的EventConsumer實例組成管道:

  • 首先,我們應用IgnoreDuplicates拒絕重復項
  • 然后,我們調用SmartPool ,它將始終將給定的clientId到同一線程,并在該線程中執行下一階段
  • 最后,調用真正執行業務邏輯的ClientProjection 。
  • 您可以選擇在SmartPool和ClientProjection之間放置FailOnConcurrentModification步驟,以提高安全性(設計上不應進行并發修改):

    ClientProjection clientProjection =new ClientProjection(new ProjectionMetrics(metricRegistry)); FailOnConcurrentModification concurrentModification =new FailOnConcurrentModification(clientProjection); SmartPool smartPool =new SmartPool(12, concurrentModification, metricRegistry); IgnoreDuplicates withoutDuplicates =new IgnoreDuplicates(smartPool, metricRegistry); EventStream es = new EventStream(); es.consume(withoutDuplicates);

    我們花了很多工作才能提出相對簡單且結構合理的解決方案(我希望您同意)。 最后,解決并發問題的最佳方法是……避免并發,并在一個線程中運行受競爭條件約束的代碼。 這也是Akka actor(每個actor處理單個消息)和RxJava( Subscriber處理的一條消息)背后的思想。 在下一部分中,我們將在RxJava中看到聲明式解決方案。

    翻譯自: https://www.javacodegeeks.com/2016/10/small-scale-stream-processing-kata-part-1-thread-pools.html

    kata

    總結

    以上是生活随笔為你收集整理的kata_小规模流处理kata。 第1部分:线程池的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    色婷婷狠狠五月综合天色拍 | 午夜精品一区二区三区免费视频 | 国产成人三级在线观看 | 深爱激情开心 | 欧美污在线观看 | 中文字幕免费播放 | 日韩欧美精品一区 | 久久av中文字幕片 | 蜜臀久久99精品久久久久久网站 | 91视频a | 天天色婷婷 | 三级视频片 | 国产对白av| 亚洲国产三级 | 久久久久女人精品毛片九一 | 亚洲欧美日韩在线看 | 97在线观看免费观看高清 | 免费看污在线观看 | 久久福利影视 | 久久久伊人网 | 国产精品日韩久久久久 | 成年人视频在线免费播放 | 在线观看一| 国产白浆在线观看 | 亚洲无吗天堂 | 国产伦精品一区二区三区无广告 | 久久综合干| 国产精品视频久久久 | 色综合久久88色综合天天免费 | 日韩在线观看网站 | 91精品欧美一区二区三区 | 亚洲人人av| 成人免费在线观看av | 成人黄色免费在线观看 | 国产亚州av | 亚洲精品国产精品99久久 | 在线免费观看的av | 国模视频一区二区 | 久久久国产精华液 | 国产精品正在播放 | 玖玖视频国产 | 日韩在线网址 | 97超碰人 | 国产九色视频在线观看 | 区一区二在线 | 国产91精品一区二区 | 国产成人黄色网址 | 国产专区欧美专区 | 中文国产字幕在线观看 | 婷婷五月色综合 | 精品久久久久久久久久 | 日韩videos| 日日夜夜免费精品 | 亚洲在线网址 | 国产传媒中文字幕 | 人人添人人澡人人澡人人人爽 | 91精品影视 | 在线观看精品视频 | av亚洲产国偷v产偷v自拍小说 | 久久精品牌麻豆国产大山 | 久久久久久久久黄色 | 国产精品免费视频网站 | 天天插天天射 | 久久精品99国产 | 亚洲va综合va国产va中文 | 91精品国产91久久久久 | 在线国产中文 | 成人欧美在线 | 开心色激情网 | 黄污网 | 国产视频1区2区3区 久久夜视频 | 在线亚洲天堂网 | 精品视频免费看 | 人人精品久久 | 人人爱在线视频 | 精品国产1区2区3区 国产欧美精品在线观看 | 欧美日韩国产综合网 | 超碰97久久| 久久神马影院 | 国内久久久久久 | 成人性生交大片免费看中文网站 | 精品国产一区二区三区久久久 | 国产日韩视频在线观看 | 一区在线观看视频 | 五月天中文在线 | 欧美日韩中文在线 | 狠狠干狠狠色 | 国产午夜精品一区二区三区在线观看 | 91中文在线观看 | 亚洲天天摸日日摸天天欢 | 午夜av免费看 | 日韩av高潮 | 天海冀一区二区三区 | 国产中文伊人 | 免费视频xnxx com| 久久久免费 | 91在线视频一区 | 亚洲精品乱码白浆高清久久久久久 | 2022久久国产露脸精品国产 | 亚洲精品一区二区网址 | 国产精品欧美久久久久无广告 | 麻豆一区在线观看 | 97在线精品视频 | 六月色婷婷 | 国产精品九九九九九 | 亚洲小视频在线观看 | 97国产情侣爱久久免费观看 | 国产在线色 | 特级黄色一级 | 日日夜夜添 | 日韩成人免费在线观看 | 日韩一区在线免费观看 | 夜夜嗨av色一区二区不卡 | 97视频在线播放 | 中文视频在线看 | 91在线影院 | 国产麻豆精品一区二区 | 精品婷婷 | 欧美大片第1页 | 亚洲精品91天天久久人人 | 久久久久久久久久久网站 | 国产精品久久久久久久久久免费看 | 亚洲视频观看 | 一区二区三区四区在线免费观看 | 亚洲欧美日韩精品久久久 | 日韩久久精品一区 | av免费看网站 | 日本久久精品视频 | 欧美日韩在线网站 | 在线免费av观看 | 成人 国产 在线 | 日韩精品一区二区三区第95 | 久久综合久色欧美综合狠狠 | 片黄色毛片黄色毛片 | 日韩精品一区二区三区免费观看 | 亚州精品在线视频 | 狠狠操综合网 | 青青网视频 | 黄色美女免费网站 | 久久久精品福利视频 | 一本到视频在线观看 | 国产一区二区高清 | 国产高清第一页 | 91九色蝌蚪视频 | 最新动作电影 | 超碰在线观看97 | 婷婷丁香狠狠爱 | 天天干天天操av | 91热爆视频| 久久国产精品99精国产 | 国产黄色大全 | 亚洲最大av在线播放 | 亚洲一区久久久 | 亚洲一二区视频 | 亚洲午夜av久久乱码 | 97超碰在线久草超碰在线观看 | 色视频网站免费观看 | 99免费在线视频 | 国产 欧美 在线 | 开心激情综合网 | 最近高清中文在线字幕在线观看 | 色噜噜日韩精品一区二区三区视频 | 成人黄色电影在线观看 | 色的网站在线观看 | 中文字幕在线免费看线人 | 日韩精品久久久久久久电影竹菊 | 精品亚洲免费 | 99热手机在线观看 | 婷婷色在线视频 | 色婷婷国产 | 亚洲人天堂 | 久久免费国产精品 | 免费看黄电影 | 久久精品一区二区三区中文字幕 | 日韩在线电影一区二区 | 黄色大片网 | av网站有哪些 | 91看成人| 欧美日韩在线观看视频 | 亚洲欧美激情精品一区二区 | 一级黄色毛片 | 国产精品久久久一区二区 | 极品久久久久久久 | 男女精品久久 | 麻豆 videos| 天天爽人人爽 | 成人一区二区三区在线观看 | 麻豆小视频在线观看 | 中文在线免费视频 | 日韩在线观看网站 | 免费色视频在线 | 超碰999| 蜜桃麻豆www久久囤产精品 | 丁香六月色 | 久久久久一区二区三区四区 | 亚洲精品久久久久久久蜜桃 | 三级在线视频观看 | 一区二区三区中文字幕在线观看 | 免费视频你懂得 | 69人人| 色综合久| 激情视频区 | 国产综合香蕉五月婷在线 | 亚洲男男gaygay无套同网址 | 国产成人一二三 | 久久婷婷一区二区三区 | 日韩视频一区二区在线观看 | 久久国产影院 | 99久久综合狠狠综合久久 | 久久久国产影视 | 亚洲综合成人在线 | 亚洲在线黄色 | 制服丝袜一区二区 | 日日摸日日添夜夜爽97 | 麻豆一区在线观看 | 一区二区三区四区在线免费观看 | 麻豆国产在线播放 | 国产福利91精品 | 亚洲精品成人av在线 | 午夜日b视频 | 日韩欧美在线综合网 | 日日躁夜夜躁xxxxaaaa | 91麻豆精品国产自产在线 | 亚洲国产视频在线 | 911香蕉视频 | 91视频网址入口 | 三级黄色欧美 | 精品国产乱码一区二 | 欧美久久成人 | 精品国产一区二区三区在线观看 | 丁香色婷| 久草视频免费在线观看 | 91丨九色丨国产女 | 免费看片网页 | 久久成人一区 | 97精品免费视频 | 欧美国产在线看 | 狠狠狠干狠狠 | 999精品视频 | 欧美巨乳波霸 | 久久久久久久免费看 | 精品久久久国产 | 视频国产在线观看18 | 日韩精品一区二区三区水蜜桃 | 国产91精品一区二区麻豆网站 | 国产1区2区3区在线 亚洲自拍偷拍色图 | 亚洲小视频在线 | 亚洲蜜桃在线 | 婷婷五情天综123 | 免费欧美 | 中文字幕高清 | 国产人成看黄久久久久久久久 | 欧美日bb| 国产免费国产 | 黄色网www| 国产在线播放一区二区三区 | 国产精品igao视频网入口 | 中文字幕有码在线观看 | jizzjizzjizz亚洲| 国产高清99| 91在线看黄 | 国产精品粉嫩 | 日韩电影在线观看中文字幕 | 91色国产 | 日韩免费观看高清 | 日韩电影一区二区三区在线观看 | 一区二区三区久久精品 | 日韩精品播放 | 伊人狠狠色丁香婷婷综合 | 久久久久久久久亚洲精品 | 欧美一性一交一乱 | 久久精品99久久久久久2456 | 日日爱999| 黄色免费观看网址 | 精品久久久精品 | 亚洲天天综合网 | 69av视频在线| 亚洲电影第一页av | 91一区二区三区久久久久国产乱 | 免费合欢视频成人app | 三级黄免费看 | 五月亚洲| 99热在线精品观看 | 久久久久久网站 | 激情视频91 | 国产资源 | 日韩成人不卡 | 天天爱天天干天天爽 | 久久超碰99| 日韩精品欧美精品 | 中文字幕观看在线 | 欧美成人精品欧美一级乱黄 | 在线观看黄色 | 97超碰人人爱| 中文国产在线观看 | 国产精品porn | 日本激情视频中文字幕 | 精品在线观看国产 | 黄色网址在线播放 | 国产一区自拍视频 | 亚洲午夜激情网 | 色综合婷婷久久 | 黄色毛片一级片 | 黄色动态图xx | 黄色在线网站噜噜噜 | 91亚色视频在线观看 | 久久深夜福利免费观看 | 国产精品久久久久久久久久久久冷 | 在线观看精品一区 | 在线观看免费中文字幕 | 久久久久久久免费 | 日韩av一区二区三区 | 亚洲综合视频在线 | www.天天射.com | 中文字幕第| 日韩中文在线电影 | 国产一级性生活 | 久久久久国产精品一区 | 97超碰国产精品女人人人爽 | 欧美不卡在线 | 中日韩欧美精彩视频 | 免费观看一级成人毛片 | 丝袜+亚洲+另类+欧美+变态 | 2024国产精品视频 | 久草在线观看视频免费 | 国产精品一区二区麻豆 | 日韩av午夜 | 久久免费看视频 | 欧美日韩免费在线视频 | 欧美日韩视频在线观看免费 | 国产亚洲欧美精品久久久久久 | 丁香六月国产 | 麻豆影视在线观看 | 免费a v网站 | 一区二区三区 中文字幕 | 日韩在线小视频 | 久久久999免费视频 日韩网站在线 | 四虎4hu永久免费 | 久久久久国产精品午夜一区 | 成人视屏免费看 | www.成人sex| 天天爽人人爽夜夜爽 | 国产91精品久久久久久 | 国产精品国产三级国产专区53 | 99久久99久久精品免费 | 激情网五月婷婷 | 亚洲狠狠 | 91欧美日韩国产 | 国产视频不卡一区 | 最近乱久中文字幕 | 午夜视频99 | 在线观看视频亚洲 | 超碰97在线看| 啪啪免费视频网站 | 午夜美女wwww | 2018好看的中文在线观看 | 色wwww| 国产视频在 | 麻豆成人精品视频 | 国产精品免费一区二区三区在线观看 | 少妇搡bbbb搡bbb搡忠贞 | 日韩精品不卡 | 欧美性春潮 | 欧美精品一区在线 | 久久草在线精品 | 国模一二三区 | 国产一级久久 | 久草青青在线观看 | 精品视频在线免费 | 久久精品视频在线播放 | 日日夜夜精品网站 | 黄色网址在线播放 | 欧美一级激情 | 亚洲自拍偷拍色图 | zzijzzij日本成熟少妇 | 五月婷婷在线视频观看 | 亚洲影院一区 | 国产成人一区二区三区久久精品 | 一区二区视频网站 | 一级欧美一级日韩 | 黄色av观看| 日韩在线视频播放 | 免费在线观看视频一区 | 在线色亚洲| 日韩系列 | 国产精品乱码久久久 | 久久久久综合视频 | 91香蕉视频 mp4 | 久久99精品一区二区三区三区 | 免费性网站 | 国内视频| 国产精品完整版 | 国产一区在线精品 | 成人黄色小说在线观看 | 色久五月 | 国外调教视频网站 | 99热在线这里只有精品 | 一色av | 九九热只有这里有精品 | 日日干激情五月 | 在线免费观看不卡av | 偷拍久久久 | 好看av在线| 国产成人精品999 | 在线蜜桃视频 | 欧美性生交大片免网 | 国产高清综合 | 日韩精品在线看 | 国产精品综合在线 | 69国产成人综合久久精品欧美 | 美女久久视频 | 日韩精品一区二区三区免费观看视频 | 国产一区播放 | 狠狠干网址 | 欧美日韩性视频 | 日本最新中文字幕 | 超碰在线人 | 久久视频6| 久草免费在线视频 | 中日韩欧美精彩视频 | 在线免费精品视频 | 久久国产99 | 超碰97在线看 | 欧美性生活久久 | 在线国产视频观看 | 成人中文字幕av | 国产精品美女毛片真酒店 | 亚洲一级片在线看 | a黄色大片 | 中文字幕丝袜美腿 | 在线天堂中文在线资源网 | 久久久久久蜜桃一区二区 | 在线一级片 | 日韩二区精品 | 亚洲日本激情 | 国产手机免费视频 | 久久久国产一区 | 久久99久久久久久 | 日韩免费视频一区二区 | 久久综合九色综合欧美就去吻 | 一区二区三区在线播放 | 6080yy午夜一二三区久久 | 精品成人在线 | 久久在线观看 | 国产精品原创av片国产免费 | 99草视频| 九九热免费观看 | 国产一区视频免费在线观看 | 国产日韩欧美在线影视 | 日韩a级黄色 | 日韩.com | 国产成人a亚洲精品v | 99精品在线观看视频 | 99久久99久久精品国产片 | 日日天天 | 欧美老女人xx | 日韩国产高清在线 | 久久综合网色—综合色88 | 国产精品91一区 | www.亚洲在线| 国产97色| bbw av | 日本精品久久久久中文字幕5 | 国产精品一区二区久久精品爱微奶 | 视频一区二区免费 | 国产精品欧美久久久久天天影视 | 国产99一区视频免费 | 国产午夜三级一区二区三桃花影视 | 国产一级性生活视频 | 麻豆免费精品视频 | 高潮毛片无遮挡高清免费 | 一级黄色免费 | 国产污视频在线观看 | 亚洲九九影院 | 最近最新最好看中文视频 | 国产伦理精品一区二区 | 九九av | 狠狠天天| 午夜精品视频一区 | 五月婷婷开心中文字幕 | 亚洲小视频在线观看 | 五月激情电影 | 日韩欧美中文 | 欧美精品在线一区二区 | 日韩av一卡二卡三卡 | 国产午夜一区二区 | 丁香激情综合久久伊人久久 | 99热只有精品在线观看 | 天天色天天射天天操 | 天天综合网入口 | 亚洲最新av在线网站 | 国产成人精品999 | 国产精品18久久久久vr手机版特色 | 奇人奇案qvod | 国产精品观看在线亚洲人成网 | 久久久久国产一区二区三区四区 | 日韩一级片网址 | 午夜国产一区二区三区四区 | 国产精品一区二区三区在线 | 91成人在线网站 | 国内精品小视频 | 免费99| 欧美日韩一区久久 | 中国一级片在线观看 | 97超碰资源| 精品国自产在线观看 | 免费成视频 | 在线日韩中文字幕 | 色综合久久88色综合天天 | 久久免费视频5 | 黄色毛片视频免费观看中文 | 国产字幕在线观看 | 91九色精品女同系列 | 久久色网站 | 日韩黄色中文字幕 | 亚洲最新在线视频 | 三上悠亚在线免费 | 亚洲婷婷综合色高清在线 | www.在线观看视频 | 日本精品免费看 | 日本三级吹潮在线 | 国产特级毛片aaaaaaa高清 | 91视频国产高清 | 婷婷久久综合九色综合 | 一区二区精品在线 | 免费成人结看片 | 狠狠色噜噜狠狠狠 | 国产1区2区3区在线 亚洲自拍偷拍色图 | 美女在线免费视频 | 麻豆 91 在线 | 亚洲最新av网址 | 操夜夜操 | 国产色视频网站2 | 一级α片免费看 | 国产91aaa| 在线观看小视频 | 久久99这里只有精品 | 一区二区中文字幕在线观看 | 色婷婷狠狠五月综合天色拍 | 999久久久免费精品国产 | 免费看日韩 | 欧美日韩精品网站 | 黄色成人在线 | 亚洲精品在线视频播放 | 亚洲区视频在线 | 人人草人 | 欧美成a人片在线观看久 | 欧美日韩精品在线免费观看 | 亚洲在线免费视频 | 亚洲91精品 | 国产精美视频 | 日韩av中文字幕在线 | 精品一区二区免费视频 | 久久精品国产精品亚洲 | 久久精品欧美视频 | a色视频| 在线日本看片免费人成视久网 | 国产又黄又猛又粗 | 国产成在线观看免费视频 | 中文字幕日韩精品有码视频 | 国产黄色精品在线 | 超碰在线9 | 成人性生爱a∨ | 成人国产精品一区 | 亚洲人成人在线 | 成人免费共享视频 | 午夜精品一区二区国产 | 欧美日韩另类在线观看 | 99视频在线精品国自产拍免费观看 | 国产精品普通话 | 婷婷在线网 | 伊人婷婷综合 | 久99久在线视频 | 成人免费大片黄在线播放 | av女优中文字幕在线观看 | 精品视频成人 | 91亚洲影院 | 日韩高清在线一区二区 | 国产精品乱码久久久久久1区2区 | 久久久久久久久久久黄色 | 中文字幕日韩高清 | www色婷婷com | 五月婷婷影院 | 国产午夜三级一区二区三 | 九九九九精品九九九九 | 韩国一区在线 | 日韩二三区 | 操操操操网 | 国产在线观看xxx | 精品女同一区二区三区在线观看 | 日本系列中文字幕 | 色在线网| 99视频精品全部免费 在线 | 日韩激情在线视频 | 97视频在线观看播放 | 91精品国自产在线偷拍蜜桃 | 天天综合网天天 | 久久精品79国产精品 | 久久久久影视 | 久久,天天综合 | wwwwww国产 | 欧美国产日韩一区二区 | 97在线观看免费高清 | 999久久久免费视频 午夜国产在线观看 | 国产 日韩 欧美 中文 在线播放 | 国产久视频| 国产日本亚洲 | 国产精品福利在线 | 亚洲激情av | 深夜免费福利在线 | 在线天堂中文www视软件 | 国产精品一区二区 91 | 久草在在线 | 国产一区二区在线免费视频 | 超碰av在线免费观看 | 国产在线91在线电影 | 国产91免费在线观看 | 久久久免费 | 激情综合色播五月 | 深爱婷婷激情 | 99爱视频| 婷婷日 | 欧美久久久久久久久久 | 国产成人精品在线 | 精品a视频| 永久免费视频国产 | 91九色成人蝌蚪首页 | 97在线观看免费高清完整版在线观看 | 国产精品久久久久婷婷 | 色在线免费 | av导航福利 | 欧美一级片免费播放 | 国产精品18毛片一区二区 | 天天射天天搞 | 久久躁日日躁aaaaxxxx | 日韩成人免费在线观看 | 久久久久伦理电影 | 九九交易行官网 | 国产成人久久久久 | 国产一区二区视频在线 | 黄色软件在线观看免费 | 香蕉视频在线视频 | 日韩在线视频在线观看 | 日本最新一区二区三区 | 波多野结衣久久资源 | 在线观看黄网站 | 免费在线观看污网站 | 在线观看视频在线 | 久艹视频免费观看 | 精品天堂av | 日韩免费一区二区在线观看 | 久久综合九色综合欧美就去吻 | 国产人成看黄久久久久久久久 | 五月天国产 | 99 精品 在线 | www.久久视频| 91麻豆精品国产午夜天堂 | 久久你懂得 | 深爱五月网 | 99久久这里有精品 | 亚洲精品国产视频 | 精品视频久久 | 中文字幕制服丝袜av久久 | 久草久草久草久草 | 久久久人人人 | 色婷婷骚婷婷 | 一级理论片在线观看 | 国产精品久久久久久久久久久久午 | 国产一级a毛片视频爆浆 | 日女人电影 | 久久成熟 | 9久久精品| 色99导航| 日日日视频 | 最近中文字幕久久 | 色噜噜日韩精品一区二区三区视频 | 亚洲mv大片欧洲mv大片免费 | 欧美极品xxx | 伊人丁香 | 久久久久这里只有精品 | 日韩电影在线一区二区 | 四虎国产精品成人免费4hu | 日韩欧美电影网 | 伊人日日干| 草久在线播放 | 国产精品视频全国免费观看 | 天天色天天色 | 欧美精品xxx | 成人亚洲综合 | 99精品国产兔费观看久久99 | 国产一区二区久久 | 超碰人人在线观看 | 亚洲天堂香蕉 | 九9热这里真品2 | 天天操夜夜操国产精品 | 国产精品系列在线 | 天天爽天天做 | 色综合久久久久综合体 | 91看成人| av性网站| 99久热在线精品视频成人一区 | av黄色亚洲 | 久久免费成人精品视频 | 久久久av电影 | 在线观看视频你懂得 | 国产精品永久在线 | 国产成人精品一区二区三区福利 | 在线视频1卡二卡三卡 | 国产成人一区二区三区 | 2020天天干天天操 | 最新av网址在线 | 在线观看国产一区二区 | 国产精品九色 | 99re国产视频| 成人av免费在线 | 天天操天天操天天干 | 制服丝袜一区二区 | 九九九热精品 | 高清av中文字幕 | 国产一区二区免费看 | 麻豆91精品91久久久 | 黄色一级大片在线免费看产 | 久久不见久久见免费影院 | 欧美另类视频 | 免费av网址大全 | 麻豆视频国产在线观看 | 国内精品免费 | 三级黄色理论片 | 啪嗒啪嗒免费观看完整版 | 在线精品视频免费观看 | 国内精品久久久久久久久久 | 人人模人人爽 | 91精品国产91 | 91中文在线| 一级片免费观看 | 亚洲成a人片在线观看中文 中文字幕在线视频第一页 狠狠色丁香婷婷综合 | 99久久99精品| 国产精品一区二区免费视频 | 狠狠色丁香婷婷综合久久片 | 国产黄网站在线观看 | 成人精品999 | 中文字幕 成人 | 日b黄色片 | 久久久国产一区二区三区四区小说 | 亚洲一二三区精品 | 美腿丝袜一区二区三区 | 久久爽久久爽久久av东京爽 | 在线观看日韩一区 | www五月 | va视频在线观看 | 亚洲蜜桃av | 91精品国自产拍天天拍 | 黄av资源 | 免费看一级特黄a大片 | 国产在线精品一区二区 | 亚洲最大免费成人网 | 丝袜美女在线 | 成人影视免费 | 婷婷六月综合网 | 99精品国产99久久久久久福利 | 激情五月播播久久久精品 | 97精品国产97久久久久久 | 亚洲精品www久久久 www国产精品com | 国产亚洲精品久久久久动 | 亚洲区另类春色综合小说 | www.夜夜操.com | 天天做天天射 | 久久人人爽爽人人爽人人片av | 欧美一区二区免费在线观看 | 在线观看视频在线 | zzijzzij亚洲日本少妇熟睡 | 亚洲一区二区视频在线 | 亚洲国产成人久久综合 | 国产精品久久久免费 | 国产在线观看一区 | 久久高清视频免费 | www.天天操| 午夜影院在线观看18 | 国产视频九色蝌蚪 | 天天色天天上天天操 | 91激情| 黄色电影在线免费观看 | 又黄又色又爽 | 黄色小视频在线观看免费 | 国产va在线| 亚洲一二区视频 | 成人在线视频你懂的 | 国产精品久久精品 | 日韩三级视频在线看 | 国精产品一二三线999 | 婷婷丁香色 | 日日操天天爽 | 麻豆一级视频 | 国内精品久久久久影院一蜜桃 | 69亚洲视频 | 欧美乱码精品一区二区 | 一区二区久久久久 | 国产精品一区二区三区在线看 | 国产护士hd高朝护士1 | 免费又黄又爽 | 粉嫩av一区二区三区四区在线观看 | 久久综合九色欧美综合狠狠 | 日韩精品专区 | 九九九九热精品免费视频点播观看 | 蜜臀久久99精品久久久无需会员 | av免费网站| 亚洲伊人天堂 | 婷婷黄色片| 18av在线视频 | 午夜在线国产 | 五月天久久久久久 | 人人澡超碰碰97碰碰碰软件 | 国产精品福利午夜在线观看 | 在线观看黄色av | 伊人电影在线观看 | 久草免费在线观看视频 | 亚洲国产精彩中文乱码av | 激情婷婷综合 | 很污的网站 | 日韩免费精品 | 天天撸夜夜操 | 91av大全 | 久久久久成人精品免费播放动漫 | 狠狠狠综合 | 亚洲精品tv久久久久久久久久 | 亚洲丁香久久久 | 欧美了一区在线观看 | 久久在线视频在线 | 久久久久成人精品免费播放动漫 | 欧美精品一区二区在线播放 | 国产在线2020 | 色网站免费在线观看 | 天天爱天天草 | 欧美嫩草影院 | 欧美一二三四在线 | 人人射网站| 久久久久成人精品亚洲国产 | 91视频一8mav| 四虎影视精品永久在线观看 | av观看在线观看 | 日韩中文字幕免费在线播放 | 深夜激情影院 | 片黄色毛片黄色毛片 | 成人午夜电影在线观看 | 亚洲免费不卡 | 国产视频不卡 | 日韩一区二区免费播放 | 成人蜜桃视频 | 成人黄色av网站 | av色影院 | 国产精品嫩草55av | 久久高视频| 91精品国产自产在线观看永久 | 伊人黄| 久久久精品国产一区二区 | 伊人导航 | 国产 日韩 在线 亚洲 字幕 中文 | 成人黄色片免费看 | 国产 日韩 欧美 在线 | 日韩欧美在线免费 | 国产精品成人久久 | 麻豆91在线观看 | 国产精品久久久久久久久久久久冷 | 成人网444ppp| 天天伊人狠狠 | 日本中文字幕观看 | 免费黄色在线网址 | 永久黄网站色视频免费观看w | 在线精品视频在线观看高清 | 99国产在线观看 | 国产精品久久在线 | 月下香电影 | 在线视频国产区 | 国产精品久久久久久电影 | 免费观看视频黄 | 中文字幕av在线 | 四虎最新域名 | 91观看视频| 五月视频 | 久久婷五月 | 国产黄在线免费观看 | 热久久免费视频 | 在线观看中文字幕一区二区 | 国产一级黄色电影 | 日韩在线观看的 | 成年人免费观看在线视频 | 国产成人久久av977小说 | a级国产乱理伦片在线播放 久久久久国产精品一区 | 玖草影院| 中文字幕丰满人伦在线 | 在线视频日韩欧美 | 天天摸夜夜操 | 91丨九色丨蝌蚪丨老版 | 免费观看日韩 | 久久综合亚洲鲁鲁五月久久 | 国产96在线视频 | 国产精品永久久久久久久www | 五月婷社区 | 久久乱码卡一卡2卡三卡四 五月婷婷久 | 就操操久久 | 婷婷电影网| 久久精品国产一区二区三区 | 国产99久久久精品视频 | 久久久免费观看视频 | 免费的成人av | 日韩欧美一二三 | 激情综合啪 | 亚洲一区二区视频在线播放 | 天天射天天爽 | 国产区免费在线 | 中文字幕成人在线观看 | 久久久精品国产一区二区 | 黄色a在线 | 天天干夜夜爱 | 99亚洲国产| 国产精品一区二区三区久久久 | 丁香五月亚洲综合在线 | 天天操天天操天天操天天操天天操 | 激情久久婷婷 | 天天射天 | 久久手机精品视频 | 中文区中文字幕免费看 | 天天艹日日干 | 国产精品久久久久9999吃药 | 日韩免费电影一区二区三区 | av一级久久 | 久久精品一区二区三区视频 | 久久影视网 | 中文字幕一区2区3区 | 日韩欧美精品在线 | 97爱爱爱| 丁香5月婷婷 | jizz欧美性9 国产一区高清在线观看 | 丁香五香天综合情 | 色妞久久福利网 | 草久久影院 | 97精品国产97久久久久久久久久久久 | 亚洲黄色网络 | 欧美精品亚洲二区 | 久草免费福利在线观看 | 91看片黄色| 在线免费91 | 国产精品av久久久久久无 | 国产在线观看xxx | 一本—道久久a久久精品蜜桃 | 久久久av免费| 国产视频黄 | 日本色小说视频 | 欧美日韩视频在线观看免费 | 日韩欧美在线一区 | 午夜电影一区 | 成年人电影毛片 | av久久在线 | 亚洲国产精品99久久久久久久久 | 欧美一区免费观看 | 日韩丝袜| 最新av在线播放 | 精品免费 | 成人av网站在线观看 | 国产成人亚洲在线观看 | 免费视频久久久久 | 天天干中文字幕 | 一本一道久久a久久精品蜜桃 | 欧美少妇的秘密 | 久久爱综合 | 久久精品视频国产 | 精品久久1 | 黄色软件视频大全免费下载 | 天天干天天射天天插 | 91在线中字| 国产美女被啪进深处喷白浆视频 | 精品在线视频观看 | 国产精品久久久久av福利动漫 | 一区二区久久 | 色婷婷av一区| 91天堂素人约啪 | 超级碰碰免费视频 | 久久深夜福利免费观看 | 怡红院av久久久久久久 | 久久五月婷婷丁香社区 | 在线看黄色av | 特级西西444www高清大视频 | 精品主播网红福利资源观看 | 久久短视频| 久久久久亚洲精品男人的天堂 | 尤物一区二区三区 | 四虎影视成人精品国库在线观看 | 久久久久久久久久久久久国产精品 | 国产色 在线 | 尤物一区二区三区 | 九九热精 | 久久免费高清 | 国产又黄又爽又猛视频日本 | 精品国产一区二区三区久久久 | 亚洲国产成人av网 | 久久久免费网站 | 国产青青青 | 亚洲国产午夜视频 |