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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

sparkstreaming 读取mysql_第十篇|SparkStreaming手动维护Kafka Offset的几种方式

發(fā)布時間:2024/9/27 数据库 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 sparkstreaming 读取mysql_第十篇|SparkStreaming手动维护Kafka Offset的几种方式 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

Spark Streaming No Receivers 方式的createDirectStream 方法不使用接收器,而是創(chuàng)建輸入流直接從Kafka 集群節(jié)點拉取消息。輸入流保證每個消息從Kafka 集群拉取以后只完全轉(zhuǎn)換一次,保證語義一致性。但是當(dāng)作業(yè)發(fā)生故障或重啟時,要保障從當(dāng)前的消費位點去處理數(shù)據(jù)(即Exactly Once語義),單純的依靠SparkStreaming本身的機制是不太理想的,生產(chǎn)環(huán)境中通常借助手動管理offset的方式來維護kafka的消費位點。本文分享將介紹如何手動管理Kafka的Offset,希望對你有所幫助。本文主要包括以下內(nèi)容:

  • 如何使用MySQL管理Kafka的Offset
  • 如何使用Redis管理Kafka的OffSet

如何使用MySQL管理Kafka的Offset

我們可以從Spark Streaming 應(yīng)用程序中編寫代碼來手動管理Kafka偏移量,偏移量可以從每一批流處理中生成的RDDS偏移量來獲取,獲取方式為:

KafkaUtils.createDirectStream(...).foreachRDD { rdd => // 獲取偏移量 val offsetRanges = rdd.asInstanceOf[HasOffsetRanges].offsetRanges...}

當(dāng)獲取到偏移量之后,可以將將其保存到外部存儲設(shè)備中(MySQL、Redis、Zookeeper、HBase等)。

使用案例代碼

  • MySQL中用于保存偏移量的表
CREATE TABLE `topic_par_group_offset` (`topic` varchar(255) NOT NULL,`partition` int(11) NOT NULL,`groupid` varchar(255) NOT NULL,`offset` bigint(20) DEFAULT NULL,PRIMARY KEY (`topic`,`partition`,`groupid`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 ;
  • 常量配置類:ConfigConstants
object ConfigConstants {// Kafka配置val kafkaBrokers = "kms-2:9092,kms-3:9092,kms-4:9092"val groupId = "group_test"val kafkaTopics = "test"val batchInterval = Seconds(5)val streamingStorageLevel = StorageLevel.MEMORY_AND_DISK_SER_2val kafkaKeySer = "org.apache.kafka.common.serialization.StringSerializer"val kafkaValueSer = "org.apache.kafka.common.serialization.StringSerializer"val sparkSerializer = "org.apache.spark.serializer.KryoSerializer"val batchSize = 16384val lingerMs = 1val bufferMemory = 33554432// MySQL配置val user = "root"val password = "123qwe"val url = "jdbc:mysql://localhost:3306/kafka_offset"val driver = "com.mysql.jdbc.Driver"// 檢查點配置val checkpointDir = "file:///e:/checkpoint"val checkpointInterval = Seconds(10)// Redis配置val redisAddress = "192.168.10.203"val redisPort = 6379val redisAuth = "123qwe"val redisTimeout = 3000 }
  • JDBC連接工具類:JDBCConnPool
object JDBCConnPool {val log: Logger = Logger.getLogger(JDBCConnPool.getClass)var dataSource: BasicDataSource = null/*** 創(chuàng)建數(shù)據(jù)源** @return*/def getDataSource(): BasicDataSource = {if (dataSource == null) {dataSource = new BasicDataSource()dataSource.setDriverClassName(ConfigConstants.driver)dataSource.setUrl(ConfigConstants.url)dataSource.setUsername(ConfigConstants.user)dataSource.setPassword(ConfigConstants.password)dataSource.setMaxTotal(50)dataSource.setInitialSize(3)dataSource.setMinIdle(3)dataSource.setMaxIdle(10)dataSource.setMaxWaitMillis(2 * 10000)dataSource.setRemoveAbandonedTimeout(180)dataSource.setRemoveAbandonedOnBorrow(true)dataSource.setRemoveAbandonedOnMaintenance(true)dataSource.setTestOnReturn(true)dataSource.setTestOnBorrow(true)}return dataSource}/*** 釋放數(shù)據(jù)源*/def closeDataSource() = {if (dataSource != null) {dataSource.close()}}/*** 獲取數(shù)據(jù)庫連接** @return*/def getConnection(): Connection = {var conn: Connection = nulltry {if (dataSource != null) {conn = dataSource.getConnection()} else {conn = getDataSource().getConnection()}} catch {case e: Exception =>log.error(e.getMessage(), e)}conn}/*** 關(guān)閉連接*/def closeConnection (ps:PreparedStatement , conn:Connection ) {if (ps != null) {try {ps.close();} catch {case e:Exception =>log.error("預(yù)編譯SQL語句對象PreparedStatement關(guān)閉異常!" + e.getMessage(), e);}}if (conn != null) {try {conn.close();} catch {case e:Exception =>log.error("關(guān)閉連接對象Connection異常!" + e.getMessage(), e);}}} }
  • Kafka生產(chǎn)者:KafkaProducerTest
object KafkaProducerTest {def main(args: Array[String]): Unit = {val props : Properties = new Properties()props.put("bootstrap.servers", ConfigConstants.kafkaBrokers)props.put("batch.size", ConfigConstants.batchSize.asInstanceOf[Integer])props.put("linger.ms", ConfigConstants.lingerMs.asInstanceOf[Integer])props.put("buffer.memory", ConfigConstants.bufferMemory.asInstanceOf[Integer])props.put("key.serializer",ConfigConstants.kafkaKeySer)props.put("value.serializer", ConfigConstants.kafkaValueSer)val producer : Producer[String, String] = new KafkaProducer[String, String](props)val startTime : Long = System.currentTimeMillis()for ( i <- 1 to 100) {producer.send(new ProducerRecord[String, String](ConfigConstants.kafkaTopics, "Spark", Integer.toString(i)))}println("消耗時間:" + (System.currentTimeMillis() - startTime))producer.close()} }
  • 讀取和保存Offset:

該對象的作用是從外部設(shè)備中讀取和寫入Offset,包括MySQL和Redis

object OffsetReadAndSave {/*** 從MySQL中獲取偏移量** @param groupid* @param topic* @return*/def getOffsetMap(groupid: String, topic: String): mutable.Map[TopicPartition, Long] = {val conn = JDBCConnPool.getConnection()val selectSql = "select * from topic_par_group_offset where groupid = ? and topic = ?"val ppst = conn.prepareStatement(selectSql)ppst.setString(1, groupid)ppst.setString(2, topic)val result: ResultSet = ppst.executeQuery()// 主題分區(qū)偏移量val topicPartitionOffset = mutable.Map[TopicPartition, Long]()while (result.next()) {val topicPartition: TopicPartition = new TopicPartition(result.getString("topic"), result.getInt("partition"))topicPartitionOffset += (topicPartition -> result.getLong("offset"))}JDBCConnPool.closeConnection(ppst, conn)topicPartitionOffset}/*** 從Redis中獲取偏移量** @param groupid* @param topic* @return*/def getOffsetFromRedis(groupid: String, topic: String): Map[TopicPartition, Long] = {val jedis: Jedis = JedisConnPool.getConnection()var offsets = mutable.Map[TopicPartition, Long]()val key = s"${topic}_${groupid}"val fields : java.util.Map[String, String] = jedis.hgetAll(key)for (partition <- JavaConversions.mapAsScalaMap(fields)) {offsets.put(new TopicPartition(topic, partition._1.toInt), partition._2.toLong)}offsets.toMap}/*** 將偏移量寫入MySQL** @param groupid 消費者組ID* @param offsetRange 消息偏移量范圍*/def saveOffsetRanges(groupid: String, offsetRange: Array[OffsetRange]) = {val conn = JDBCConnPool.getConnection()val insertSql = "replace into topic_par_group_offset(`topic`, `partition`, `groupid`, `offset`) values(?,?,?,?)"val ppst = conn.prepareStatement(insertSql)for (offset <- offsetRange) {ppst.setString(1, offset.topic)ppst.setInt(2, offset.partition)ppst.setString(3, groupid)ppst.setLong(4, offset.untilOffset)ppst.executeUpdate()}JDBCConnPool.closeConnection(ppst, conn)}/*** 將偏移量保存到Redis中* @param groupid* @param offsetRange*/def saveOffsetToRedis(groupid: String, offsetRange: Array[OffsetRange]) = {val jedis :Jedis = JedisConnPool.getConnection()for(offsetRange<-offsetRange){val topic=offsetRange.topicval partition=offsetRange.partitionval offset=offsetRange.untilOffset// key為topic_groupid,field為partition,value為offsetjedis.hset(s"${topic}_${groupid}",partition.toString,offset.toString)}} }
  • 業(yè)務(wù)處理類

該對象是業(yè)務(wù)處理邏輯,主要是消費Kafka數(shù)據(jù),再處理之后進行手動將偏移量保存到MySQL中。在啟動程序時,會判斷外部存儲設(shè)備中是否存在偏移量,如果是首次啟動則從最初的消費位點消費,如果存在Offset,則從當(dāng)前的Offset去消費。

觀察現(xiàn)象:當(dāng)首次啟動時會從頭消費數(shù)據(jù),手動停止程序,然后再次啟動,會發(fā)現(xiàn)會從當(dāng)前提交的偏移量消費數(shù)據(jù)。object ManualCommitOffset {def main(args: Array[String]): Unit = {val brokers = ConfigConstants.kafkaBrokersval groupId = ConfigConstants.groupIdval topics = ConfigConstants.kafkaTopicsval batchInterval = ConfigConstants.batchIntervalval conf = new SparkConf().setAppName(ManualCommitOffset.getClass.getSimpleName).setMaster("local[1]").set("spark.serializer",ConfigConstants.sparkSerializer)val ssc = new StreamingContext(conf, batchInterval)// 必須開啟checkpoint,否則會報錯ssc.checkpoint(ConfigConstants.checkpointDir)ssc.sparkContext.setLogLevel("OFF")//使用broker和topic創(chuàng)建direct kafka streamval topicSet = topics.split(" ").toSet// kafka連接參數(shù)val kafkaParams = Map[String, Object](ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG -> brokers,ConsumerConfig.GROUP_ID_CONFIG -> groupId,ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG -> classOf[StringDeserializer],ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG -> classOf[StringDeserializer],ConsumerConfig.ENABLE_AUTO_COMMIT_CONFIG -> (false: java.lang.Boolean),ConsumerConfig.AUTO_OFFSET_RESET_CONFIG -> "earliest")// 從MySQL中讀取該主題對應(yīng)的消費者組的分區(qū)偏移量val offsetMap = OffsetReadAndSave.getOffsetMap(groupId, topics)var inputDStream: InputDStream[ConsumerRecord[String, String]] = null//如果MySQL中已經(jīng)存在了偏移量,則應(yīng)該從該偏移量處開始消費if (offsetMap.size > 0) {println("存在偏移量,從該偏移量處進行消費!!")inputDStream = KafkaUtils.createDirectStream[String, String](ssc,LocationStrategies.PreferConsistent,ConsumerStrategies.Subscribe[String, String](topicSet, kafkaParams, offsetMap))} else {//如果MySQL中沒有存在了偏移量,從最早開始消費inputDStream = KafkaUtils.createDirectStream[String, String](ssc,LocationStrategies.PreferConsistent,ConsumerStrategies.Subscribe[String, String](topicSet, kafkaParams))}// checkpoint時間間隔,必須是batchInterval的整數(shù)倍inputDStream.checkpoint(ConfigConstants.checkpointInterval)// 保存batch的offsetvar offsetRanges = Array[OffsetRange]()// 獲取當(dāng)前DS的消息偏移量val transformDS = inputDStream.transform { rdd =>// 獲取offsetoffsetRanges = rdd.asInstanceOf[HasOffsetRanges].offsetRangesrdd}/*** 狀態(tài)更新函數(shù)* @param newValues:新的value值* @param stateValue:狀態(tài)值* @return*/def updateFunc(newValues: Seq[Int], stateValue: Option[Int]): Option[Int] = {var oldvalue = stateValue.getOrElse(0) // 獲取狀態(tài)值// 遍歷當(dāng)前數(shù)據(jù),并更新狀態(tài)for (newValue <- newValues) {oldvalue += newValue}// 返回最新的狀態(tài)Option(oldvalue)}// 業(yè)務(wù)邏輯處理// 該示例統(tǒng)計消息key的個數(shù),用于查看是否是從已經(jīng)提交的偏移量消費數(shù)據(jù)transformDS.map(meg => ("spark", meg.value().toInt)).updateStateByKey(updateFunc).print()// 打印偏移量和數(shù)據(jù)信息,觀察輸出的結(jié)果transformDS.foreachRDD { (rdd, time) =>// 遍歷打印該RDD數(shù)據(jù)rdd.foreach { record =>println(s"key=${record.key()},value=${record.value()},partition=${record.partition()},offset=${record.offset()}")}// 打印消費偏移量信息for (o <- offsetRanges) {println(s"topic=${o.topic},partition=${o.partition},fromOffset=${o.fromOffset},untilOffset=${o.untilOffset},time=${time}")}//將偏移量保存到到MySQL中OffsetReadAndSave.saveOffsetRanges(groupId, offsetRanges)}ssc.start()ssc.awaitTermination()} }

如何使用Redis管理Kafka的OffSet

  • Redis連接類
object JedisConnPool {val config = new JedisPoolConfig//最大連接數(shù)config.setMaxTotal(60)//最大空閑連接數(shù)config.setMaxIdle(10)config.setTestOnBorrow(true)//服務(wù)器ipval redisAddress :String = ConfigConstants.redisAddress.toString// 端口號val redisPort:Int = ConfigConstants.redisPort.toInt//訪問密碼val redisAuth :String = ConfigConstants.redisAuth.toString//等待可用連接的最大時間val redisTimeout:Int = ConfigConstants.redisTimeout.toIntval pool = new JedisPool(config,redisAddress,redisPort,redisTimeout,redisAuth)def getConnection():Jedis = {pool.getResource}}
  • 業(yè)務(wù)邏輯處理

該對象與上面的基本類似,只不過使用的是Redis來進行存儲Offset,存儲到Redis的數(shù)據(jù)類型是Hash,基本格式為:[key field value] -> [ topic_groupid partition offset],即 key為topic_groupid,field為partition,value為offset。

object ManualCommitOffsetToRedis {def main(args: Array[String]): Unit = {val brokers = ConfigConstants.kafkaBrokersval groupId = ConfigConstants.groupIdval topics = ConfigConstants.kafkaTopicsval batchInterval = ConfigConstants.batchIntervalval conf = new SparkConf().setAppName(ManualCommitOffset.getClass.getSimpleName).setMaster("local[1]").set("spark.serializer", ConfigConstants.sparkSerializer)val ssc = new StreamingContext(conf, batchInterval)// 必須開啟checkpoint,否則會報錯ssc.checkpoint(ConfigConstants.checkpointDir)ssc.sparkContext.setLogLevel("OFF")//使用broker和topic創(chuàng)建direct kafka streamval topicSet = topics.split(" ").toSet// kafka連接參數(shù)val kafkaParams = Map[String, Object](ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG -> brokers,ConsumerConfig.GROUP_ID_CONFIG -> groupId,ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG -> classOf[StringDeserializer],ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG -> classOf[StringDeserializer],ConsumerConfig.ENABLE_AUTO_COMMIT_CONFIG -> (false: java.lang.Boolean),ConsumerConfig.AUTO_OFFSET_RESET_CONFIG -> "earliest")// 從Redis中讀取該主題對應(yīng)的消費者組的分區(qū)偏移量val offsetMap = OffsetReadAndSave.getOffsetFromRedis(groupId, topics)var inputDStream: InputDStream[ConsumerRecord[String, String]] = null//如果Redis中已經(jīng)存在了偏移量,則應(yīng)該從該偏移量處開始消費if (offsetMap.size > 0) {println("存在偏移量,從該偏移量處進行消費!!")inputDStream = KafkaUtils.createDirectStream[String, String](ssc,LocationStrategies.PreferConsistent,ConsumerStrategies.Subscribe[String, String](topicSet, kafkaParams, offsetMap))} else {//如果Redis中沒有存在了偏移量,從最早開始消費inputDStream = KafkaUtils.createDirectStream[String, String](ssc,LocationStrategies.PreferConsistent,ConsumerStrategies.Subscribe[String, String](topicSet, kafkaParams))}// checkpoint時間間隔,必須是batchInterval的整數(shù)倍inputDStream.checkpoint(ConfigConstants.checkpointInterval)// 保存batch的offsetvar offsetRanges = Array[OffsetRange]()// 獲取當(dāng)前DS的消息偏移量val transformDS = inputDStream.transform { rdd =>// 獲取offsetoffsetRanges = rdd.asInstanceOf[HasOffsetRanges].offsetRangesrdd}/*** 狀態(tài)更新函數(shù)** @param newValues :新的value值* @param stateValue :狀態(tài)值* @return*/def updateFunc(newValues: Seq[Int], stateValue: Option[Int]): Option[Int] = {var oldvalue = stateValue.getOrElse(0) // 獲取狀態(tài)值// 遍歷當(dāng)前數(shù)據(jù),并更新狀態(tài)for (newValue <- newValues) {oldvalue += newValue}// 返回最新的狀態(tài)Option(oldvalue)}// 業(yè)務(wù)邏輯處理// 該示例統(tǒng)計消息key的個數(shù),用于查看是否是從已經(jīng)提交的偏移量消費數(shù)據(jù)transformDS.map(meg => ("spark", meg.value().toInt)).updateStateByKey(updateFunc).print()// 打印偏移量和數(shù)據(jù)信息,觀察輸出的結(jié)果transformDS.foreachRDD { (rdd, time) =>// 遍歷打印該RDD數(shù)據(jù)rdd.foreach { record =>println(s"key=${record.key()},value=${record.value()},partition=${record.partition()},offset=${record.offset()}")}// 打印消費偏移量信息for (o <- offsetRanges) {println(s"topic=${o.topic},partition=${o.partition},fromOffset=${o.fromOffset},untilOffset=${o.untilOffset},time=${time}")}//將偏移量保存到到Redis中OffsetReadAndSave.saveOffsetToRedis(groupId, offsetRanges)}ssc.start()ssc.awaitTermination()}}

總結(jié)

本文介紹了如何使用外部存儲設(shè)備來保存Kafka的消費位點,通過詳細(xì)的代碼示例說明了使用MySQL和Redis管理消費位點的方式。當(dāng)然,外部存儲設(shè)備很多,用戶也可以使用其他的存儲設(shè)備進行管理Offset,比如Zookeeper和HBase等,其基本處理思路都十分相似。

大數(shù)據(jù)技術(shù)與數(shù)倉

總結(jié)

以上是生活随笔為你收集整理的sparkstreaming 读取mysql_第十篇|SparkStreaming手动维护Kafka Offset的几种方式的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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

日韩精品在线免费播放 | 涩五月婷婷 | 国产在线v | 久久精品国产一区二区电影 | 天天操天天操天天操天天操 | 丝袜精品视频 | 精品日韩中文字幕 | 一区二区三区在线免费 | 伊人丁香| 狠狠干夜夜爽 | 999久久久久久久久6666 | 麻豆精品91 | 天天爽夜夜爽人人爽一区二区 | 黄色软件网站在线观看 | 人成午夜视频 | 亚洲一区二区三区在线看 | 国产成视频在线观看 | 91丨九色丨丝袜 | 日韩亚洲在线 | 国产精品精品国产婷婷这里av | 亚洲一区二区天堂 | 亚洲一区二区91 | 亚洲91精品 | 亚洲激情综合 | 在线看一区| 九九九热精品免费视频观看网站 | 国内少妇自拍视频一区 | 日韩中文字幕在线不卡 | 国产在线日本 | 99精品免费久久久久久日本 | 日韩视频一二三区 | 亚洲精品乱码久久久久久9色 | 国产精品久久久久久久久久尿 | 久久好看免费视频 | 久久久久99精品国产片 | 国产精品久久久久久69 | 成人中文字幕在线观看 | 免费久久99精品国产婷婷六月 | 99爱在线| 天天操导航 | 精品久久在线 | 日韩中文字幕免费看 | 色姑娘综合天天 | 色天堂在线视频 | 一区二区三区日韩精品 | 热99在线视频 | 欧美日韩在线免费视频 | 天天操狠狠操夜夜操 | 亚洲成av片人久久久 | 少妇精品久久久一区二区免费 | 国产精品日韩在线 | 日本韩国中文字幕 | 亚洲 欧美 日韩 综合 | 欧美激情精品一区 | 欧美日韩中字 | 久久精品国产成人精品 | 免费看污的网站 | 综合影视 | 亚洲视频999 | 911香蕉视频 | 久久草在线视频国产 | 欧美日韩国产色综合一二三四 | 日韩高清在线不卡 | 亚洲国产精品电影 | 日韩欧美精品在线观看 | 日韩成人免费在线观看 | 91一区啪爱嗯打偷拍欧美 | 成人免费在线观看入口 | 午夜av网站 | 亚洲精品短视频 | 亚洲精品国精品久久99热 | 色av资源网 | 黄色网址a | 人人爽影院 | 精品国偷自产在线 | 999久久a精品合区久久久 | 综合天天网 | 丁香六月在线 | 狠狠操狠狠 | 国产又粗又硬又爽视频 | 性色av香蕉一区二区 | 久草网在线视频 | 91在线porny国产在线看 | 久久午夜网 | 欧美日韩电影在线播放 | 日韩乱理 | 日韩丝袜在线观看 | 91视频电影| 亚洲国产精品成人va在线观看 | 丝袜美腿在线播放 | 久久精品艹 | 亚洲精品玖玖玖av在线看 | 色多多污污 | 中文字幕亚洲高清 | 永久精品视频 | 免费看黄在线观看 | 午夜精品一区二区三区视频免费看 | 日韩欧美精品在线观看 | 久久久久久综合 | 日韩资源在线 | 亚洲成人蜜桃 | 欧美乱码精品一区 | 91av资源网| 天堂av在线网址 | 一区二区三区免费在线观看 | 国产手机在线观看视频 | 国产精品久久一卡二卡 | 丁香久久久 | 很黄很污的视频网站 | 伊人视频 | 亚洲精品玖玖玖av在线看 | 婷婷精品 | 毛片视频网址 | 免费在线视频一区二区 | 国产91精品久久久久久 | 中文字幕高清有码 | 亚洲闷骚少妇在线观看网站 | 日韩一区二区免费视频 | 91传媒视频在线观看 | 久久综合给合久久狠狠色 | 免费看成人 | 香蕉视频在线观看免费 | 国产美女视频 | 国产精品免费久久久久影院仙踪林 | 精品国产一区二区三区四区在线观看 | 少妇资源站 | 国产精品福利无圣光在线一区 | 九草在线视频 | 99爱国产精品 | 欧美视频二区 | 国产一区福利在线 | 色wwwww| 97人人精品| 欧美日韩网站 | 91在线看视频 | 日韩精品电影在线播放 | 亚洲人成综合 | 亚洲精品乱码久久久久久蜜桃91 | av成人动漫 | 国产成人在线观看 | adn—256中文在线观看 | 日日综合网| 婷婷丁香色综合狠狠色 | 国产 一区二区三区 在线 | 欧美另类一二三四区 | 久久精品一区二区 | 国产精品不卡视频 | 欧美国产精品一区二区 | 91久久国产自产拍夜夜嗨 | 狠狠操精品| 中文资源在线播放 | 3d黄动漫免费看 | 国产精品初高中精品久久 | 日韩毛片久久久 | 亚洲精品在线免费看 | 国产精品九色 | 欧美日韩视频在线观看一区二区 | 国产一级二级视频 | 狠狠狠狠狠操 | 久久精品激情 | 日韩在线不卡av | 国产视频在 | 少妇搡bbbb搡bbb搡aa | 欧美日韩高清一区二区 国产亚洲免费看 | 午夜视频在线瓜伦 | 国产视频日韩 | 91av中文 | 日日夜夜综合网 | 久久午夜电影院 | 91亚洲精品国偷拍 | 久久精品在线免费观看 | 中文字幕视频三区 | 成人在线观看免费 | 亚州成人av在线 | 欧美在线观看视频一区二区三区 | 国产我不卡 | 日韩黄视频 | 玖玖国产精品视频 | 免费十分钟 | 最近最新最好看中文视频 | 国产精品久久久久久久久久 | 视频高清 | 美女视频黄免费 | .国产精品成人自产拍在线观看6 | 国产三级午夜理伦三级 | 国产精品高清在线 | 日韩成人邪恶影片 | 99热这里只有精品国产首页 | 免费观看黄色av | 高清色免费 | 日韩美av在线| 亚洲精品成人av在线 | 91黄站| 黄色一级免费网站 | 国产精品福利在线播放 | 午夜视频二区 | 91久久丝袜国产露脸动漫 | 97在线观看免费高清完整版在线观看 | 一区二区三区四区久久 | 四虎国产精品成人免费影视 | 国产精品免费视频一区二区 | 激情深爱五月 | 最近中文字幕第一页 | 久久99久国产精品黄毛片入口 | 久久桃花网 | 欧美一级片在线观看视频 | 国内久久久久久 | 成年人免费在线播放 | 久久人人精 | 操久久网 | 色小说av| 久久伦理电影网 | 久久精品—区二区三区 | 色视频网址 | 91看片成人 | 中文字幕视频网站 | 免费看污在线观看 | www.天天操.com | 亚洲免费视频在线观看 | 超碰在线观看av | 伊人久久国产精品 | 欧美另类调教 | 国产精品成人一区二区三区吃奶 | 六月丁香激情综合色啪小说 | 亚洲黄色成人 | 国产久草在线观看 | 国产无遮挡又黄又爽馒头漫画 | 久久99亚洲网美利坚合众国 | 全黄色一级片 | 精品日韩在线一区 | 亚洲国产mv| 天天看天天干 | 欧美色插| 久久国产网 | 91精品一区在线观看 | 亚州国产精品视频 | 久久精品国产精品亚洲 | 国产一二三四在线视频 | 狠狠躁日日躁狂躁夜夜躁av | 少妇bbw搡bbbb搡bbbb | 免费看的国产视频网站 | 三级黄色片在线观看 | 国产群p视频 | 91亚洲精品久久久蜜桃借种 | 成人在线免费观看视视频 | 97电影在线观看 | 五月婷婷黄色 | 国产精品免费视频网站 | 精品一区二区日韩 | 精品伦理一区二区三区 | 中文在线字幕免费观看 | 久久精品99国产 | 日韩大片在线观看 | 免费日韩 精品中文字幕视频在线 | 久久久国内精品 | 黄色精品久久久 | 日韩理论在线 | 欧美在线你懂的 | av国产在线观看 | 一本一道久久a久久精品蜜桃 | 一区二区三区高清不卡 | 免费成人av| 国模精品一区二区三区 | 亚洲欧洲中文日韩久久av乱码 | v片在线看 | 99 久久久久| av资源免费在线观看 | 毛片网在线观看 | 中文字幕网址 | 91伊人久久大香线蕉蜜芽人口 | 日日干天夜夜 | 国产精品免费在线 | 99国产精品久久久久久久久久 | 午夜国产一区二区 | 一区二区三区在线影院 | 天天射天天干天天 | 亚洲日本激情 | 黄色小说视频网站 | 黄网av在线| www.伊人色.com | 国产精品久久久久久欧美 | 在线观看视频在线 | 欧美aa在线 | 天天干国产 | 91精品国产麻豆国产自产影视 | 国产精品va在线观看入 | 亚洲精品综合一二三区在线观看 | 日本动漫做毛片一区二区 | 色播五月婷婷 | 成人一区不卡 | 人人射人人 | 国产乱对白刺激视频不卡 | 国产一级免费在线观看 | 黄色网大全 | 狠狠狠狠狠狠狠干 | 97视频网址 | 欧美精品在线视频 | 久久久久国产a免费观看rela | 国产精品美女999 | 青青草国产免费 | 亚洲天堂网视频 | 中文字幕成人av | 午夜视频免费播放 | 久久亚洲影院 | 国产精品视频免费 | 久草在线 | 亚洲 欧美 精品 | 97视频在线观看免费 | 成人午夜电影在线观看 | 91热爆在线观看 | 黄色大片视频网站 | 99精品免费视频 | av电影免费在线看 | 中文字幕亚洲综合久久五月天色无吗'' | 99草在线视频| 中文字幕一区在线 | 国产精品美乳一区二区免费 | 黄色1级毛片 | 天天操综合网站 | 国产精品观看 | 天天干婷婷 | 91精品国产乱码在线观看 | 免费大片黄在线 | 久草视频在线播放 | 国产精品一区二区av影院萌芽 | www亚洲国产 | 成人在线观看免费视频 | 国产精品久久久久久久久久久久久久 | www好男人 | 激情欧美一区二区三区 | 免费看片网站91 | 一区二区三区久久精品 | 色婷婷激情 | 蜜臀久久99静品久久久久久 | 日韩精品三区四区 | 天天操天天爽天天干 | 国产精品99久久久精品免费观看 | 国产精品亚洲视频 | 97超在线视频 | 中文字幕中文字幕在线中文字幕三区 | 国产一区二区网址 | 免费成人在线电影 | 性色av免费在线观看 | 午夜精品视频在线 | 日韩成人免费观看 | 丁香视频在线观看 | www.狠狠色.com | 国产剧在线观看片 | av成人黄色| 永久免费的啪啪网站免费观看浪潮 | 国产精品video爽爽爽爽 | 亚洲精品在线二区 | 久久久国产精品成人免费 | 国产一级免费播放 | 天天做天天爱天天综合网 | 国产69精品久久99的直播节目 | 免费观看一级一片 | 婷婷5月激情5月 | 91看片成人 | 97看片| 久久尤物电影视频在线观看 | 99精品小视频 | 久久久久久久久久久成人 | 97在线精品国自产拍中文 | 午夜国产福利在线 | 五月婷婷电影网 | 美女视频是黄的免费观看 | 国产成人精品av在线观 | 人人爱爱 | 国产精品亚 | 亚洲伦理电影在线 | 欧美久草网 | 日韩电影一区二区在线 | 欧美 亚洲 另类 激情 另类 | 尤物九九久久国产精品的分类 | 日本久久久亚洲精品 | 精品国产区| 九九九九免费视频 | 999在线观看视频 | 99久热精品| 成人影片在线播放 | 麻豆播放| 国内视频1区 | 欧美aa在线观看 | 国产精品xxxx18a99 | 亚洲视屏在线播放 | 亚洲欧洲一区二区在线观看 | 日本韩国精品一区二区在线观看 | 久久精品一二三区白丝高潮 | 日韩精品视频在线免费观看 | 91亚洲精品乱码久久久久久蜜桃 | 久久精品观看 | 中文字幕最新精品 | 射射射综合网 | 色视频网站在线观看一=区 a视频免费在线观看 | 美女黄网久久 | 国产黄色在线观看 | 亚洲少妇xxxx | 午夜久久久精品 | 亚洲一区二区三区在线看 | 一区二区三区日韩在线 | 国产91亚洲精品 | 在线播放日韩av | 日韩高清一区 | 成人在线超碰 | 992tv在线观看网站 | 国产精品免费观看网站 | 在线国产高清 | 麻豆影视在线播放 | 欧美日韩中文在线 | 欧美激精品| 天天激情天天干 | 黄毛片在线观看 | 亚洲va韩国va欧美va精四季 | 国产福利资源 | 国产在线视频一区二区 | 亚洲精品在线一区二区三区 | 天天干天天操天天干 | 国产 日韩 欧美 在线 | 啪啪小视频网站 | 午夜私人影院久久久久 | 九九激情视频 | 亚洲高清免费在线 | 国产成人精品在线观看 | 成人av影视在线 | 欧美精品一区二区免费 | 九热在线 | 2019中文字幕第一页 | 亚洲最新av在线网站 | 欧美国产日韩在线观看 | 日本女人在线观看 | 成人高清在线观看 | 99国产精品免费网站 | 国产 在线观看 | 国产精品第十页 | 久久婷婷色综合 | www.啪啪.com| 久久黄色免费观看 | 亚洲美女久久 | 日韩av网页 | 美女黄频免费 | 黄色一级在线免费观看 | 欧美色图亚洲图片 | 国产91精品看黄网站 | 激情在线网址 | 亚洲精品www久久久久久 | 国产精品久久久久久久久搜平片 | 一区二区欧美在线观看 | 日韩av成人免费看 | 日韩免费看 | 四虎影视成人永久免费观看视频 | 99精彩视频 | 99精品亚洲 | 一区二区三区高清不卡 | 日韩av男人的天堂 | 国产麻豆果冻传媒在线观看 | 国产原厂视频在线观看 | 91网页版免费观看 | 99热这里只有精品国产首页 | 黄色免费网站 | 99久在线精品99re8热视频 | 2019av在线视频 | www黄色av| 麻花传媒mv免费观看 | 精品特级毛片 | 国产伦理久久精品久久久久_ | 黄色的视频| 久久999精品 | 久久国产二区 | 欧美精品免费在线 | 午夜影院在线观看18 | 综合五月婷婷 | 最近能播放的中文字幕 | 精品国产一区二区三区久久久蜜月 | 免费在线观看一区 | 日本三级吹潮在线 | 婷婷在线不卡 | 久久久久久久久精 | 亚洲美女视频网 | av成人在线电影 | 亚洲极色| 国产午夜精品一区二区三区 | 色的网站在线观看 | 女人18片| 黄色网免费 | 国产精品第十页 | 五月婷婷婷婷婷 | 亚洲另类xxxx| 99久久日韩精品免费热麻豆美女 | 在线 高清 中文字幕 | 午夜av大片 | 久久伊人操 | 日韩av片无码一区二区不卡电影 | 国内一级片在线观看 | 亚洲国产精品一区二区尤物区 | 91高清视频免费 | 九九热视频在线 | 国产成人性色生活片 | 国产理论影院 | 色5月婷婷| 欧美精品免费一区二区 | 国产一区二区三区久久久 | 免费男女羞羞的视频网站中文字幕 | 欧美性黑人 | 国产成年免费视频 | 精品久久一区二区三区 | 国产成人精品不卡 | 99tvdz@gmail.com| www婷婷| 91av蜜桃 | 国产97在线播放 | 亚洲午夜精品一区 | 欧美日韩一区二区三区在线免费观看 | 国产黄色精品在线 | 国产精品免费av | 看片黄网站 | 91精品亚洲影视在线观看 | 91精品毛片| 日日夜夜天天干 | 91精品国产综合久久福利 | 伊人婷婷网 | 久久久综合精品 | 日韩久久视频 | 国产小视频91 | 黄色免费高清视频 | 99久国产 | 美女免费视频网站 | 黄色一级大片在线免费看国产一 | 亚洲天堂网站 | 色噜噜日韩精品欧美一区二区 | 欧美日韩高清在线 | 黄毛片在线观看 | 日韩av二区 | 久久国产精品第一页 | 超碰在线网 | 在线观看日本高清mv视频 | 伊人影院在线观看 | 不卡中文字幕av | 伊人成人激情 | 国产精品毛片一区二区 | 毛片网站在线观看 | 精品国产免费一区二区三区五区 | av在线看片 | 欧美性高跟鞋xxxxhd | 欧美大片在线观看一区 | 久久久精品午夜 | 亚洲午夜久久久久久久久 | 在线视频你懂 | 国产成人精品国内自产拍免费看 | 欧美日韩大片在线观看 | 欧美一区在线看 | 人人爽人人澡 | 91九色在线播放 | 91视频免费看 | 精品女同一区二区三区在线观看 | 日日夜夜添 | 国产免费久久av | 菠萝菠萝在线精品视频 | 免费精品视频 | 亚洲人成影院在线 | 麻豆国产精品va在线观看不卡 | 激情五月婷婷综合 | 狠狠操狠狠插 | 成人午夜精品福利免费 | 一级电影免费在线观看 | 在线中文字幕网站 | 精品久久久久国产免费第一页 | 欧美午夜精品久久久久 | 日本一区二区三区免费观看 | 国产精品九九视频 | 日韩a在线观看 | 五月婷婷天堂 | 国产一区在线精品 | 日韩高清片 | 午夜色大片在线观看 | 狠狠狠色丁香婷婷综合激情 | 99视频在线观看一区三区 | 免费三及片 | 91精品一区二区三区久久久久久 | 伊人天天狠天天添日日拍 | 亚洲视频一区二区三区在线观看 | 九九精品视频在线观看 | 国产精品久久久久久久7电影 | 国产伦理久久 | 免费精品视频在线 | 夜色成人网 | 中文字幕av网站 | 天天操天天操一操 | 免费a级大片 | 久草视频免费在线观看 | 91丨porny丨九色| 一区二区三区韩国免费中文网站 | 久久不卡视频 | 亚洲精品自拍 | 欧美日韩不卡一区 | 久久综合狠狠综合久久激情 | 成 人 黄 色 免费播放 | 亚洲激情综合 | 天天射天天添 | 日韩欧美精品在线观看 | h动漫中文字幕 | 久久理论影院 | 中文字幕在线观看网站 | 天天拍天天爽 | 国产午夜精品一区二区三区在线观看 | 最新久久免费视频 | 久久精品国产亚洲a | 最新日本中文字幕 | 亚洲国产中文字幕在线视频综合 | 日本三级人妇 | 精品国产中文字幕 | 国内外成人免费在线视频 | 国产黄色一级大片 | 二区视频在线观看 | 日韩综合在线观看 | 久久99久久99久久 | 97超碰人人模人人人爽人人爱 | av在线之家电影网站 | 国产亚洲精品精品精品 | 亚洲成人精品在线 | av免费观看网站 | 三级a视频 | 九九激情视频 | 成人av高清在线观看 | 狠狠躁日日躁狂躁夜夜躁av | 9在线观看免费高清完整 | 色婷婷亚洲精品 | 18性欧美xxxⅹ性满足 | 欧美另类美少妇69xxxx | 99久久毛片 | 人人舔人人插 | 草久中文字幕 | 国内精品久久久久久中文字幕 | 色视频在线观看免费 | 成人国产精品久久久久久亚洲 | 国产精品毛片久久蜜 | 国产精品免费在线播放 | 欧美成人亚洲 | 日韩精品三区四区 | 在线观看黄网 | 伊人手机在线 | 亚洲欧美成人综合 | 国产精品国产三级国产 | 97视频网址| 午夜精品福利一区二区 | 51精品国自产在线 | 色狠狠婷婷 | 欧美日韩中| 国产原创av在线 | 夜夜操网| 日韩黄在线观看 | 免费男女羞羞的视频网站中文字幕 | 中文字幕中文字幕中文字幕 | 日本公妇在线观看 | 久久艹99| 国产成人精品一区二区三区 | 久久99在线观看 | 亚洲狠狠| 欧美中文字幕久久 | 亚洲国产成人在线 | 国产日产精品一区二区三区四区 | 久久人人爽| 成人综合日日夜夜 | 日韩城人在线 | 国产一级精品在线观看 | 亚洲小视频在线观看 | 国产黄色成人av | 日本丰满少妇免费一区 | a天堂在线看 | 91中文字幕网 | 日韩精品中文字幕在线不卡尤物 | 正在播放 久久 | 国产久草在线 | 色爱成人网 | 亚洲免费精品一区二区 | 欧美一区在线看 | 国产精品久久婷婷六月丁香 | 国内综合精品午夜久久资源 | 天天综合网久久综合网 | 在线观看中文av | 91视频高清免费 | 亚洲免费国产视频 | 日韩欧美在线一区 | 国语精品免费视频 | 99视频免费 | 日韩视频免费 | 国产精品视频专区 | 欧美一区二区精美视频 | 天天色天天干天天 | 性色va| 日韩色在线观看 | 亚洲国产精品999 | 久久久久久久网 | 久久国产亚洲视频 | 天天干,天天射,天天操,天天摸 | 岛国精品一区二区 | 欧美性生爱 | 日日干天夜夜 | 91久久久久久久 | 精品在线观看国产 | 玖玖精品在线 | 成年人黄色免费网站 | 99超碰在线播放 | 成人免费观看视频网站 | 天天操天天干天天插 | 久久久久久高潮国产精品视 | 成人免费一区二区三区在线观看 | 日韩三级av | 四虎影视国产精品免费久久 | 99 久久久久 | 狠狠操导航 | 亚洲精品www| 国产视频在线看 | 国产区精品视频 | av在线电影网站 | 久久国产精品久久精品国产演员表 | 最新国产中文字幕 | 伊在线视频 | 99热在线观看 | 国产尤物在线视频 | 99综合视频 | 婷婷色5月| 99久久影院 | 国产尤物在线视频 | 亚洲精品在线二区 | 不卡日韩av | 日韩av片免费在线观看 | 久操操 | 国产小视频在线观看 | 久久综合欧美 | 中文在线免费视频 | 99爱在线观看| 在线看的毛片 | 久久在线免费观看 | 国产亚洲精品成人av久久影院 | 国产999精品久久久 免费a网站 | 激情综合五月婷婷 | 久久精品第一页 | 91在线观| 色吊丝在线永久观看最新版本 | 久久视频6 | 91视频91蝌蚪 | 免费日韩电影 | 国产成人a亚洲精品v | 天天曰天天曰 | 天天激情综合网 | 中文字幕在线观看第一页 | 成人在线一区二区 | 久久色在线观看 | 欧美 激情在线 | 日韩久久视频 | 999国内精品永久免费视频 | 一区二区三区免费看 | 国产精品va在线观看入 | 欧美精品乱码久久久久 | 色老板在线 | 808电影免费观看三年 | 国产精品久久久久久久久蜜臀 | 99久热在线精品视频 | 精品久久久网 | 中文字幕在线观看av | 97超碰.com| 国产精品久久久区三区天天噜 | 天天干天天干天天操 | 国产你懂的在线 | 中文字幕 婷婷 | 精品视频成人 | 久久综合网色—综合色88 | 国产精品1000 | 久久精品99国产精品日本 | 在线观看你懂的网址 | 最近中文字幕在线播放 | 成人毛片a | 久久一久久 | 碰超在线观看 | 最新一区二区三区 | 一级免费av| 91片在线观看 | 国产免费叼嘿网站免费 | 日韩视频www | av在线播放观看 | 69视频在线 | 久草视频免费观 | 久福利| 97综合在线| 国内精品久久天天躁人人爽 | 国产伦精品一区二区三区… | 国产精品丝袜久久久久久久不卡 | 蜜臀久久99精品久久久无需会员 | 精品99999| 日韩欧美精品一区二区 | 毛片网在线播放 | 成人动漫一区二区 | 综合激情av | 黄色在线看网站 | 久久开心激情 | 久久综合久久久 | 国产高清中文字幕 | 日本久久成人 | 国产伦理久久 | 欧美黄污视频 | 免费看网站在线 | 夜夜躁日日躁狠狠久久av | 人人艹视频 | 免费看的视频 | 欧美一级高清片 | 黄网站色成年免费观看 | 综合久久久久久久久 | 91视频观看免费 | 精品久久网 | 不卡视频在线 | 国产不卡在线播放 | 欧洲成人av | 欧美精品免费在线观看 | 天堂在线成人 | 日韩av影视| 国产97在线观看 | 久久国产精品免费观看 | 欧美资源 | 久久国产精品免费一区 | 狠狠躁夜夜躁人人爽视频 | 久久婷婷综合激情 | 国语自产偷拍精品视频偷 | aaaaaa毛片| av中文字幕网址 | 成人国产精品一区二区 | 国产综合香蕉五月婷在线 | 欧美日韩二区三区 | 精品国产一区二区三区久久久蜜月 | 久久精品3| 国产精品成人一区二区 | 操操日| 亚洲黄色三级 | 国产欧美综合在线观看 | 最新动作电影 | 亚洲国产av精品毛片鲁大师 | 一本一本久久a久久精品综合小说 | 久章草在线 | 欧美日韩另类在线观看 | 91麻豆精品国产91久久久久久 | 嫩草伊人久久精品少妇av | 在线免费观看黄网站 | 色就色,综合激情 | 精品a视频 | 伊人色综合久久天天 | av手机版 | av电影在线观看 | 香蕉网址 | 久久久久久久久久久影院 | 久久精品高清 | 国产永久免费观看 | 欧美日韩一区二区视频在线观看 | 99热这里只有精品免费 | 国产成人333kkk | 91精品国产91久久久久 | 韩国在线一区二区 | 久久精品1区 | 国产成人精品av久久 | 美女久久 | 正在播放国产一区二区 | 夜夜骑首页 | 日韩av资源在线观看 | 精品美女在线视频 | 国产精品黄色影片导航在线观看 | 中文字幕第一页在线视频 | 在线亚州 | 日韩城人在线 | 亚洲在线视频观看 | 激情网第四色 | av片一区| 国产资源 | 免费视频a | 精品视频在线视频 | 亚洲精品午夜久久久 | 久久精品国产精品 | 国产日女人 | 日韩二区三区在线观看 | 丝袜美腿在线 | 日韩av高潮 | 久久亚洲电影 | 中文字幕第一页在线 | 国产亚洲在线视频 | 免费麻豆| 99成人精品 | 中文理论片 | 欧美一区二区在线 | 国产精品麻豆果冻传媒在线播放 | 91视频传媒 | 色婷婷国产在线 | 青春草免费在线视频 | 深夜视频久久 | 天堂资源在线观看视频 | 国产资源网 | 国产黄色片免费看 | 欧美精品在线观看一区 | 午夜免费福利视频 | 色五婷婷 | 嫩草91影院 | 久久久久免费网站 | 色多多在线观看 | 久久久久久久毛片 | 久久久久免费精品国产小说色大师 | 亚洲精品网页 | 久久精品婷婷 | 色五月情 | 精品国产乱码一区二区三区在线 | 久久久久一区二区三区 | 国产在线一区二区三区播放 | 夜夜骑首页| 亚洲闷骚少妇在线观看网站 | 亚洲欧洲在线视频 | 成人h电影在线观看 | 午夜在线观看影院 | 欧美激情精品久久久久久变态 | 六月丁香婷婷在线 | 人人爽人人爽人人片av免 | 久久久久看片 | 奇米网网址 | 一级免费片| 超碰av免费| 五月天婷婷视频 | 鲁一鲁影院 | 九九有精品 | 色综合久久久久综合 | 亚洲欧美日韩在线一区二区 | 香蕉手机在线 | 国产成人一区二区三区在线观看 | www.亚洲视频.com | 国产精品6999成人免费视频 | 久久久www成人免费毛片麻豆 | 婷婷国产一区二区三区 | 中文字幕人成一区 | 99免费在线视频 | 久久影院亚洲 | 中文字幕日韩av | 欧美极度另类 | av一级在线 | 五月婷婷爱 | 91精品国产入口 | 国产色就色 | 亚洲最新av在线网址 | www日韩高清| 国产午夜精品一区二区三区在线观看 | 中文成人字幕 | 欧美久久久久久久久久久 | www.99在线观看 | 综合视频在线 | 日本aaa在线观看 | 日韩精品视 | 日韩av女优视频 | 日韩精品久久久久久 | 成人在线你懂得 | 日韩在线观看第一页 | 一本一本久久a久久精品综合 | 久久99热这里只有精品国产 | 女人18片毛片90分钟 | 国产精品久久久久久久久久久久 | 日韩一三区 | 亚洲婷婷综合色高清在线 | 中文字幕成人 | 午夜久久影视 | 国产毛片aaa | 懂色av懂色av粉嫩av分享吧 | 天天色中文 | 天天在线视频色 | 久草资源免费 | 国产免费观看av | 91成人短视频在线观看 | 欧美精品久久久久性色 | 伊人六月 | 粉嫩一区二区三区粉嫩91 | 久操97| 日韩激情av在线 | 看国产黄色大片 | 中文字幕在线有码 | 国产日韩欧美网站 | 在线免费观看麻豆视频 | 白丝av免费观看 | 欧美另类tv | 色偷偷97 | 成人日批视频 | 精品视频99 | 色久五月 | 国产一级免费观看视频 | 午夜av在线免费 | 五月天.com| 欧美另类网站 | 青青草在久久免费久久免费 | 国产精品久久精品 | 天天干视频在线 | 2021国产精品视频 | 日韩高清免费电影 | 一区二区三区在线影院 | 国产成人久久av免费高清密臂 | 国产精品女主播一区二区三区 | 久久影院亚洲 | 久久精品女人毛片国产 | 久久国产精品视频免费看 |