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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

kafka 主动消费_Kafka核心API——Consumer消费者

發布時間:2025/3/15 编程问答 56 豆豆
生活随笔 收集整理的這篇文章主要介紹了 kafka 主动消费_Kafka核心API——Consumer消费者 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Consumer之自動提交

在上文中介紹了Producer API的使用,現在我們已經知道如何將消息通過API發送到Kafka中了,那么現在的生產者/消費者模型就還差一位扮演消費者的角色了。因此,本文將介紹Consumer API的使用,使用API從Kafka中消費消息,讓應用成為一個消費者角色。

還是老樣子,首先我們得創建一個Consumer實例,并指定相關配置項,有了這個實例對象后我們才能進行其他的操作。代碼示例:

/**

* 創建Consumer實例

*/

public static Consumer createConsumer() {

Properties props = new Properties();

// 指定Kafka服務的ip地址及端口

props.setProperty(ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG, "127。0.0.1:9092");

// 指定group.id,Kafka中的消費者需要在消費者組里

props.setProperty(ConsumerConfig.GROUP_ID_CONFIG, "test");

// 是否開啟自動提交

props.setProperty(ConsumerConfig.ENABLE_AUTO_COMMIT_CONFIG, "true");

// 自動提交的間隔,單位毫秒

props.setProperty(ConsumerConfig.AUTO_COMMIT_INTERVAL_MS_CONFIG, "1000");

// 消息key的序列化器

props.setProperty(ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG,

"org.apache.kafka.common.serialization.StringDeserializer");

// 消息value的序列化器

props.setProperty(ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG,

"org.apache.kafka.common.serialization.StringDeserializer");

return new KafkaConsumer<>(props);

}

在以上代碼中,可以看到設置了group.id這個配置項,這是一個Consumer的必要配置項,因為在Kafka中,Consumer需要位于一個Consumer Group里。具體如下圖所示:

在上圖中是一個Consumer消費一個Partition,是一對一的關系。但Consumer Group里可以只有一個Consumer,此時該Consumer可以消費多個Partition,是一對多的關系。如下圖所示:

一個Consumer可以只消費一個Partition,也可以消費多個Partition,但需要注意的是多個Consumer不能消費同一個Partition:

總結一下Consumer的注意事項:

單個Partition的消息只能由Consumer Group中的某個Consumer來消費

Consumer從Partition中消費消息是順序的,默認從頭開始消費

如果Consumer Group中只有一個Consumer,那么這個Consumer會消費所有Partition中的消息

在Kafka中,當消費者消費數據后,需要提交數據的offset來告知服務端成功消費了哪些數據。然后服務端就會移動數據的offset,下一次消費的時候就是從移動后的offset位置開始消費。

這樣可以在一定程度上保證數據是被消費成功的,并且由于數據不會被刪除,而只是移動數據的offset,這也保證了數據不易丟失。若消費者處理數據失敗時,只要不提交相應的offset,就可以在下一次重新進行消費。

和數據庫的事務一樣,Kafka消費者提交offset的方式也有兩種,分別是自動提交和手動提交。在本例中演示的是自動提交,這也是消費數據最簡單的方式。代碼示例:

/**

* 演示自動提交offset

*/

public static void autoCommitOffset() {

Consumer consumer = createConsumer();

List topics = List.of("MyTopic");

// 訂閱一個或多個Topic

consumer.subscribe(topics);

while (true) {

// 從Topic中拉取數據,每1000毫秒拉取一次

ConsumerRecords records = consumer.poll(Duration.ofMillis(1000));

// 每次拉取可能都是一組數據,需要遍歷出來

for (ConsumerRecord record : records) {

System.out.printf("partition = %d, offset = %d, key = %s, value = %s%n",

record.partition(), record.offset(), record.key(), record.value());

}

}

}

Consumer之手動提交

自動提交的方式是最簡單的,但不建議在實際生產中使用,因為可控性不高。所以更多時候我們使用的是手動提交,但想要使用手動提交,就需要先關閉自動提交,修改配置項如下:

props.setProperty(ConsumerConfig.ENABLE_AUTO_COMMIT_CONFIG, "false");

關閉了自動提交后,就得在代碼中調用commit相關的方法來提交offset,主要就是兩個方法:commitAsync和commitSync,看方法名也知道一個是異步提交一個是同步提交。

這里以commitAsync為例,實現思路主要是在發生異常的時候不要調用commitAsync方法,而在正常執行完畢后才調用commitAsync方法。代碼示例:

/**

* 演示手動提交offset

*/

public static void manualCommitOffset() {

Consumer consumer = createConsumer();

List topics = List.of("MyTopic");

// 訂閱一個或多個Topic

consumer.subscribe(topics);

while (true) {

// 從Topic中拉取數據,每1000毫秒拉取一次

ConsumerRecords records = consumer.poll(Duration.ofMillis(1000));

// 每次拉取可能都是一組數據,需要遍歷出來

for (ConsumerRecord record : records) {

try {

// 模擬將數據寫入數據庫

Thread.sleep(1000);

System.out.println("save to db...");

System.out.printf("partition = %d, offset = %d, key = %s, value = %s%n",

record.partition(), record.offset(), record.key(), record.value());

} catch (Exception e) {

// 寫入失敗則不要調用commit,這樣就相當于起到回滾的作用,

// 下次消費還是從之前的offset開始消費

e.printStackTrace();

return;

}

}

// 寫入成功則調用commit相關方法去手動提交offset

consumer.commitAsync();

}

}

##針對Partition提交offset

在前文中有介紹到,一個Consumer Group里可以只有一個Consumer,該Consumer可以消費多個Partition。在這種場景下,我們可能會在Consumer中開啟多線程去處理多個Partition中的數據,以提高性能。

為了防止某些Partition里的數據消費成功,而某些Partition里的數據消費失敗,卻都一并提交了offset。我們就需要針對單個Partition去提交offset,也就是將offset的提交粒度控制在Partition級別。

這里先簡單演示一下如何針對單個Partition提交offset,代碼示例:

/**

* 演示手動提交單個Partition的offset

*/

public static void manualCommitOffsetWithPartition() {

Consumer consumer = createConsumer();

List topics = List.of("MyTopic");

// 訂閱一個或多個Topic

consumer.subscribe(topics);

while (true) {

// 從Topic中拉取數據,每1000毫秒拉取一次

ConsumerRecords records = consumer.poll(Duration.ofMillis(1000));

// 單獨處理每一個Partition中的數據

for (TopicPartition partition : records.partitions()) {

System.out.println("======partition: " + partition + " start======");

// 從Partition中取出數據

List> partitionRecords = records.records(partition);

for (ConsumerRecord record : partitionRecords) {

try {

// 模擬將數據寫入數據庫

Thread.sleep(1000);

System.out.println("save to db...");

System.out.printf("partition = %d, offset = %d, key = %s, value = %s%n",

record.partition(), record.offset(), record.key(), record.value());

} catch (Exception e) {

// 發生異常直接結束,不提交offset

e.printStackTrace();

return;

}

}

// 執行成功則取出當前消費到的offset

long lastOffset = partitionRecords.get(partitionRecords.size() - 1).offset();

// 由于下一次開始消費的位置是最后一次offset+1的位置,所以這里要+1

OffsetAndMetadata metadata = new OffsetAndMetadata(lastOffset + 1);

// 針對Partition提交offset

Map offsets = new HashMap<>();

offsets.put(partition, metadata);

// 同步提交offset

consumer.commitSync(offsets);

System.out.println("======partition: " + partition + " end======");

}

}

}

Consumer針對一個或多個Partition進行訂閱

在之前的例子中,我們都是針對Topic去訂閱并消費數據,實際上也可以更細粒度一些針對Partition進行訂閱,這通常應用在一個Consumer多線程消費的場景下。代碼示例:

/**

* 演示將訂閱粒度控制到Partition級別

* 針對單個或多個Partition進行訂閱

*/

public static void manualCommitOffsetWithPartition2() {

Consumer consumer = createConsumer();

// 該Topic中有兩個Partition

TopicPartition p0 = new TopicPartition("MyTopic", 0);

TopicPartition p1 = new TopicPartition("MyTopic", 1);

// 訂閱該Topic下的一個Partition

consumer.assign(List.of(p0));

// 也可以訂閱該Topic下的多個Partition

// consumer.assign(List.of(p0, p1));

while (true) {

...與上一小節中的代碼一致,略...

}

}

Consumer多線程并發處理

前面兩個小節的內容基本都是為了本小節所介紹的多線程并發處理消息而鋪墊的,因為為了提高應用對消息的處理效率,我們通常會使用多線程來并行消費消息,從而加快消息的處理速度。

而多線程處理消息的方式主要有兩種,一種是按Partition數量創建線程,然后每個線程里創建一個Consumer,多個Consumer對多個Partition進行消費。這就和之前在介紹Consumer Group時,給出的那張圖所展示的一樣:

這種屬于是經典模式,實現起來也比較簡單,適用于對消息的順序和offset控制有要求的場景。代碼示例:

package com.zj.study.kafka.consumer;

import org.apache.kafka.clients.consumer.ConsumerRecord;

import org.apache.kafka.clients.consumer.ConsumerRecords;

import org.apache.kafka.clients.consumer.KafkaConsumer;

import org.apache.kafka.clients.consumer.OffsetAndMetadata;

import org.apache.kafka.common.TopicPartition;

import org.apache.kafka.common.errors.WakeupException;

import java.time.Duration;

import java.util.Collections;

import java.util.List;

import java.util.Properties;

import java.util.concurrent.atomic.AtomicBoolean;

/**

* 經典模式

*

* @author 01

* @date 2020-05-21

**/

public class ConsumerThreadSample {

private final static String TOPIC_NAME = "MyTopic";

/**

* 這種類型是經典模式,每一個線程單獨創建一個KafkaConsumer,用于保證線程安全

*/

public static void main(String[] args) throws InterruptedException {

KafkaConsumerRunner r1 = new KafkaConsumerRunner();

Thread t1 = new Thread(r1);

t1.start();

Thread.sleep(15000);

r1.shutdown();

}

public static class KafkaConsumerRunner implements Runnable {

private final AtomicBoolean closed = new AtomicBoolean(false);

private final KafkaConsumer consumer;

public KafkaConsumerRunner() {

Properties props = new Properties();

props.put("bootstrap.servers", "192.168.220.128:9092");

props.put("group.id", "test");

props.put("enable.auto.commit", "false");

props.put("auto.commit.interval.ms", "1000");

props.put("session.timeout.ms", "30000");

props.put("key.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");

props.put("value.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");

consumer = new KafkaConsumer<>(props);

TopicPartition p0 = new TopicPartition(TOPIC_NAME, 0);

TopicPartition p1 = new TopicPartition(TOPIC_NAME, 1);

consumer.assign(List.of(p0, p1));

}

@Override

public void run() {

try {

while (!closed.get()) {

//處理消息

ConsumerRecords records = consumer.poll(Duration.ofMillis(10000));

for (TopicPartition partition : records.partitions()) {

List> pRecord = records.records(partition);

// 處理每個分區的消息

for (ConsumerRecord record : pRecord) {

System.out.printf("patition = %d , offset = %d, key = %s, value = %s%n",

record.partition(), record.offset(), record.key(), record.value());

}

// 返回去告訴kafka新的offset

long lastOffset = pRecord.get(pRecord.size() - 1).offset();

// 注意加1

consumer.commitSync(Collections.singletonMap(partition, new OffsetAndMetadata(lastOffset + 1)));

}

}

} catch (WakeupException e) {

if (!closed.get()) {

throw e;

}

} finally {

consumer.close();

}

}

public void shutdown() {

closed.set(true);

consumer.wakeup();

}

}

}

另一種多線程的消費方式則是在一個線程池中只創建一個Consumer實例,然后通過這個Consumer去拉取數據后交由線程池中的線程去處理。如下圖所示:

但需要注意的是在這種模式下我們無法手動控制數據的offset,也無法保證數據的順序性,所以通常應用在流處理場景,對數據的順序和準確性要求不高。

經過之前的例子,我們知道每拉取一次數據返回的就是一個ConsumerRecords,這里面存放了多條數據。然后我們對ConsumerRecords進行迭代,就可以將多條數據交由線程池中的多個線程去并行處理了。代碼示例:

package com.zj.study.kafka.consumer;

import org.apache.kafka.clients.consumer.ConsumerRecord;

import org.apache.kafka.clients.consumer.ConsumerRecords;

import org.apache.kafka.clients.consumer.KafkaConsumer;

import java.util.List;

import java.util.Properties;

import java.util.concurrent.ArrayBlockingQueue;

import java.util.concurrent.ExecutorService;

import java.util.concurrent.ThreadPoolExecutor;

import java.util.concurrent.TimeUnit;

/**

* 一個Consumer,多個hander模式

*

* @author 01

* @date 2020-05-21

**/

public class ConsumerRecordThreadSample {

private final static String TOPIC_NAME = "MyTopic";

public static void main(String[] args) throws InterruptedException {

String brokerList = "192.168.220.128:9092";

String groupId = "test";

int workerNum = 5;

ConsumerExecutor consumers = new ConsumerExecutor(brokerList, groupId, TOPIC_NAME);

consumers.execute(workerNum);

Thread.sleep(1000000);

consumers.shutdown();

}

/**

* Consumer處理

*/

public static class ConsumerExecutor {

private final KafkaConsumer consumer;

private ExecutorService executors;

public ConsumerExecutor(String brokerList, String groupId, String topic) {

Properties props = new Properties();

props.put("bootstrap.servers", brokerList);

props.put("group.id", groupId);

props.put("enable.auto.commit", "true");

props.put("auto.commit.interval.ms", "1000");

props.put("session.timeout.ms", "30000");

props.put("key.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");

props.put("value.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");

consumer = new KafkaConsumer<>(props);

consumer.subscribe(List.of(topic));

}

public void execute(int workerNum) {

executors = new ThreadPoolExecutor(workerNum, workerNum, 0L, TimeUnit.MILLISECONDS,

new ArrayBlockingQueue<>(1000), new ThreadPoolExecutor.CallerRunsPolicy());

while (true) {

ConsumerRecords records = consumer.poll(200);

for (final ConsumerRecord record : records) {

executors.submit(new ConsumerRecordWorker(record));

}

}

}

public void shutdown() {

if (consumer != null) {

consumer.close();

}

if (executors != null) {

executors.shutdown();

}

try {

if (executors != null && !executors.awaitTermination(10, TimeUnit.SECONDS)) {

System.out.println("Timeout.... Ignore for this case");

}

} catch (InterruptedException ignored) {

System.out.println("Other thread interrupted this shutdown, ignore for this case.");

Thread.currentThread().interrupt();

}

}

}

/**

* 記錄處理

*/

public static class ConsumerRecordWorker implements Runnable {

private ConsumerRecord record;

public ConsumerRecordWorker(ConsumerRecord record) {

this.record = record;

}

@Override

public void run() {

// 假如說數據入庫操作

System.out.println("Thread - " + Thread.currentThread().getName());

System.err.printf("patition = %d , offset = %d, key = %s, value = %s%n",

record.partition(), record.offset(), record.key(), record.value());

}

}

}

Consumer控制offset起始位置

上一小節中介紹的第二種多線程消息模式,通過Consumer拉取數據后交由多線程去處理是沒法控制offset的,如果此時程序出現錯誤或其他意外情況導致消息沒有被正確消費,我們就需要人為控制offset的起始位置重新進行消費。

通過調用seek方法可以指定從哪個Partition的哪個offset位置進行消費,代碼示例:

/**

* 手動控制offset的起始位置

*/

public static void manualCommitOffsetWithPartition2() {

Consumer consumer = createConsumer();

TopicPartition p0 = new TopicPartition("MyTopic", 0);

consumer.assign(List.of(p0));

// 指定offset的起始位置

consumer.seek(p0, 1);

while (true) {

...與上一小節中的代碼一致,略...

}

}

實際應用中的設計思路:

第一次從某個offset的起始位置進行消費

如果本次消費了100條數據,那么offset設置為101并存入Redis等緩存數據庫中

后續每次poll之前,從Redis中獲取offset值,然后從這個offset的起始位置進行消費

消費完后,再次將新的offset值存入Redis,周而復始

Consumer限流

為了避免Kafka中的流量劇增導致過大的流量打到Consumer端將Consumer給壓垮的情況,我們就需要針對Consumer進行限流。例如,當處理的數據量達到某個閾值時暫停消費,低于閾值時則恢復消費,這就可以讓Consumer保持一定的速率去消費數據,從而避免流量劇增時將Consumer給壓垮。大體思路如下:

在poll到數據之后,先去令牌桶中拿取令牌

如果獲取到令牌,則繼續業務處理

如果獲取不到令牌,則調用pause方法暫停Consumer,等待令牌

當令牌桶中的令牌足夠,則調用resume方法恢復Consumer的消費狀態

接下來編寫具體的代碼案例簡單演示一下這個限流思路,令牌桶算法使用Guava里內置的,所以需要在項目中添加對Guava的依賴。添加的依賴項如下:

com.google.guava

guava

29.0-jre

然后我們就可以使用Guava的限流器對Consumer進行限流了,代碼示例:

public class ConsumerCurrentLimiting {

/*** 令牌生成速率,單位為秒 */

public static final int permitsPerSecond = 1;

/*** 限流器 */

private static final RateLimiter LIMITER = RateLimiter.create(permitsPerSecond);

/**

* 創建Consumer實例

*/

public static Consumer createConsumer() {

... 與之前小節的代碼類似,略 ...

}

/**

* 演示對Consumer限流

*/

public static void currentLimiting() {

Consumer consumer = createConsumer();

TopicPartition p0 = new TopicPartition("MyTopic", 0);

TopicPartition p1 = new TopicPartition("MyTopic", 1);

consumer.assign(List.of(p0, p1));

while (true) {

// 從Topic中拉取數據,每100毫秒拉取一次

ConsumerRecords records = consumer.poll(Duration.ofMillis(1));

if (records.isEmpty()) {

continue;

}

// 限流

if (!LIMITER.tryAcquire()) {

System.out.println("無法獲取到令牌,暫停消費");

consumer.pause(List.of(p0, p1));

} else {

System.out.println("獲取到令牌,恢復消費");

consumer.resume(List.of(p0, p1));

}

// 單獨處理每一個Partition中的數據

for (TopicPartition partition : records.partitions()) {

System.out.println("======partition: " + partition + " start======");

// 從Partition中取出數據

List> partitionRecords = records.records(partition);

for (ConsumerRecord record : partitionRecords) {

try {

// 模擬將數據寫入數據庫

Thread.sleep(1000);

System.out.println("save to db...");

System.out.printf("partition = %d, offset = %d, key = %s, value = %s%n",

record.partition(), record.offset(), record.key(), record.value());

} catch (Exception e) {

// 發生異常直接結束,不提交offset

e.printStackTrace();

return;

}

}

// 執行成功則取出當前消費到的offset

long lastOffset = partitionRecords.get(partitionRecords.size() - 1).offset();

// 由于下一次開始消費的位置是最后一次offset+1的位置,所以這里要+1

OffsetAndMetadata metadata = new OffsetAndMetadata(lastOffset + 1);

// 針對Partition提交offset

Map offsets = new HashMap<>();

offsets.put(partition, metadata);

// 同步提交offset

consumer.commitSync(offsets);

System.out.println("======partition: " + partition + " end======");

}

}

}

public static void main(String[] args) {

currentLimiting();

}

}

Consumer Rebalance解析

Consumer有個Rebalance的特性,即重新負載均衡,該特性依賴于一個協調器來實現。每當Consumer Group中有Consumer退出或有新的Consumer加入都會觸發Rebalance。

之所以要重新負載均衡,是為了將退出的Consumer所負責處理的數據再重新分配到組內的其他Consumer上進行處理。或當有新加入的Consumer時,將組內其他Consumer的負載壓力,重新進均勻分配,而不會說新加入一個Consumer就閑在那。

下面就用幾張圖簡單描述一下,各種情況觸發Rebalance時,組內成員是如何與協調器進行交互的。

1、新成員加入組(member join):

Tips:圖中的Coordinator是協調器,而generation則類似于樂觀鎖中的版本號,每當成員入組成功就會更新,也是起到一個并發控制的作用

2、組成員崩潰/非正常退出(member failure):

3、組成員主動離組/正常退出(member leave group):

4、當Consumer提交位移(member commit offset)時,也會有類似的交互過程:

總結

以上是生活随笔為你收集整理的kafka 主动消费_Kafka核心API——Consumer消费者的全部內容,希望文章能夠幫你解決所遇到的問題。

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

91精品在线免费观看视频 | 国产免费黄色 | 91视频网址入口 | 国产日韩精品在线观看 | 免费看十八岁美女 | 久久久久久美女 | 日本精品久久久久 | 亚洲国产精品500在线观看 | 麻豆传媒视频在线免费观看 | 丁香在线观看完整电影视频 | av成人免费 | 日韩精品免费在线观看 | 99这里只有久久精品视频 | 精品一区二区在线播放 | 99精品欧美一区二区三区黑人哦 | 激情欧美一区二区三区 | 日韩av在线免费看 | 男女免费av| 国产精品一区二区麻豆 | 国产在线色站 | 久久久久久电影 | 精选久久 | 国产999在线 | 免费欧美精品 | 五月婷婷av在线 | 国产日韩中文字幕在线 | 亚洲蜜桃在线 | 天天五月天色 | 日韩字幕 | 中文在线a√在线 | 欧洲精品在线视频 | 岛国一区在线 | 久久夜靖品 | 欧美男女爱爱视频 | 草在线视频 | 三级av片 | 久操操| 国产成人福利在线观看 | 99精品欧美一区二区 | va视频在线观看 | 免费观看成人av | 亚洲精品在线观看网站 | 亚洲一区二区三区毛片 | 久久精品一级片 | 日韩精品电影在线播放 | 色婷婷免费视频 | 高清av中文在线字幕观看1 | 国产精品一区二区三区四区在线观看 | 国产精品成人免费一区久久羞羞 | 欧美在线你懂的 | 中文字幕国产亚洲 | 在线观看免费黄视频 | 中文字幕精品三区 | 一区二区三区在线免费 | 欧美一级片在线免费观看 | 久久婷婷色综合 | 色综合久久久久综合体桃花网 | 大荫蒂欧美视频另类xxxx | 日韩天天干 | av网站免费线看精品 | 日日夜夜狠狠 | 成人午夜在线电影 | 国产91综合一区在线观看 | 手机在线永久免费观看av片 | 免费日韩视频 | 99热日本| 中文字幕一区二区三区乱码在线 | 亚洲乱码在线观看 | 91污污视频在线观看 | 免费av在线网 | 久久精品一区二 | 久青草国产在线 | 亚洲三级av | 色婷婷88av视频一二三区 | 婷婷丁香狠狠爱 | 成人av一二三区 | 成人资源网 | 国产黄色片在线免费观看 | 精品国产理论 | 中文字幕第一页在线播放 | www免费看片com| www.精选视频.com | 人人舔人人 | 亚洲激情| 久久99精品久久久久蜜臀 | 日韩网站在线观看 | 超碰97中文 | 成人高清在线观看 | 伊人射 | 天堂av在线免费观看 | 91高清完整版在线观看 | 国产高清永久免费 | 激情欧美国产 | 女人18毛片90分钟 | 夜夜操天天 | 欧美成人tv | 色噜噜日韩精品一区二区三区视频 | 五月婷婷视频 | 黄色大片免费网站 | 精品国产乱码一区二 | 亚洲91网站 | a黄色一级片 | 久久久精品一区二区三区 | 在线免费观看视频一区二区三区 | 欧洲精品在线视频 | 91在线色| 在线观看亚洲电影 | 欧美性生活免费看 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 婷婷综合电影 | av中文字幕在线免费观看 | 九九电影在线 | 久久手机免费视频 | 婷婷国产一区二区三区 | 91九色丨porny丨丰满6 | 日日干精品 | 国产成人精品综合久久久 | 999久久久久久久久 69av视频在线观看 | 九九激情视频 | 97成人精品 | 亚洲综合情 | 精品国产自 | 日韩av不卡在线播放 | 亚洲午夜av久久乱码 | 丰满少妇久久久 | 欧美片一区二区三区 | 精品一区精品二区高清 | 婷婷丁香狠狠爱 | 韩国精品福利一区二区三区 | 草久视频在线观看 | 婷婷六月中文字幕 | 人人澡人人爽欧一区 | 欧美另类美少妇69xxxx | 亚洲第一久久久 | 亚洲欧美国产精品久久久久 | 在线观看91精品视频 | 久久综合给合久久狠狠色 | 中文字幕高清有码 | 成人午夜精品福利免费 | 国际精品久久 | 在线观看成人 | 天天操狠狠干 | 日日夜夜噜 | 久久久午夜视频 | 国产一区成人在线 | 丝袜美腿在线视频 | 91精品国产综合久久福利不卡 | 久久久久久久久久久免费av | 久久福利国产 | 四川妇女搡bbbb搡bbbb搡 | 美女国内精品自产拍在线播放 | 99精品视频在线播放观看 | 亚洲日韩欧美一区二区在线 | 婷婷新五月 | 日韩黄色免费在线观看 | www.狠狠插.com| 日本久久久影视 | 人人cao| 国产精品久久久久久久久久久久午夜 | 国产我不卡 | 久久99精品久久久久久秒播蜜臀 | 国产精品成人久久 | 天天射色综合 | 看v片| 波多野结衣视频一区二区三区 | 亚洲精品在线看 | 国产福利91精品一区二区三区 | 在线观看视频精品 | 黄色av成人在线观看 | 国产成人一区二区三区免费看 | 免费福利在线观看 | 91中文在线视频 | 日本黄色免费在线 | 国产精品黄色av | 91日韩在线视频 | 国产成人精品国内自产拍免费看 | 午夜av不卡 | 麻豆视频国产精品 | 一区二区不卡视频在线观看 | 国产福利一区二区在线 | 天天久久综合 | 亚洲h在线播放在线观看h | 狠狠狠狠狠狠干 | 国产精品毛片一区二区在线 | 亚洲日本欧美在线 | 成人影视免费 | 亚洲人成人在线 | 综合网久久 | 免费看的av片| 天天操操 | 国产精品久久久久一区二区三区 | 日韩视频免费观看高清 | 九九九在线观看 | 91视频在线免费下载 | 国产精品专区在线 | 狠狠色狠狠色终合网 | 婷婷五月在线视频 | 亚洲成人av免费 | 亚洲精品在线免费播放 | 日批网站在线观看 | 国产精品毛片一区二区 | 亚洲综合成人在线 | 欧美精品一区二区三区一线天视频 | 国产精品免费在线播放 | 亚洲在线a | 国产专区日韩专区 | 西西4444www大胆无视频 | 国产亚洲免费的视频看 | 性色av一区二区三区在线观看 | 国产成人在线精品 | 成人激情开心网 | 麻豆视频免费在线 | 久久国产精品99久久久久久老狼 | 欧美亚洲免费在线一区 | 久久伦理 | 女人魂免费观看 | 免费 在线 中文 日本 | www日韩欧美| 亚洲综合欧美激情 | 99国产精品一区 | 久久精品国产一区二区三区 | 在线视频欧美精品 | 成人在线视频观看 | 三级av中文字幕 | 久久99国产综合精品免费 | 成人97视频 | 91成人网在线观看 | 国产精品福利无圣光在线一区 | 色国产精品 | 国产麻豆剧传媒免费观看 | 91色九色 | 国产黄色精品在线 | 91丨九色丨高潮丰满 | 99热99re6国产在线播放 | 99热手机在线 | 五月婷婷丁香 | 色欧美日韩| 91久久人澡人人添人人爽欧美 | 精品视频免费久久久看 | 91精品国产欧美一区二区成人 | 99亚洲精品在线 | 色视频在线免费 | 1024手机在线看 | 亚洲天天综合网 | 成人免费观看完整版电影 | av大全免费在线观看 | 国产精品视频久久久 | 在线涩涩 | 免费视频一二三区 | 91视频三区 | 婷久久| 色网站国产精品 | 国产亚洲精品久久久久久久久久久久 | 国产伦精品一区二区三区在线 | 国产裸体无遮挡 | 成人高清在线观看 | 国产在线传媒 | 午夜在线免费视频 | 成人三级网址 | 日韩激情中文字幕 | 欧美日韩精品在线 | 综合网五月天 | 亚洲国内精品 | 欧美国产精品一区二区 | 一色av | 日本精品一区二区在线观看 | 久久精品超碰 | 久久理论视频 | 在线欧美中文字幕 | 国产精品久久久999 国产91九色视频 | 欧美日韩视频在线观看一区二区 | 午夜一级免费电影 | 欧美在线aa | 午夜av剧场 | 91精品国产综合久久婷婷香蕉 | 国产在线综合视频 | 日韩无在线 | 欧美天天综合网 | 五月天激情视频在线观看 | 男女视频久久久 | 国产精品一区二区免费 | 亚洲精品理论 | 日韩在线播放欧美字幕 | 青青久草在线视频 | 久久不卡视频 | 日韩电影在线观看中文字幕 | 久久国产精品99久久久久久丝袜 | 国产小视频国产精品 | 亚洲成aⅴ人片久久青草影院 | 天天干天天做天天操 | 久久综合色一综合色88 | 欧美在线视频免费 | 精品一区二区三区四区在线 | 黄色精品一区二区 | 亚洲日本成人网 | 精品国产伦一区二区三区免费 | 在线观看黄色国产 | 天天伊人网 | 日韩久久片 | 草久在线播放 | 精品国产日本 | 日韩 在线观看 | 天天操天天怕 | 97国产精品亚洲精品 | 色五婷婷 | 一区二区三区韩国免费中文网站 | 亚洲精品视频在线 | 天天干天天拍天天操天天拍 | 国内精品久久久久影院日本资源 | 久久久久久久福利 | 九九视频精品在线 | 欧美色图东方 | 狠狠色综合网站久久久久久久 | 视频三区在线 | 久久国产免 | 免费观看一级视频 | 国产小视频免费观看 | 91麻豆精品国产91久久久使用方法 | 九九热有精品 | 91精品蜜桃 | 天天干天天综合 | 国产精品视频大全 | 国产视频 亚洲视频 | 亚洲 欧美 国产 va在线影院 | 久久精品毛片 | 狠狠躁夜夜躁人人爽超碰91 | 国产午夜精品免费一区二区三区视频 | 深爱五月网 | 亚洲影视九九影院在线观看 | 国内成人精品视频 | 亚洲高清精品在线 | 一区二区视频在线免费观看 | 成人黄色片在线播放 | 亚洲欧洲国产精品 | 91精品免费看| 亚洲精品高清一区二区三区四区 | 人成在线免费视频 | 美女啪啪图片 | 国产精品免费视频网站 | www.xxx.性狂虐 | 在线观看国产www | 中文国产字幕在线观看 | 欧美另类交在线观看 | 手机av在线网站 | 99免费在线视频 | 亚洲免费专区 | 一区二区三区影院 | 又爽又黄在线观看 | 午夜久久影院 | 国际精品久久久 | 亚洲 欧洲 国产 日本 综合 | 国产一二区精品 | 黄色日视频| 在线看av的网址 | 欧美一级性视频 | 久久黄色网页 | 久久精品毛片 | 成人aⅴ视频 | 国产精品日韩高清 | 夜色资源站国产www在线视频 | 久久99最新地址 | 国产精品久久99综合免费观看尤物 | 人人爽久久涩噜噜噜网站 | 99精品视频播放 | 成年人国产视频 | 国语自产偷拍精品视频偷 | av电影一区 | 免费国产视频 | 99色在线观看 | 婷婷久久丁香 | 久久久久久久久久久成人 | 欧美国产日韩激情 | 成人在线视频免费看 | 一级黄色大片在线观看 | 中文字幕在线观看第二页 | 少妇搡bbb| 九九色综合 | 亚洲高清视频在线播放 | 五月婷av| 伊人中文字幕在线 | 欧美午夜视频在线 | 99精品在线视频播放 | 五月婷婷开心 | 日韩v在线91成人自拍 | 日韩欧美国产激情在线播放 | 狠狠综合久久 | 亚洲va欧美| 久久黄网站 | 国产成人精品一区二区三区网站观看 | 麻豆视频在线免费看 | 91视频免费看片 | 日韩中文字幕一区 | 又黄又爽又刺激视频 | 99在线精品视频在线观看 | 色老板在线 | 欧美做受69| 国产高清亚洲 | 欧美精品一二三 | 深爱激情综合 | 日韩免费中文 | 成人污视频在线观看 | 激情网在线视频 | 久久久久久久久网站 | 久草在线观 | 日韩色在线 | 国产特级毛片 | 激情综合网色播五月 | 一本一本久久a久久精品综合 | 五月婷网站 | 国产精品短视频 | 亚洲精品国产欧美在线观看 | 狠狠操.com | 亚洲一区二区三区毛片 | 中文字幕日韩免费视频 | 成人免费网站在线观看 | 国产视频资源在线观看 | 麻豆精品国产传媒 | 国产伦精品一区二区三区高清 | 涩涩爱夜夜爱 | 免费看污污视频的网站 | 国产亚洲视频在线免费观看 | 超碰大片 | 国产色爽| 叶爱av在线| 国产色小视频 | 精品亚洲一区二区 | 国产一级片网站 | 成人影音av| 激情黄色av | 最近中文字幕高清字幕在线视频 | 亚洲高清视频在线 | 欧美99热| 国产精品美女久久久久久久 | 91在线观看视频 | 在线观看视频一区二区三区 | 亚洲成人家庭影院 | 婷婷精品国产欧美精品亚洲人人爽 | 国产小视频你懂的 | 久久影视一区 | 婷婷成人亚洲综合国产xv88 | 色婷婷综合五月 | www国产精品com | 999久久精品 | www.色五月| 中文字幕欧美三区 | 久久久天堂 | 91精品一区二区三区久久久久久 | 国产精品久久久久久av | 日日夜夜人人天天 | 午夜91在线 | 成人网在线免费视频 | 亚洲另类视频 | 99免费精品视频 | 丁香婷婷社区 | 国产精品大全 | 香蕉视频在线网站 | 99热这里有 | 中文在线√天堂 | 天天鲁一鲁摸一摸爽一爽 | 一本色道久久精品 | 99精品国自产在线 | 久草视频在线免费播放 | 久草爱| 91香蕉视频色版 | 69国产成人综合久久精品欧美 | 五月婷在线观看 | 久久综合偷偷噜噜噜色 | 91传媒在线| 丁香婷五月 | 五月情婷婷 | 超碰在线日韩 | 免费成人在线观看 | 久久夜av| 干干日日 | 少妇bbw撒尿 | 在线观看一区二区视频 | 日日操天天操夜夜操 | 韩国av一区二区三区在线观看 | 日韩精品中文字幕在线播放 | 97手机电影网 | av片子在线观看 | 夜夜躁日日躁狠狠久久av | 国产1区在线 | 国产 中文 日韩 欧美 | 国产高清绿奴videos | 中文字幕视频网 | 欧美激情在线看 | 日本久久综合视频 | 久久久999免费视频 日韩网站在线 | 亚洲第一香蕉视频 | 午夜少妇av| 国产中文字幕视频在线观看 | 亚洲精品视频在线观看视频 | 久草在线在线视频 | 久久亚洲综合国产精品99麻豆的功能介绍 | 久久草精品 | 999久久久久 | 狠狠网 | 中文字幕激情 | 国产成人综 | 久久精品国产99 | 亚洲欧美观看 | 91色亚洲| 99免在线观看免费视频高清 | 国产精品久久久久久久久久久久午夜片 | 激情丁香在线 | 天天搞天天干天天色 | 国产精品原创 | 亚洲永久免费av | 99在线观看免费视频精品观看 | 2024国产精品视频 | 狠狠干夜夜操天天爽 | 国产成人免费网站 | 少妇性bbb搡bbb爽爽爽欧美 | 国产精品视频资源 | 一级电影免费在线观看 | 一区二区电影在线观看 | 国产aaa毛片 | 五月婷婷六月丁香激情 | 夜夜夜影院| 亚洲男男gaygay无套 | 国内成人精品2018免费看 | 少妇bbb搡bbbb搡bbbb| 深夜视频久久 | 欧美极品在线播放 | 国精产品999国精产品视频 | 91最新网址 | 精品久久久久久一区二区里番 | 久久精品国产亚洲a | 在线观看成年人 | 国产又黄又猛又粗 | 中文字幕在线视频国产 | 久久激情综合 | 97人人澡人人添人人爽超碰 | 日韩免费视频一区二区 | 在线观看视频色 | 丁香色婷婷 | 精品国产免费看 | 黄色三级免费看 | 免费网址在线播放 | 国产精品乱看 | 国产婷婷在线观看 | 亚洲精品乱码久久久久久蜜桃欧美 | 欧美黄色高清 | 国产91免费观看 | a视频免费 | 中文一区在线观看 | 色99在线| 91夫妻视频 | 国产在线毛片 | 深夜福利视频在线观看 | 久久99精品国产99久久6尤 | 国产在线一区二区 | 中文在线免费一区三区 | 久久精品第一页 | 黄污在线看 | 国产婷婷久久 | 不卡视频一区二区三区 | 国产不卡在线视频 | 亚洲天堂网视频在线观看 | 波多野结衣久久资源 | 国产精品2区 | 在线看岛国av | 亚洲精品综合在线观看 | 天天操天天能 | 成人av高清在线观看 | 欧美吞精| 欧美日韩在线视频观看 | 丁香婷婷久久 | 丁香视频五月 | 天天天操天天天干 | 免费日韩 | 99热最新精品 | 天天色天天射综合网 | 日韩电影中文字幕在线观看 | 美女网站视频免费都是黄 | 久久国语露脸国产精品电影 | 973理论片235影院9 | 久久精品99国产国产精 | 欧美另类一二三四区 | 日韩黄色中文字幕 | 97人人射 | 免费在线电影网址大全 | 久久免费福利 | 伊人首页 | 欧美一级久久久久 | 日本特黄特色aaa大片免费 | 欧美日韩在线视频一区二区 | 国产精品一区久久久久 | 91亚洲精品久久久蜜桃网站 | 99精品视频免费看 | 午夜男人影院 | 亚洲毛片一区二区三区 | 成人97人人超碰人人99 | 337p日本大胆噜噜噜噜 | aaa免费毛片 | 国产精品成人免费一区久久羞羞 | 日韩3区| 久久艹国产视频 | 69热国产视频 | 中文字幕a∨在线乱码免费看 | 久久午夜视频 | 99热精品久久 | 免费观看第二部31集 | 456免费视频 | 精品国自产在线观看 | 国产精品18久久久久vr手机版特色 | 日韩在线视频免费观看 | 成人aⅴ视频 | 91尤物在线播放 | 国产精品扒开做爽爽的视频 | 国产日韩中文在线 | 亚洲午夜激情网 | 免费看片在线观看 | 国产专区精品 | 日韩性色 | 成人午夜免费剧场 | 三日本三级少妇三级99 | 丁香av | 久久久久99精品国产片 | 国产视频第二页 | 99色网站 | 国产免费一区二区三区网站免费 | 天天操夜操 | av大全在线 | 在线观看亚洲精品 | av中文字幕在线观看网站 | 九色在线视频 | 国产精品一区二区久久国产 | 中文字幕首页 | 欧美在线不卡一区 | 日韩精品久久久免费观看夜色 | 日韩欧美一区视频 | 天天摸天天舔天天操 | 久久99精品国产麻豆宅宅 | 国产麻豆视频 | 亚洲精品男人天堂 | 91网站免费观看 | a'aaa级片在线观看 | 精品一区二区免费视频 | 亚洲精品资源在线 | 国产一区二区高清不卡 | 久久成人久久 | 91九色在线视频 | 狠狠狠狠狠狠狠狠干 | 国产最新在线视频 | 国产精品手机看片 | 日韩av免费在线看 | 国产视频一区二区三区在线 | 国产剧情av在线播放 | 操高跟美女 | 黄色福利网站 | av天天色| 日韩高清www| 国产福利91精品张津瑜 | www毛片com| 久99久久| 久一久久 | 亚洲国产网站 | 日本精品视频在线观看 | 精品一区中文字幕 | 超碰国产在线观看 | av免费电影网站 | 韩国精品福利一区二区三区 | 91精品第一页 | 国产黄色高清 | 成年人电影毛片 | 欧美日韩免费在线视频 | 人人插人人草 | 国产精品视频地址 | 波多野结衣精品 | 久久综合狠狠综合久久激情 | av免费电影网站 | 99视| 久久婷婷网 | 国产精品不卡视频 | 色婷av | 成人免费观看完整版电影 | 久久亚洲综合国产精品99麻豆的功能介绍 | 三级av片 | 在线观看亚洲精品 | 天天插综合网 | 免费久久久久久久 | 91一区啪爱嗯打偷拍欧美 | 欧美福利片在线观看 | 色91av | 亚洲午夜电影网 | 在线观看国产福利片 | 精品人妖videos欧美人妖 | 久久综合九色综合久99 | 天天干天天天天 | 国产高清不卡在线 | 婷婷日 | 99久久精品免费看国产免费软件 | 久久国产三级 | 97精品一区二区三区 | 丁香视频五月 | 婷婷日日 | 三级在线视频观看 | 午夜性福利 | 欧美日韩精品综合 | 激情片av | 日韩高清不卡一区二区三区 | 亚洲精品乱码久久久久久高潮 | 久久综合偷偷噜噜噜色 | 天天操夜夜操国产精品 | 亚洲三级性片 | 九九视频在线观看视频6 | 欧美日韩网站 | 国产精品嫩草影院123 | 一区二区三区av在线 | 中文字幕在线日 | 一级一片免费观看 | 色综合久久中文字幕综合网 | 精品国产电影一区 | 国产麻豆果冻传媒在线观看 | 国产麻豆精品一区 | 国产视频一区二区在线播放 | 欧美日韩高清在线一区 | 欧美在线18 | 国产午夜精品一区二区三区欧美 | 欧美日韩高清在线观看 | 玖玖在线播放 | 91九色视频网站 | 一区二区三区日韩在线观看 | 精品国产乱码久久久久久1区二区 | 久久综合狠狠综合久久激情 | 久久久网站 | 美女福利视频 | 国产精品 中文在线 | 怡红院成人在线 | 在线精品视频免费观看 | 色婷五月天 | 成人电影毛片 | 亚州精品视频 | 国产精品久久久久婷婷二区次 | 免费观看91 | 久久成人免费电影 | 人人搞人人干 | 久久爱资源网 | 国产精品日韩高清 | 久久精品专区 | 日韩在线观看视频网站 | 一区 二区电影免费在线观看 | 免费观看性生交 | 久久国产品 | 亚洲电影在线看 | 在线亚洲日本 | av一级网站| 成人影视免费看 | 午夜久久久久久久久 | 日本不卡久久 | 国产精品嫩草影院99网站 | 天堂网在线视频 | 在线视频观看91 | 婷婷激情久久 | 天天色天天射天天干 | 久久这里只有精品久久 | 91丨九色丨国产在线 | 精品国产一区二区三区久久久蜜月 | 97小视频 | 国产美女免费观看 | 2019久久精品 | 操综合| 黄色片视频免费 | 激情综合网五月激情 | 91中文字幕在线观看 | 91精品国自产在线 | 国产一区在线精品 | 四虎影视成人永久免费观看亚洲欧美 | 国内外成人免费在线视频 | 国产日韩精品一区二区 | 精品国产免费av | 在线精品视频免费观看 | 欧美一级免费在线 | 午夜视频免费在线观看 | www日韩在线 | 日日干日日 | www.亚洲精品在线 | 天天插日日射 | 九九热视频在线播放 | 色999精品 | 一区二区 不卡 | 最近2019中文免费高清视频观看www99 | 97超碰国产精品女人人人爽 | 国产一级久久久 | 天天干天天草天天爽 | 视频国产在线观看18 | 91亚洲精品国偷拍自产在线观看 | 欧美性粗大hdvideo | 久久久国产一区二区 | 亚州国产视频 | 1024手机看片国产 | 成年人在线看片 | 成人av在线网| 91女子私密保健养生少妇 | 毛片无卡免费无播放器 | 久草在线资源观看 | 亚洲第一av在线播放 | 久久夜靖品 | 水蜜桃亚洲一二三四在线 | 精品国产伦一区二区三区观看说明 | 最新中文字幕视频 | 人人藻人人澡人人爽 | 久久国产精品一二三区 | 这里有精品在线视频 | 国产精品一区二区在线播放 | 天天人人 | 天天曰天天射 | 欧美精品久久久久a | 久久久精品欧美 | 亚州精品天堂中文字幕 | 波多野结衣小视频 | 免费性网站| 天堂在线免费视频 | 国产亚洲日 | 亚洲精品乱码久久久久久高潮 | 91高清视频在线 | 国产精品美女久久久久久久 | 国产精品自产拍在线观看网站 | 一区二区三区韩国免费中文网站 | 97精品一区二区三区 | 久久久午夜影院 | 亚洲人人av| 久久久久久久久久久影视 | 久久久精品国产免费观看同学 | 国产大尺度视频 | 国产精品久久久久久久久久东京 | 天天色天天操综合 | 久草在线久草在线2 | 国产精品毛片一区二区在线看 | 99爱视频 | 国产精品午夜久久久久久99热 | 精品99免费视频 | 亚洲国产精品传媒在线观看 | 国产成人福利片 | 日本丰满少妇免费一区 | 国产精品女主播一区二区三区 | 日韩免费视频网站 | 久久国产亚洲精品 | 精品国产网址 | 国产成人精品一区二区在线观看 | www.五月天婷婷| 色狠狠综合天天综合综合 | 成人h在线观看 | 国产视频2区 | 日韩中文字幕免费在线播放 | 99精彩视频在线观看免费 | 在线观看中文字幕一区 | 久久国产精品99国产 | 99精品欧美一区二区三区 | 欧美二区三区91 | 国产高清精品在线 | 免费av网站观看 | 激情综合国产 | 一本色道久久精品 | 韩日av在线 | 色综合狠狠干 | 亚洲美女视频网 | 国产资源免费在线观看 | 国产中文字幕在线看 | 有码中文字幕在线观看 | 伊人天堂久久 | 中文乱码视频在线观看 | 国产剧情一区二区在线观看 | 天天综合日日夜夜 | 日韩精品久久久久 | 天天干天天拍天天操天天拍 | 中文字幕在线观看第一页 | 国产精品爽爽爽 | 精品欧美日韩 | 欧美淫视频 | 免费看日韩 | 欧美精品一区二区蜜臀亚洲 | www.久久爱.cn | 最近中文字幕国语免费高清6 | 午夜精品麻豆 | av片一区二区 | 亚洲天堂精品视频 | 一区二区三区免费在线观看视频 | 69夜色精品国产69乱 | 欧美极品久久 | 黄色毛片视频免费观看中文 | 手机av电影在线观看 | 精品国产免费人成在线观看 | 久一在线 | 婷婷五综合| 大型av综合网站 | 最新日韩电影 | 91精品国产九九九久久久亚洲 | 国产福利精品一区二区 | 国产高清综合 | 亚洲午夜精品久久久 | 国外av在线| 人人干人人超 | 久久久久久久国产精品视频 | 综合网色 | 看片一区二区三区 | 国产精品久久久久av免费 | 国产精品久久久久久久久久东京 | 久久国产精品一区二区三区 | 国产成人精品在线播放 | 亚洲精品高清一区二区三区四区 | 国内精品国产三级国产aⅴ久 | 香蕉97视频观看在线观看 | 久久综合久久综合这里只有精品 | 国产日韩欧美在线观看视频 | 国产免费一区二区三区网站免费 | 免费亚洲成人 | 蜜桃av人人夜夜澡人人爽 | 中文免费观看 | 综合久久影院 | 国产精品美女视频 | 国产高清视频色在线www | 国产免费xvideos视频入口 | 亚洲va在线va天堂va偷拍 | 久久麻豆精品 | 黄色a级片在线观看 | av片子在线观看 | 波多野结衣综合网 | 丁香花在线观看视频在线 | 亚洲综合色播 | 国产视频色 | 久久精品视频18 | 国产精品麻豆视频 | 亚洲精品福利在线观看 | 日日夜夜天天 | 亚洲自拍偷拍色图 | 亚洲精品高清一区二区三区四区 | 免费又黄又爽视频 | 欧美日韩大片在线观看 | 日日干天天操 | 日日爽夜夜操 | 夜夜视频欧洲 | 成年人看片 | 97在线视 | 深爱激情综合 | 黄色毛片观看 | 亚洲第一av在线播放 | 在线免费色| 日本午夜免费福利视频 | 国产精品美女久久久久久免费 | 99久久久免费视频 | 区一区二在线 | 伊人五月婷| 免费观看www小视频的软件 | 在线观看国产一区二区 | 91理论电影 | 狠狠地日 | 久草精品资源 | 正在播放国产一区二区 | 日韩在线二区 | 四虎影视精品 | 免费日韩| 在线天堂8√| 九九九热精品 | 国产精品av久久久久久无 | 97偷拍视频 | 日韩免费观看一区二区三区 | 色丁香综合 | 成人免费观看网址 | 国产精品12345 | 黄色一级大片在线观看 | 一级a毛片高清视频 | 成年在线观看 | 国产又粗又猛又色 | 日日夜夜草 | 日韩av资源在线观看 | 天天插综合网 | 国产黄色片免费 | 在线观看 国产 | 日韩高清不卡在线 | 亚洲精品三级 | 在线播放视频一区 | 国产一区二区综合 | 99久久婷婷国产一区二区三区 | 热久久精品在线 | 国产免费大片 | 久久久精选| 中文字幕乱码电影 | 国产特级毛片aaaaaa高清 | 91av小视频 | 欧美日韩国产在线精品 | 国产剧情一区在线 | 久久国产精品电影 | 麻豆视频大全 | 美女网站在线播放 | 午夜精品久久久99热福利 | 亚洲精品高清视频 | 免费a v视频 | 亚洲精品国产成人 | 久久婷婷色 | 国产区精品区 | 久久久久电影 | 国产精品视频你懂的 | 午夜黄色影院 | 日韩免费观看一区二区三区 | 国内外成人在线 |