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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

Kafka Shell Lag

發布時間:2023/12/15 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Kafka Shell Lag 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Kafka Shell Lag

kafka 版本:2.1.0

前言

在生產環境中,比如你正在使用group kafka-lag消費某topic內的數據。目前你沒有搭建對應的監控系統,你如何去查看對應partition 的堆積信息呢?很多人都會去使用這個命令:

# 正常使用 kafka-consumer-groups --bootstrap-server master:9092 --describe --group default# 系統存在kerberos認證使用 kafka-consumer-groups --bootstrap-server master:9092 --describe --group default --command-config /home/xiahu/client.properties

client.properties

security.protocol=PLAINTEXT sasl.mechanism=GSSAPI sasl.kerberos.service.name=kafka

沒錯,今天我們就來研究一下這個命令,先從kafka-consumer-groups啟動腳本看起

1. kafka-consumer-groups.sh

# 該腳本只是簡單的去調用了另外一個腳本kafka-run-class.sh,并將參數傳遞過去 exec $(dirname $0)/kafka-run-class.sh kafka.admin.ConsumerGroupCommand "$@"

2. kafka-run-class.sh

# 這個腳本內的內容太多了,其他的我也沒看,但是你所需要明白的是: # 在命令行執行: kafka-consumer-groups --bootstrap-server master:9092 --describe --group default # 最終調用:kafka.admin.ConsumerGroupCommand --bootstrap-server master:9092 --describe --group default # 所以主要看源碼:kafka.admin.ConsumerGroupCommand 這個類 if [ "x$DAEMON_MODE" = "xtrue" ]; thenecho $JAVA $KAFKA_HEAP_OPTS $KAFKA_JVM_PERFORMANCE_OPTS $KAFKA_GC_LOG_OPTS $KAFKA_JMX_OPTS $KAFKA_LOG4J_OPTS -cp $CLASSPATH $KAFKA_OPTS "$@" elseexec $JAVA $KAFKA_HEAP_OPTS $KAFKA_JVM_PERFORMANCE_OPTS $KAFKA_GC_LOG_OPTS $KAFKA_JMX_OPTS $KAFKA_LOG4J_OPTS -cp $CLASSPATH $KAFKA_OPTS "$@" fi

3. ConsumerGroupCommand

def main(args: Array[String]) {val opts = new ConsumerGroupCommandOptions(args)if (args.length == 0)CommandLineUtils.printUsageAndDie(opts.parser, "List all consumer groups, describe a consumer group, delete consumer group info, or reset consumer group offsets.")val actions = Seq(opts.listOpt, opts.describeOpt, opts.deleteOpt, opts.resetOffsetsOpt).count(opts.options.has)if (actions != 1)CommandLineUtils.printUsageAndDie(opts.parser, "Command must include exactly one action: --list, --describe, --delete, --reset-offsets")//參數判斷opts.checkArgs()//通過ConsumerGroupCommandOptions,構造ConsumerGroupService對象val consumerGroupService = new ConsumerGroupService(opts)try {if (opts.options.has(opts.listOpt))consumerGroupService.listGroups().foreach(println(_))else if (opts.options.has(opts.describeOpt))//因為此次我們探究的是kafka lag的數據,所以主要看方法consumerGroupService.describeGroup()else if (opts.options.has(opts.deleteOpt))... }

4. describeGroup()

def describeGroup(): Unit = {// 從配置類中獲取配置val group = opts.options.valuesOf(opts.groupOpt).asScala.headval membersOptPresent = opts.options.has(opts.membersOpt)val stateOptPresent = opts.options.has(opts.stateOpt)val offsetsOptPresent = opts.options.has(opts.offsetsOpt)val subActions = Seq(membersOptPresent, offsetsOptPresent, stateOptPresent).count(_ == true)if (subActions == 0 || offsetsOptPresent) {// kafka lag 信息的查詢,主要封裝與該類中val offsets = collectGroupOffsets()printOffsets(group, offsets._1, offsets._2)} else if (membersOptPresent) {val members = collectGroupMembers(opts.options.has(opts.verboseOpt))printMembers(group, members._1, members._2, opts.options.has(opts.verboseOpt))} elseprintState(group, collectGroupState()) }

5. collectGroupOffsets()

def collectGroupOffsets(): (Option[String], Option[Seq[PartitionAssignmentState]]) = {val groupId = opts.options.valueOf(opts.groupOpt)// 首先構造AdminClient 對象// 關于Admin Client,查看該博客即可了解:https://blog.csdn.net/zc0565/article/details/102791488// AdminClient 根據 groupId 獲取 ConsumerGroupDescription //ConsumerGroupDescription: A detailed description of a single consumer group in the cluster.val consumerGroup = adminClient.describeConsumerGroups(List(groupId).asJava,withTimeoutMs(new DescribeConsumerGroupsOptions())).describedGroups.get(groupId).getval state = consumerGroup.state// 根據groupId 返回一個Map對象<TopicPartition,OffsetAndMetadata>// TopicPartition: 內部封裝topic,partition// OffsetAndMetadata : 內部封裝當前topic,partition 對應的groupId 的 當前的offset 和元數據信息// 比如: // topic:kafka_lag_test partition:0 groupId:kafka-lag// 眾所周知,topic + partition + groupId 都對應著唯一的 :currentOffset val committedOffsets = getCommittedOffsets(groupId).asScala.toMapvar assignedTopicPartitions = ListBuffer[TopicPartition]()// 下面這段代碼主要過濾空的TopicPartition,并且封裝TopicPartition 對應的currentOffsetval rowsWithConsumer = consumerGroup.members.asScala.filter(!_.assignment.topicPartitions.isEmpty).toSeq.sortWith(_.assignment.topicPartitions.size > _.assignment.topicPartitions.size).flatMap { consumerSummary =>val topicPartitions = consumerSummary.assignment.topicPartitions.asScalaassignedTopicPartitions = assignedTopicPartitions ++ topicPartitionsval partitionOffsets = consumerSummary.assignment.topicPartitions.asScala.map { topicPartition =>topicPartition -> committedOffsets.get(topicPartition).map(_.offset)}.toMap// 主要看一下這個方法collectConsumerAssignment(groupId, Option(consumerGroup.coordinator), topicPartitions.toList,partitionOffsets, Some(s"${consumerSummary.consumerId}"), Some(s"${consumerSummary.host}"),Some(s"${consumerSummary.clientId}"))}val rowsWithoutConsumer = committedOffsets.filterKeys(!assignedTopicPartitions.contains(_)).flatMap {case (topicPartition, offset) =>collectConsumerAssignment(groupId,Option(consumerGroup.coordinator),Seq(topicPartition),Map(topicPartition -> Some(offset.offset)),Some(MISSING_COLUMN_VALUE),Some(MISSING_COLUMN_VALUE),Some(MISSING_COLUMN_VALUE))}(Some(state.toString), Some(rowsWithConsumer ++ rowsWithoutConsumer))}

6. collectConsumerAssignment

//該方法返回一個PartitionAssignmentState數據 private def collectConsumerAssignment(group: String,coordinator: Option[Node],topicPartitions: Seq[TopicPartition],getPartitionOffset: TopicPartition => Option[Long],consumerIdOpt: Option[String],hostOpt: Option[String],clientIdOpt: Option[String]): Array[PartitionAssignmentState] = {// 一般情況下,topicPartitions為空if (topicPartitions.isEmpty) {Array[PartitionAssignmentState](PartitionAssignmentState(group, coordinator, None, None, None, getLag(None, None), consumerIdOpt, hostOpt, clientIdOpt, None))}else// 主要看這個方法describePartitions(group, coordinator, topicPartitions.sortBy(_.partition), getPartitionOffset, consumerIdOpt, hostOpt, clientIdOpt) }

7. describePartitions

private def describePartitions(group: String,coordinator: Option[Node],topicPartitions: Seq[TopicPartition],getPartitionOffset: TopicPartition => Option[Long],consumerIdOpt: Option[String],hostOpt: Option[String],clientIdOpt: Option[String]): Array[PartitionAssignmentState] = {def getDescribePartitionResult(topicPartition: TopicPartition, logEndOffsetOpt: Option[Long]): PartitionAssignmentState = {val offset = getPartitionOffset(topicPartition)PartitionAssignmentState(group, coordinator, Option(topicPartition.topic), Option(topicPartition.partition), offset,getLag(offset, logEndOffsetOpt), consumerIdOpt, hostOpt, clientIdOpt, logEndOffsetOpt)}//getLogEndOffsets//1. 根據bootstrap-server,groupId 實例化KafkaConsumer對象//2. 根據TopicPartition,調用KafkaConsumer的endOffsets方法,獲取topic內每一個partition的最大offset//3. 根據之前查詢到的groupId對應topic內每一個partition的currentOffset,與此次獲取到的offset,做一個計算,最終得到Lag,并將其封裝PartitionAssignmentState返回getLogEndOffsets(topicPartitions).map {case (topicPartition, LogOffsetResult.LogOffset(offset)) => getDescribePartitionResult(topicPartition, Some(offset))case (topicPartition, _) => getDescribePartitionResult(topicPartition, None)}.toArray }

說明

在kafka內,有以下幾個概念

  • broker
  • topic
  • partition
  • group
  • offset
  • 分別說明:

    1. broker

    broker可以理解為一臺安裝kafka的機器,多個broker構成kafka集群,如果只有一個broker,那么這個kafka服務是單機的

    2. topic

    topic 翻譯過來為主題. 一個kafka集群下有多個topic

    3. partition

    partition翻譯為分區,hive里面就有分區的概念,與hive的分區類似,一個topic 內有多個partition

    4. groupId

    結合實際說明:
    目前,我有 topic: kafka_lag ,該topic有兩個partition,目前往topic內生產10000條數據,按照默認的分區測試,partition 0,partition 1 分別有 5000 條數據.
    除此之外,我有兩個group:kafka-consumer-lag-1,kafka-consumer-lag-2

    首先:我使用kafka-consumer-lag-1 去消費topic內的數據,加入,partition0,1 分別消費2000 ,則offset 如下:

    groupIdtopicpartitioncurrentOffsetlagendOffset
    kafka-consumer-lag-1kafka_lag0200030005000
    kafka-consumer-lag-1kafka_lag1200030005000
    kafka-consumer-lag-2kafka_lag0050005000
    kafka-consumer-lag-2kafka_lag1050005000

    然后,我用 kafka-consumer-lag-2 去消費topic內的數據,partition 0,1 分區消費4000 ,則offset如下:

    groupIdtopicpartitioncurrentOffsetlagendOffset
    kafka-consumer-lag-1kafka_lag0200030005000
    kafka-consumer-lag-1kafka_lag1200030005000
    kafka-consumer-lag-2kafka_lag0400010005000
    kafka-consumer-lag-2kafka_lag1400010005000

    總結

    由上面的數據展示可知:

    topic + partition 對應唯一的endOffset

    topic + partition + group 對應唯一的currentOffset

    其實kafka 提供的 kafka-run-class.sh 就是使用的這個原理

  • 構造AdminClient,使用AdminClient 的listConsumerGroupOffsets() 根據groupid 獲取每一個 topic + partition + groupId 對應的唯一的currentOffset
  • 實例化KafkaConsumer對象,根據topic + partiton 組成的TopicPartition 對象集合,獲取 topic + partition 對應的唯一的endOffset
  • 通過一系列計算(endOffset - currentOffset),獲取到了groupID 對應的Lag ,最終打印呈現
  • 由于kafka 源碼是使用scala寫的,沒了解過scala的人看起來會比較困難,我用java重新給邏輯實現了一遍,代碼如下:

    package com.clb.lag;import org.apache.kafka.clients.admin.AdminClient; import org.apache.kafka.clients.admin.ConsumerGroupDescription; import org.apache.kafka.clients.admin.MemberDescription; import org.apache.kafka.clients.consumer.ConsumerConfig; import org.apache.kafka.clients.consumer.KafkaConsumer; import org.apache.kafka.clients.consumer.OffsetAndMetadata; import org.apache.kafka.common.ConsumerGroupState; import org.apache.kafka.common.KafkaFuture; import org.apache.kafka.common.TopicPartition; import org.apache.kafka.common.serialization.StringDeserializer; import java.util.*; import java.util.function.Consumer;/*** @author Xiahu* @create 2021/1/11*/ public class KafkaOffsetTool {private AdminClient adminClient;private static final String MISSING_COLUMN_VALUE = "-";private KafkaConsumer consumer;public KafkaOffsetTool() {Properties properties = new Properties();properties.put("bootstrap.servers", "node2:9092");//kerberos認證需要自己實現if (false) {properties.put("sasl.kerberos.service.name", "kafka");properties.put("sasl.mechanism", "GSSAPI");properties.put("security.protocol", "PLAINTEXT");}this.adminClient = AdminClient.create(properties);}public List<PartitionOffsetState> collectGroupOffsets(String group) throws Exception {List<PartitionOffsetState> result = new ArrayList<>();List<String> groupId = Arrays.asList(group);Map<String, KafkaFuture<ConsumerGroupDescription>> describedGroups = adminClient.describeConsumerGroups(groupId).describedGroups();ConsumerGroupDescription consumerGroup = describedGroups.get(group).get();ConsumerGroupState state = consumerGroup.state();Map<TopicPartition, OffsetAndMetadata> committedOffsets = getCommitsOffsets(group);Collection<MemberDescription> memberDescriptions = consumerGroup.members();Set<MemberDescription> memberDescriptionSet = new HashSet<>();Iterator<MemberDescription> iterator = memberDescriptions.iterator();while (iterator.hasNext()) {MemberDescription memberDescription = iterator.next();if (null != memberDescription.assignment().topicPartitions()) {memberDescriptionSet.add(memberDescription);}}memberDescriptionSet.stream().sorted(new Comparator<MemberDescription>() {@Overridepublic int compare(MemberDescription o1, MemberDescription o2) {if (o1.assignment().topicPartitions().size() >= o2.assignment().topicPartitions().size()) {return 1;} else {return -1;}}}).forEach(new Consumer<MemberDescription>() {@Overridepublic void accept(MemberDescription memberDescription) {Set<TopicPartition> topicPartitions = memberDescription.assignment().topicPartitions();for (TopicPartition tp : topicPartitions) {long offset = committedOffsets.get(tp).offset();PartitionOffsetState partitionOffsetState = new PartitionOffsetState();partitionOffsetState.setGroup(group);partitionOffsetState.setCoordinator(consumerGroup.coordinator().toString());partitionOffsetState.setHost(memberDescription.host());partitionOffsetState.setClientId(memberDescription.clientId());partitionOffsetState.setConsumerId(memberDescription.consumerId());partitionOffsetState.setPartition(tp.partition());partitionOffsetState.setTopic(tp.topic());partitionOffsetState.setOffset(offset);result.add(partitionOffsetState);}}});//封裝committedOffsetsIterator<Map.Entry<TopicPartition, OffsetAndMetadata>> entryIterator = committedOffsets.entrySet().iterator();while (entryIterator.hasNext()) {Map.Entry<TopicPartition, OffsetAndMetadata> entry = entryIterator.next();PartitionOffsetState partitionOffsetState = new PartitionOffsetState();partitionOffsetState.setGroup(group);partitionOffsetState.setCoordinator(consumerGroup.coordinator().toString());partitionOffsetState.setHost(MISSING_COLUMN_VALUE);partitionOffsetState.setClientId(MISSING_COLUMN_VALUE);partitionOffsetState.setConsumerId(MISSING_COLUMN_VALUE);partitionOffsetState.setPartition(entry.getKey().partition());partitionOffsetState.setTopic(entry.getKey().topic());partitionOffsetState.setOffset(entry.getValue().offset());result.add(partitionOffsetState);}return result;}private Map<TopicPartition, OffsetAndMetadata> getCommitsOffsets(String groupId) throws Exception {Map<TopicPartition, OffsetAndMetadata> result = adminClient.listConsumerGroupOffsets(groupId).partitionsToOffsetAndMetadata().get();return result;}public List<PartitionOffsetState> getLag(List<PartitionOffsetState> partitionOffsetStateList,String groupId) {getConsumer(new Properties(), groupId);List<TopicPartition> topicPartitionList = new ArrayList<>();for (PartitionOffsetState partitionOffset : partitionOffsetStateList) {topicPartitionList.add(new TopicPartition(partitionOffset.getTopic(), partitionOffset.getPartition()));}Map<TopicPartition, Long> map = consumer.endOffsets(topicPartitionList);for (PartitionOffsetState partitionOffset : partitionOffsetStateList) {for (Map.Entry<TopicPartition, Long> entry : map.entrySet()) {if (entry.getKey().topic().equals(partitionOffset.getTopic()) && entry.getKey().partition() == partitionOffset.getPartition()) {partitionOffset.setLag(entry.getValue() - partitionOffset.getOffset());partitionOffset.setLogEndOffset(entry.getValue());}}}return partitionOffsetStateList;}private KafkaConsumer getConsumer(Properties prop, String groupId) {if (consumer == null) {createConsumer(prop, groupId);}return consumer;}public void createConsumer(Properties prop, String groupId) {//kerberos認證需要自己實現if (false) {System.setProperty("java.security.krb5.conf", prop.getProperty(NuwaConstant.KERBEROS_KRB5));System.setProperty("java.security.auth.login.config", prop.getProperty(NuwaConstant.KERBEROS_LOGIN_CONFIG));prop.put(NuwaConstant.KAFKA_SECURITY_PROTOCOL, prop.getProperty(NuwaConstant.KAFKA_SECURITY_PROTOCOL));prop.put(NuwaConstant.KAFKA_SASL_MECHANISM, prop.getProperty(NuwaConstant.KAFKA_SASL_MECHANISM));prop.put(NuwaConstant.KAFKA_SASL_KERBEROS_SERVICE_NAME, prop.getProperty(NuwaConstant.KAFKA_SASL_KERBEROS_SERVICE_NAME));}String deserializer = StringDeserializer.class.getName();String broker = "node1:9092";prop.put(ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG, broker);prop.put(ConsumerConfig.GROUP_ID_CONFIG, groupId);prop.put(ConsumerConfig.ENABLE_AUTO_COMMIT_CONFIG, "false");prop.put(ConsumerConfig.SESSION_TIMEOUT_MS_CONFIG, "30000");prop.put(ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG, deserializer);prop.put(ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG, deserializer);consumer = new KafkaConsumer(prop);}public static void main(String[] args) throws Exception {KafkaOffsetTool kafkaOffsetTool = new KafkaOffsetTool();List<PartitionOffsetState> partitionOffsetStates = kafkaOffsetTool.collectGroupOffsets("kafka-lag");partitionOffsetStates = kafkaOffsetTool.getLag(partitionOffsetStates,"kafka-lag");System.out.println(partitionOffsetStates);} }

    PartitionOffsetState

    package com.clb.lag;import lombok.Data;/*** @author Xiahu* @create 2021/1/11*/ @Data public class PartitionOffsetState {private String group;private String coordinator;private String topic;private int partition;private Long offset;private Long lag;private String consumerId;private String host;private String clientId;private Long logEndOffset; }

    總結

    以上是生活随笔為你收集整理的Kafka Shell Lag的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    久草99 | 婷婷激情五月 | 天天综合婷婷 | 日韩午夜网站 | 日韩激情第一页 | 久久网站最新地址 | 在线99视频| 久久久亚洲麻豆日韩精品一区三区 | 日韩欧美综合视频 | 精品久久久久久电影 | 日韩试看 | www黄色软件 | 亚洲欧美色婷婷 | 国产免费高清 | 91福利视频久久久久 | 激情综合色综合久久 | 正在播放国产一区二区 | 国产啊v在线观看 | 亚洲精品动漫在线 | 91视频91蝌蚪 | 狠狠干狠狠插 | 亚洲一区尤物 | 91九色在线视频观看 | 久久优 | 国产一区在线不卡 | 国产黄色免费观看 | 91亚洲精品国偷拍 | 99视频+国产日韩欧美 | 天天人人 | 国产精品h在线观看 | 亚洲精品久久久蜜臀下载官网 | 色综合久久中文综合久久牛 | 亚洲精品美女久久久久 | 国产精品视频观看 | 免费在线观看污网站 | 黄色小说免费在线观看 | 色婷婷激情网 | 久久99久久99精品免视看婷婷 | 五月婷婷视频在线 | 在线观看成人福利 | 九九久久国产 | 婷婷狠狠操 | 欧美色综合久久 | 五月天久久精品 | 福利一区二区三区四区 | 国产成人精品久久亚洲高清不卡 | 国产一级黄色av | 精品久久久久久久久久久久久久久久 | 日韩电影一区二区在线观看 | 狠狠操在线 | 97在线免费视频观看 | 女人18片毛片90分钟 | 亚洲女人天堂成人av在线 | 久草视频在线资源站 | 日韩三级.com | 精品乱码一区二区三四区 | 综合久久婷婷 | 日韩电影在线观看一区二区三区 | 激情av网 | 国产成人久久77777精品 | 国产亚洲91 | 日批视频在线 | 婷婷久月 | 一级c片| wwwwwww黄| 午夜精品福利一区二区三区蜜桃 | 国产麻豆剧传媒免费观看 | 国产免费一区二区三区最新 | 国产一区二区免费看 | 日本中文在线观看 | 欧美性色xo影院 | 久久精品久久99精品久久 | 国产午夜精品免费一区二区三区视频 | 97人人澡人人添人人爽超碰 | 热久久国产精品 | 亚洲黄色app| 夜夜操天天操 | 欧美日韩电影在线播放 | 国产精品视频99 | 在线观看国产福利片 | 久一网站| 免费看av在线 | 久久精品视频在线观看免费 | 国产精品二区在线观看 | 日韩欧美精品在线观看视频 | 国产免费久久久久 | 2021av在线 | 一区二区三区精品在线 | 欧美午夜一区二区福利视频 | 国产女人40精品一区毛片视频 | 麻豆91网站 | 久久永久免费视频 | 国产一级淫片免费看 | 精品国产乱码久久久久久1区2匹 | 国产资源中文字幕 | 色小说av | 久草资源在线观看 | 日韩免费b | 亚洲欧美日韩精品久久久 | 久久99久久99精品免观看软件 | 日韩av片在线| 亚洲va天堂va欧美ⅴa在线 | 国语黄色片 | 精品一区二区三区久久 | 在线观看国产日韩 | 国产精品久久久区三区天天噜 | 日韩精品中文字幕一区二区 | 亚洲无吗av | 久久精品久久99 | 久久成人国产精品一区二区 | 91福利视频在线 | 久久精品国产99国产 | 久草在线官网 | 亚欧日韩成人h片 | 波多野结衣精品 | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | 精品视频在线播放 | 国产精品免费视频久久久 | 久射网| 又黄又刺激视频 | 中文字幕三区 | 国产手机视频在线 | 在线免费观看涩涩 | 六月丁香社区 | 国产一级免费电影 | 国产免费视频一区二区裸体 | 日日夜夜人人精品 | 国产精品乱码一区二区视频 | 99久久精品国产免费看不卡 | 91天天操| 欧美看片 | 免费在线观看日韩视频 | 五月天综合色 | 91大神精品视频 | 免费看v片 | 成人a级网站 | 久久综合欧美精品亚洲一区 | 国产黄色看片 | 狂野欧美激情性xxxx | 综合天天 | 免费观看一区二区三区视频 | 五月丁色| 天天干,狠狠干 | 国产91在线 | 美洲 | 亚洲精品国产电影 | 8x8x在线观看视频 | 狠狠色婷婷丁香六月 | 91黄色在线观看 | 婷婷久久一区二区三区 | 国产欧美日韩视频 | 日韩精品中文字幕av | 99久久精品国产免费看不卡 | 国产区高清在线 | 九九综合九九综合 | www.天天色.com| 欧美精品首页 | www激情com| 欧美调教网站 | 在线国产福利 | 欧美日韩久久一区 | 国产高清福利在线 | 9999在线观看 | 免费在线一区二区三区 | 免费成人黄色 | 97看片 | 日本精品视频一区二区 | 欧美日本在线观看视频 | 在线观看精品一区 | 国产成年人av | 激情久久影院 | 欧美特一级 | 肉色欧美久久久久久久免费看 | 成人宗合网 | 成人毛片在线观看 | 免费男女羞羞的视频网站中文字幕 | 免费看精品久久片 | 亚洲欧美日韩在线一区二区 | 久久免费视频99 | 国产日韩在线观看一区 | 一区二区精品在线视频 | 中文字幕亚洲欧美日韩 | 91九色蝌蚪国产 | 国产精品99精品 | 久久官网 | 久久看片 | 911精品视频| 亚洲精品看片 | 免费看黄在线网站 | 久久精品高清视频 | 成人免费视频网站 | 久久社区视频 | 婷婷六月网 | 国产在线一区二区 | 精品字幕在线 | 精品国产精品久久一区免费式 | 91精品国产92久久久久 | 国产精品欧美久久 | 国产男女爽爽爽免费视频 | 欧美在线视频日韩 | 亚洲国产午夜精品 | 99在线热播 | 成人三级av | 永久免费观看视频 | 久久综合天天 | 9999亚洲 | 日韩一二三区不卡 | 香蕉视频4aa | 午夜精品一区二区三区在线 | 久久久精品成人 | 国产午夜精品一区二区三区在线观看 | 69国产在线观看 | 一级片黄色片网站 | 中文字幕日本电影 | 欧美国产日韩在线视频 | 99热999 | 国内精品久久久久久久 | 天天干天天拍天天操天天拍 | 91天堂素人约啪 | 亚洲国产网站 | 久久狠狠一本精品综合网 | 色小说av | 99综合久久 | 在线不卡中文字幕播放 | 久久免费国产电影 | 五月婷婷中文网 | 成人久久久精品国产乱码一区二区 | 久久精品1区 | 亚洲精品免费在线观看 | 三级动图| 成人av高清 | 国内精品久久久久影院日本资源 | 91热精品视频 | 国产精品久久久久久久午夜片 | 六月丁香婷 | 99热日本 | 日韩精品在线观看视频 | 欧美a√大片 | 欧美伦理一区二区三区 | 国产一级淫片免费看 | 天天·日日日干 | 欧美另类交在线观看 | 国产精品一区在线播放 | 色天天天 | 色视频在线免费 | 97在线观看视频国产 | 免费观看的av网站 | 亚洲三级毛片 | 国产精品1024 | 国产亚洲精品久久久久久大师 | 免费视频一级片 | 2022国产精品视频 | 精品黄色在线观看 | 久久精品精品电影网 | 91在线看免费 | 美女黄频网站 | 精品美女在线视频 | 狠狠色丁香婷婷综合视频 | 一区二区视频电影在线观看 | 狠狠88综合久久久久综合网 | 在线免费三级 | 亚洲精品在线看 | 中文字幕乱在线伦视频中文字幕乱码在线 | 日日爽夜夜爽 | 亚洲永久精品在线观看 | 久久综合狠狠综合久久综合88 | 成人va视频| 亚洲精品在线观看免费 | 天天综合网久久综合网 | 天天操天天操一操 | 91爱爱电影 | 欧美日韩不卡在线观看 | 国产精品久久久久久久久久久不卡 | 日韩欧美在线综合网 | 五月在线 | 国产黄在线免费观看 | 91传媒免费观看 | 精品视频亚洲 | 狠狠地操 | 久久亚洲热 | 婷婷射五月 | 99精品在线直播 | 亚洲专区 国产精品 | 欧洲性视频 | 一级成人网| 五月天激情视频在线观看 | 欧美日韩国产伦理 | 亚洲精品高清视频 | www亚洲精品 | 激情五月***国产精品 | 91av原创 | 欧美韩日在线 | 综合网天天色 | 国产精品观看视频 | 久久艹精品 | 一区二区三区高清在线 | www.色com | 99在线高清视频在线播放 | 一区二区在线电影 | 成x99人av在线www| a'aaa级片在线观看 | 久久国产综合视频 | 狠狠干我 | 天天五月天色 | 天天操夜操 | 黄色在线视频网址 | 激情一区二区三区欧美 | 蜜臀av麻豆 | 天天干天天干天天 | 91九色视频在线观看 | 久久久精品在线观看 | 91看片成人 | 91精品国自产在线观看 | 在线中文字幕观看 | 欧美一区二区三区四区夜夜大片 | 久久视频国产精品免费视频在线 | 日日夜夜综合 | 超级碰碰免费视频 | 亚洲一二三区精品 | 久草在线综合网 | 欧洲视频一区 | 国产一区在线不卡 | 久草在线中文视频 | 九九九热精品免费视频观看网站 | 在线观看视频你懂得 | 97国产在线 | 丝袜美腿在线播放 | 亚洲影视九九影院在线观看 | 首页国产精品 | 欧美成人一区二区 | 国产精品久久久久久久久久久久午 | 国产又粗又猛又黄 | 伊人中文在线 | 久久私人影院 | 久草网免费 | 国产精品18久久久久久不卡孕妇 | 超碰在线免费97 | 日日夜夜天天人人 | 成av人电影| 一区二区三区免费 | 国产成人福利片 | 在线播放精品一区二区三区 | 日韩精品中文字幕在线不卡尤物 | 免费黄色av电影 | 在线播放日韩 | 三级在线视频观看 | 99视频偷窥在线精品国自产拍 | 天天摸夜夜添 | 国产精品久久久久久久久久久久久 | 日本 在线 视频 中文 有码 | 久久久国产精品网站 | 精品国产_亚洲人成在线 | 日本女人b | 在线导航福利 | 亚洲成人av电影在线 | 国产中文在线视频 | 国产亚洲精品久久19p | 欧美日韩国产欧美 | 国产黄色高清 | 国产免费视频在线 | 国产精品毛片一区视频 | 亚洲视频播放 | 成人91在线 | 91在线九色 | 成人免费视频播放 | 中文字幕美女免费在线 | 久久av网 | 国产一区免费看 | 人人澡人摸人人添学生av | 亚洲资源在线网 | 在线视频日韩欧美 | 亚洲色综合 | 日本中文字幕在线免费观看 | 免费在线黄| av在线免费网站 | 久久成人国产精品入口 | 狠狠操狠狠干2017 | 99成人免费视频 | 91中文字幕永久在线 | 日本中文字幕网站 | 欧美日韩国产二区三区 | 91精品视频免费看 | 日本久久久久久科技有限公司 | 欧美久久久久久久久中文字幕 | 亚洲精品影院在线观看 | 成人免费 在线播放 | 国产精品久久久久久久久久尿 | 免费性网站 | 天堂va在线高清一区 | 亚洲 欧美变态 另类 综合 | 爱色婷婷 | 一区二区三区视频网站 | 成人小视频在线观看免费 | 久久成年人视频 | 日韩va亚洲va欧美va久久 | 久久国产三级 | 欧美乱大交 | 三级av片 | 国产伦理一区二区 | 91在线视频一区 | 午夜久久久久久久久久久 | 日韩午夜视频在线观看 | 免费在线一区二区三区 | 亚洲成人精品久久 | 久久综合操 | а中文在线天堂 | 在线你懂的视频 | 国产精品欧美精品 | 国产亚洲精品久久久久秋 | 国产精品激情在线观看 | www成人av| 日韩在线视频免费看 | 婷婷去俺也去六月色 | 中文字幕专区高清在线观看 | 一级淫片在线观看 | 亚洲国产成人高清精品 | 国产不卡在线观看 | 麻花豆传媒mv在线观看网站 | 三日本三级少妇三级99 | 国产成人免费在线 | 国产精品久久久久一区二区 | 日韩va亚洲va欧美va久久 | 日韩av一区二区三区在线观看 | 婷婷激情在线 | 久久国产精品区 | 97电影在线观看 | 蜜臀aⅴ精品一区二区三区 久久视屏网 | 国产精品第7页 | 一区二区三区国产欧美 | 黄在线免费看 | 中文字幕在线播放日韩 | 国产精品国产三级国产aⅴ入口 | 日韩高清免费在线观看 | 西西4444www大胆视频 | 免费黄在线观看 | 果冻av在线 | 国产亚洲精品免费 | 国产一区二区免费看 | 亚洲区精品| 国产美女免费观看 | 最近日本中文字幕 | 久久亚洲成人网 | 波多野结衣在线中文字幕 | 日韩在线观看一区二区 | 天天摸天天操天天舔 | 天天爽夜夜爽人人爽曰av | 亚洲手机天堂 | 国产综合视频在线观看 | 国产亚洲久一区二区 | 国产精品永久 | 精品国产成人av在线免 | 亚洲日本va中文字幕 | 婷婷久久丁香 | 国产亚洲精品久久网站 | 日本黄色大片免费 | 欧美日韩在线视频一区二区 | 一区二区三区影院 | www.亚洲黄 | 91丨九色丨国产在线 | 97成人精品视频在线观看 | 国产精久久久久久妇女av | 在线观看av小说 | 免费午夜视频在线观看 | 中文字幕五区 | 亚洲国产精品99久久久久久久久 | 国产亚洲精品bv在线观看 | 人成在线免费视频 | av免费在线看网站 | 手机成人在线 | 中文字幕日韩精品有码视频 | 丁香婷婷激情 | 在线激情影院一区 | 国产午夜激情视频 | 国产精品美女久久久久久网站 | 黄色aaa级片 | 开心激情婷婷 | www.久久com | 999免费视频| 黄色亚洲在线 | 在线亚洲高清视频 | 久久久久国产一区二区三区 | 五月婷婷视频在线观看 | 99久久精品免费看 | 九九视频一区 | 香蕉在线播放 | www国产亚洲精品久久麻豆 | 日韩在线观看视频一区二区三区 | 国产亚洲综合在线 | 伊人久久av| 五月天婷婷在线播放 | 国产三级视频 | 精品亚洲免费 | 国产精品免费久久久久久久久久中文 | 99久久久成人国产精品 | 麻豆久久 | 欧美精品首页 | 丁香电影小说免费视频观看 | 免费观看一级成人毛片 | 99国产精品| 中日韩在线视频 | 国产精品久久久久久欧美 | 深夜免费小视频 | 日韩av电影网站在线观看 | 欧美一二三四在线 | 国产精品涩涩屋www在线观看 | 最新色视频 | 日韩网站免费观看 | 欧美99热 | 中文字幕免费 | 欧美另类tv | 日韩av高清在线观看 | 国产成人精品免高潮在线观看 | 亚洲伦理中文字幕 | 国产综合91 | 中文字幕一区二区三区乱码不卡 | 亚洲精品福利视频 | 国产 亚洲 欧美 在线 | 亚洲美女免费精品视频在线观看 | www.99热精品| 午夜精品婷婷 | 亚洲aⅴ在线观看 | 中文字幕在线播放一区二区 | 五月婷婷丁香六月 | 蜜桃av人人夜夜澡人人爽 | 91久久久国产精品 | 奇米影视777四色米奇影院 | 天天av综合网 | 久草视频视频在线播放 | 国产成人在线精品 | 波多野结衣网址 | 国产福利在线免费观看 | 精品国产乱码久久久久久天美 | 国产精品区一区 | 天天操天天操天天操天天操天天操 | 在线观看播放av | 日韩女同一区二区三区在线观看 | 狠狠激情中文字幕 | 国产伦理一区 | 日韩天天综合 | 成人av在线一区二区 | 亚洲伊人婷婷 | 91看片淫黄大片在线播放 | 黄色a一级片 | 九九热只有这里有精品 | 久久久久免费精品国产 | 精品亚洲免费视频 | 日操操| 又黄又爽的视频在线观看网站 | 亚洲五月婷 | 婷婷六月天综合 | 91色视频 | 中文字幕久久久精品 | 果冻av在线 | 成人免费精品 | 成人a毛片 | 国产96av| 在线视频 国产 日韩 | 日韩视频免费 | 国产精品激情偷乱一区二区∴ | 精品久久久久久久久久久久久久久久久久 | 久久精品牌麻豆国产大山 | 天天天天天天天操 | 日韩在线网址 | 免费成人看片 | 婷婷综合| 国产很黄很色的视频 | 久久精品中文字幕少妇 | 香蕉免费在线 | 久久一区二区免费视频 | 久久精品精品 | 精品1区2区3区 | 在线视频中文字幕一区 | 香蕉色综合 | 国产最新网站 | 久久精品中文字幕免费mv | 亚洲天堂色婷婷 | 国产一区二区成人 | 日日干夜夜草 | 日韩av手机在线观看 | 国产精品成人免费一区久久羞羞 | 欧美性生活小视频 | 天天插天天狠天天透 | 91中文字幕在线播放 | 久艹视频免费观看 | 伊人超碰在线 | 国产一区二区视频在线 | 公与妇乱理三级xxx 在线观看视频在线观看 | 亚洲 欧美 综合 在线 精品 | 国产精品女同一区二区三区久久夜 | 精品久久久久久久久亚洲 | www.狠狠干| 国产中文字幕三区 | 国产中的精品av小宝探花 | 色伊人网 | 成片免费观看视频大全 | 精品久久一区 | 97在线观看免费观看高清 | 五月情婷婷 | 亚洲电影一级黄 | 色91av| 天天草天天干天天 | 国产美女视频网站 | 亚洲 欧洲 国产 日本 综合 | 国产精品毛片久久蜜 | 国产高清久久久 | 国产一区二区三区免费在线观看 | 黄色的网站免费看 | 久久精品国产v日韩v亚洲 | 综合久久久久久久久 | 中文日韩在线视频 | 国产区在线看 | 欧美精品亚洲精品日韩精品 | 在线免费观看视频一区二区三区 | 国产福利av| 国产视频在| 免费日韩一级片 | 91精品视频在线免费观看 | 日韩欧美高清不卡 | 亚洲不卡av一区二区三区 | 日韩r级电影在线观看 | 国产激情电影综合在线看 | 精品久久久久久综合日本 | 久草视频99 | 麻豆精品在线 | 91av网站在线观看 | 91爱看片| 又长又大又黑又粗欧美 | 色欧美成人精品a∨在线观看 | 国产伦理一区二区三区 | 久久综合99 | 国产精品女人网站 | 久久精品激情 | 国产不卡毛片 | 免费在线观看成年人视频 | 国产中文字幕在线看 | 亚洲一级片在线观看 | 色婷婷国产精品 | 久久免费看毛片 | 日韩免费视频在线观看 | 成人啪啪18免费游戏链接 | 国产精品一区二区麻豆 | 91久久精 | 久久久黄色免费网站 | 97超碰中文字幕 | 国内揄拍国内精品 | 视频一区在线播放 | 中文免费在线观看 | 亚洲我射av | 午夜色站 | 国产专区精品视频 | 国产一区二三区好的 | 91在线视频免费 | 欧美特一级 | 日韩一区二区三区不卡 | 日批网站免费观看 | 成年人视频在线免费播放 | 射射射综合网 | 欧美成a人片在线观看久 | 日本激情视频中文字幕 | 天天天天天天天操 | 午夜精品福利在线 | 久久一本综合 | 国产91精品高清一区二区三区 | 精品国产一区二区在线 | 91av视屏| 五月婷婷中文网 | 中文字幕人成乱码在线观看 | 999电影免费在线观看 | 99久久精品免费一区 | 男女啪啪免费网站 | 国产一级淫片免费看 | 国产欧美日韩一区 | 亚洲 欧美 91| 一区在线播放 | 天天色欧美 | 亚洲激精日韩激精欧美精品 | 97色资源| 久久不射电影院 | 欧美日韩一区二区三区免费视频 | 亚洲国产大片 | av在线不卡观看 | 欧美一区三区四区 | 国产免费视频在线 | 欧美在线视频a | av福利免费 | 四虎影视精品成人 | 热re99久久精品国产99热 | 国产精品欧美久久久久无广告 | 三级av免费观看 | 国产色妞影院wwwxxx | 国产精品丝袜在线 | 黄色www| 午夜精品久久久久久久久久久久 | 成人av一二三区 | 波多野结衣一区二区三区中文字幕 | 国产99久久久国产精品成人免费 | 中文字幕免费高清在线观看 | 最近2019好看的中文字幕免费 | 特级西西444www高清大视频 | 国产亚洲精品久久网站 | 六月婷婷久香在线视频 | 国产欧美日韩一区 | 福利视频 | 区一区二区三区中文字幕 | 狠狠干天天操 | 国产精品欧美精品 | 精品国产成人在线 | 欧美在线日韩在线 | 久草在线视频中文 | 最新av在线播放 | 久草在线最新 | 日韩成人在线免费观看 | 精品 激情 | 中日韩在线视频 | 日韩18p| 亚洲欧洲国产日韩精品 | 久久r精品| 国产视频在线观看免费 | 亚洲欧美在线视频免费 | 偷拍区另类综合在线 | 在线黄色免费av | 操综合| 人人超碰免费 | 国内成人av | 国产剧情一区二区 | 国产乱老熟视频网88av | 超碰97.com| 国产原创在线视频 | 91视频链接 | 国产亚洲日 | 在线观看免费高清视频大全追剧 | 99视频免费播放 | 手机在线中文字幕 | aaa亚洲精品一二三区 | 国产精品久久久久一区二区 | 日韩网站视频 | 日韩三区在线观看 | 999热视频 | 最新成人在线 | 97精品伊人 | 在线观看黄色免费视频 | 韩国av免费观看 | 国产女v资源在线观看 | 国产美女被啪进深处喷白浆视频 | 欧美另类xxx | 亚洲三级毛片 | 欧洲成人av| 婷婷网站天天婷婷网站 | 日韩av免费网站 | 婷婷色影院 | 天天草天天干天天 | 天天在线免费视频 | 国产91免费看 | 99精品国产福利在线观看免费 | 国产高清中文字幕 | 国产色视频一区二区三区qq号 | 婷婷丁香激情五月 | 久久久久99精品国产片 | 91看片在线| av黄色大片 | 91精品国产电影 | 欧美午夜视频在线 | 欧美做受69 | 成人午夜影视 | 69精品久久| 狠狠狠综合 | 韩国av电影在线观看 | 毛片无卡免费无播放器 | 一区二区三区韩国免费中文网站 | 久久综合成人网 | 91热这里只有精品 | 人人搞人人搞 | 欧美 日韩 久久 | 欧美日韩xxxxx | 丝袜av网站| 岛国精品一区二区 | 黄色午夜 | www天天干com | 99久久激情视频 | 天天操天天色综合 | 亚洲五月婷婷 | 天天干天天操天天爱 | 国产一区高清在线 | 国产永久免费观看 | 日韩高清不卡在线 | 亚洲天堂视频在线 | 91在线色 | 免费久久片 | 国产又黄又爽又猛视频日本 | 亚洲国产免费看 | 国产精品美乳一区二区免费 | 黄色av网站在线观看免费 | 日韩精品一区二区免费视频 | 成人免费网站在线观看 | 日韩乱码在线 | 草草草影院 | 中文字幕丝袜 | 97成人精品视频在线观看 | 婷婷综合久久 | 久久久久久久久电影 | 91自拍成人 | 人人干人人爽 | 亚洲综合欧美日韩狠狠色 | 国产一区二区视频在线播放 | 成人欧美在线 | 欧美日在线观看 | 天堂在线一区二区三区 | 免费看的视频 | 久久久久成人免费 | 日本性生活一级片 | 嫩草av在线 | 草久视频在线观看 | 伊人色综合久久天天 | 九九热在线免费观看 | 色综合天天做天天爱 | 亚洲丝袜中文 | 在线观看日韩免费视频 | 国产精品国内免费一区二区三区 | 99成人精品 | 91天天操 | 91麻豆精品国产91久久久更新时间 | 91在线精品一区二区 | 日韩中文在线播放 | 久久影院精品 | 91视频麻豆视频 | 天天干天天操天天爱 | 日韩久久精品一区二区 | 黄色一级性片 | 国产91粉嫩白浆在线观看 | 视频在线观看一区 | 亚洲免费精彩视频 | www夜夜| 久久精品国产v日韩v亚洲 | 99久久精品无免国产免费 | 玖玖玖在线观看 | 国产亚洲一区二区在线观看 | 热九九精品| 国产性天天综合网 | 日韩高清久久 | 日韩在线 | 91久久人澡人人添人人爽欧美 | 欧美日韩一级视频 | 日本护士撒尿xxxx18 | 国产在线观看你懂得 | 欧美日韩视频免费看 | 亚洲视频大全 | 中文字幕一区二区三区在线观看 | 成人av资源网 | 日韩一区二区三区在线观看 | 国产 中文 日韩 欧美 | 国产中文字幕视频在线观看 | 久草在线视频网站 | 久草在线免费播放 | 人人澡超碰碰97碰碰碰软件 | 丁香视频在线观看 | 麻豆视频免费在线观看 | 日日爽天天爽 | 福利视频网站 | 天天综合成人网 | 亚洲三级黄色 | 日韩一区二区三 | 久久久久久国产一区二区三区 | 亚洲电影久久 | 精品视频在线观看 | 日韩精品不卡在线观看 | 日韩在线免费小视频 | 久久99亚洲网美利坚合众国 | 精品毛片在线 | 六月色婷婷 | 婷婷精品国产欧美精品亚洲人人爽 | 日韩免费在线 | 亚洲动漫在线观看 | 日批视频国产 | 国产一级在线视频 | 国产无遮挡猛进猛出免费软件 | 久久综合成人网 | 免费美女久久99 | 夜夜爽88888免费视频4848 | 日韩在线观看一区 | 国产免费又黄又爽 | 国产喷水在线 | 久久久久久久久久久久久9999 | 国产成人区 | 成人免费在线视频 | 亚洲免费精品一区二区 | 国产精品91一区 | 成人在线观看免费视频 | 亚洲aⅴ一区二区三区 | 成人黄色电影在线观看 | 国产精品综合在线 | 国内精自线一二区永久 | 国产专区视频 | 精品专区一区二区 | 久久男人免费视频 | 又黄又爽又湿又无遮挡的在线视频 | av成人免费在线观看 | 婷婷激情在线 | 97av视频在线观看 | 国产成人精品一区二三区 | 免费看成年人 | 一区二区视频播放 | 最近免费中文字幕mv在线视频3 | av片在线观看免费 | 美女视频久久久 | 99久久久久 | 国产一区二区影院 | 精品视频区 | 免费看十八岁美女 | 免费在线观看一区 | 人人澡人人舔 | 在线观看视频 | 五月综合在线观看 | 日韩电影中文字幕 | 成年人视频免费在线播放 | 久久伊人爱 | 在线视频一区观看 | 亚洲精品18日本一区app | 国产精品va在线观看入 | www.亚洲精品| 99免费看片| www.天堂av| 欧美激情视频一区二区三区 | 狠狠干婷婷| 日韩免费一区二区 | 天天综合色 | 国产亚洲在 | 国产视频 亚洲精品 | 日韩a级免费视频 | 在线观看视频国产 | 777视频在线观看 | 免费一级片观看 | 久草视频免费播放 | 黄色网址在线播放 | 欧美天天干 | 精品亚洲一区二区 | 日韩免费久久 | 人人要人人澡人人爽人人dvd | 日韩二区精品 | 日b黄色片 | 97超碰福利久久精品 | 亚洲人片在线观看 | 在线观看亚洲国产 | 免费在线观看av不卡 | 午夜精品视频一区二区三区在线看 | 国产99亚洲 | 成人午夜黄色 | 特级西西444www大胆高清无视频 | 一区二区av | 91九色成人蝌蚪首页 | 99色资源 | 日韩精品大片 | 丁香六月天 | 视频福利在线 | 97超级碰| 久久免费国产电影 | 日韩国产精品久久久久久亚洲 | 99久久婷婷国产精品综合 | 狠狠色噜噜狠狠狠狠2021天天 | 狠狠色综合网站久久久久久久 | 国产成人久久精品77777综合 | 久久99网| 天天干天天摸 | 国产精品国产三级国产不产一地 | 韩日色视频 | 日韩欧美视频免费在线观看 | 国产字幕在线看 | 狠狠干我 | 国产精品美女在线 | 激情婷婷综合 | 91精品伦理 | 天天干,夜夜操 | 国产精品第7页 | 久久尤物电影视频在线观看 | 亚洲经典视频在线观看 | 99r在线播放 | 国产免费久久 | 韩日av一区二区 | 黄色亚洲大片免费在线观看 | 超碰97av在线| 欧美性网站 | 91在线网址 | 二区视频在线观看 | 麻豆久久久久 | 久久久久久久久影视 | 日韩欧美综合精品 | 国产成人精品999 | 国产精品免费看 | 四虎视频 | 亚洲最大av网站 | 日韩在线一区二区免费 | 欧美色图88| 久久精国产 | 国产xvideos免费视频播放 | 在线免费91 | 亚洲成a人片在线观看中文 中文字幕在线视频第一页 狠狠色丁香婷婷综合 | 欧美午夜久久 | 日韩精品亚洲专区在线观看 | 免费看三级黄色片 | 国产精品久久久久影院 |