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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

spark 车流量项目实战

發布時間:2023/12/10 编程问答 43 豆豆
生活随笔 收集整理的這篇文章主要介紹了 spark 车流量项目实战 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

spark 車流量項目實戰

這里目錄標題

  • spark 車流量項目實戰
    • 1、車流向項目介紹
      • 1.1. 數據采集
      • 1.2. 模塊介紹
        • 1.2.1. 卡扣流量分析模塊介紹
      • 1.3. 項目架構介紹
      • 1.4. 數據介紹
        • 1.4.1. 基本概念
        • 1.4.2. 表
      • 1.5. 需求分析
    • 2、數據流程
    • 3、spark任務
      • 如何將Spark任務提交到集群運行?
    • 4、模塊功能
      • 4.1、卡口流量分析
        • 4.1.1. 卡口狀態監控
          • 4.1.1.1. 統計卡口壞攝像頭
          • 4.1.1.2. 統計每個區域車流量
          • 4.1.1.3. 統計每個區域的攝像頭
          • 4.1.1.5 卡口流量分析 代碼解析
        • 4.1.2. 區域車流量Top3及其速度
        • 4.1.3. 區域中高低速數量
        • 4.1.3. 指定卡口對應卡口車輛軌跡
      • 4.2、行車軌跡
        • 4.2.1. 車輛行車軌跡
        • 4.2.2. 車輛套牌
        • 4.2.3. 車輛抽樣--蓄水池抽樣算法
        • 4.2.4. 道路轉換率
      • 4.3、區域道路流量Top3
        • 4.3.1 RDD解決
        • 4.3.2. Java連接Hive---SQL解決
      • hive中導入模擬數據
      • 4.4、Streaming 實時
        • 4.4.1. 道路實時擁堵情況 --kafka
        • 4.4.2. 動態改變廣播變量(布控)

1、車流向項目介紹

1.1. 數據采集

數據從哪兒來?

  • 我們知道數據來來源,比如網站,APP或者工業設備(比如卡口拍攝設備)實現實時數據采集,它首先有非常重要的一點就是所謂的埋點,也就是說,埋點,在網站的哪個頁面哪些操作發生時,前端的代碼比如javascript或者app android/ios,就通過網絡請求Ajax; socket向后端的服務器發送日志數據。
  • 如果是卡口信息,那么每次拍攝的信息都會傳輸到服務器端。
  • 首先就是說網站或者頁面設置埋點,那么就是你要跟前端的開發人員約定好,在哪些頁面哪些操作發生的時候,網站的話就通過ajax引擎,APP的話就通過Socket網絡請求,向后端的服務器發送指定格式的日志數據。卡口數據的話,是和廠商定制數據格式的,數據以指定的格式向服務器發送實時的數據。
  • 接著通過Flume監控指定的文件夾,轉移到HDFS里面去,實際大多數是放在Hive中因為Hive還有計算的能力,還有另外一條流程,實時數據,通常都是從分布式消息隊列集群中讀取的,比如Kafka,實時的log,實時的寫入消息隊列中,然后再由我們后端實時數據處理程序(storm、spark streaming),實時從kafka中讀取數據,log日志
  • 數據除了從Flume中來,也有可能直接使用kafka 的producer角色往kafka中直接生產數據
  • 接下來就是大數據實時計算系統,比如說用storm、spark streaming開發的,可以實時的從kafka中拉取數據,然后對實時的數據進行處理和計算,這里可以有非常復雜的業務邏輯,甚至調用復雜的機器學習,數據挖掘,智能推薦的算法!然后實現實時的車輛調度,實時推薦等等。
  • 1.2. 模塊介紹

    • 卡扣流量分析 Spark Core
    • 卡扣車流量轉化率 Spark Core
    • 各區域車流量最高top5的道路統計 SparkSQL
    • 稽查布控,道路實時擁堵統計 SparkStreaming

    1.2.1. 卡扣流量分析模塊介紹

    根據使用者(平臺使用者)指定的某些條件,篩選出指定的一批卡扣信息(比如根據區域、時間篩選)

    檢測卡扣狀態,對于篩選出來的所有的卡口(不代表一個攝像頭)信息統計

  • 卡口正常數
  • 異常數
  • camera的正常數
  • camera的異常數
  • camera的詳細信息(monitor_id:camera_id)
  • 車流量最多的TonN卡扣號,延伸獲取每一個卡扣的詳細信息(Top5 )
  • 隨機抽取N個車輛信息,對這些數據可以進行多維度分析(因為隨機抽取出來的N個車輛信息可以很權威的代表整個區域的車輛)
  • 計算出經常高速通過的TopN卡口 (查看哪些卡扣經常被高速通過,高速,中速,正常,低速 根據三個速度段進行四次排序,高速通過的車輛數相同就比較中速通過的車輛數,以此來推)
  • 1.3. 項目架構介紹

    使用架構

    J2EE平臺,前端頁面,在頁面中可以指定任務類型,提交任務的參數(比如時間范圍,區域設定)平臺會接受到用戶的提交請求,會調用底層封裝的Spark-submit的shell腳本,怎么調用?運行的作業可以獲取到用戶指定的篩選條件,然后根據篩選條件進行計算。Spark任務的計算結果會寫入到數據庫中,比如MySQL,Redis等
    最后J2EE平臺可以通過前端頁面,展示結果(表格或者圖表的方式展示數據庫中的結果)。

    1.4. 數據介紹

    1.4.1. 基本概念

    卡扣號:在一條道路相同位置會有兩個卡扣,這兩個卡扣的編號是不同的,分別拍攝不同方向的車輛

    攝像頭編號:每一個卡扣拍攝的是一個方向的車輛,每一個方向都會有多個不同的車道,每一個車道對應一個攝像頭,所以卡扣號與攝像頭的對應關系是一對多的關系。

    1.4.2. 表

    monitor_flow_action表監控到的車流信息表
    date日期 單位:天
    monitor_id卡口號
    camera_id攝像頭編號
    car車牌
    action_time某個攝像頭拍攝時間 單位:秒
    speed通過卡扣的速度
    road_id道路id
    area_id區域ID
    monitor_camera_info表每個卡扣對應的攝像頭編號(標準表)
    monitor_id卡扣編號
    camera_id攝像頭編號

    具體內容見建表語句。

    1.5. 需求分析

    • 按條件篩選卡扣信息
      • 可以指定 不同的條件,時間范圍、區域范圍、卡扣號等 可以靈活的分析不同區域的卡扣信息
    • 監測卡扣狀態
      • 對符合條件的卡扣信息,可以動態的檢查每一個卡扣的狀態,查看卡扣是否正常工作,也可以查看攝像頭
    • 車流量最多的TonN卡扣
      • 查看哪些卡扣的車流量最高,為什么會出現這么高的車流量。分析原因,例如今天出城的車輛非常多,啥原因,今天進城的車輛非常多,啥原因? 集會還是聚集? 這個功能點里面也會拿到具體的車輛的信息,分析一下本地車牌造成的還是外地車牌?
    • 在符合條件的卡扣信息中隨機抽取N個車輛信息
      • 隨機抽取N輛車的信息,可以權威的代表整個區域的車輛,這時候可以分析這些車的軌跡,看一下在不同的時間點車輛的流動方向。以便于道路的規劃。
    • 計算出經常高速通過的TopN卡口
      • 統計出是否存在飆車現象,或者經常進行超速行駛,可以在此處安裝違章拍攝設備

    2、數據流程

    數據處理流程:

    公司有集群沒有數據 分布式爬取數據,多節點爬取數據,一般將數據爬取到flume中,或者將數據直接爬取放入HDFS中。 公司有集群有數據 每天每時每刻在產生數據,數據直接清洗放在HBase或者HDFS中。或者日志數據直接使用flum導入分布式文件中。

    一般有了數據之后又分為兩個大的方向處理數據:

  • 假設數據放在了HDFS集群中之后,一般下一步就要清洗數據,可以將數據通過Hive清洗,當然這里Hive一般使用外表,這樣做的目的是可以將相同的數據只在HDFS中存入一份,避免過多的重復數據。清洗完成的數據一般又會放入Hive表中或者以結構化的數據放在HDFS上。得到清洗后的數據后一般會使用MR或者使用Spark來對數據進行分析處理,也可以對清洗后的數據使用SparkSQL來進行處理分析。之后,將分析完成的數據放入數據庫中,如Redis,Mysql,Oracle中,供前端查詢展示。
  • 如果數據放入了flume中,一般將數據sink到kafka中,不同數據的種類放入不同的topic中。然后對打入kafka中的數據進行流式處理,一般可以使用storm或者SparkStreaming對數據進行清洗,分析處理,然后將結果放到數據庫中,如Redis,Mysql,Oracle中,以供前端頁面來查詢展示。
  • 3、spark任務

    如何將Spark任務提交到集群運行?

    最次也是腳本化執行Spark任務。

    平臺化提交Spark任務。流程圖如下:

    submit后先將數據存入Mysql中,task當做唯一主鍵,這樣做是為了簡化任務執行失敗時,可以直接在數據庫中查詢之前的提交的業務參數,當任務失敗后,下次retry時方便執行。

    submit后可以使用java調用liunx系統腳本,通過taskId得到系統中的業務參數數據。

    注意: 假如使用tomcat實現平臺化,那么tomcat應該部署在客戶端。

    l java代碼中如何執行liunx腳本?

    Process proc = Runtime.**getRuntime**().exec(“sh 腳本”); proc.waitFor();

    4、模塊功能

    4.1、卡口流量分析

    • 全部使用SparkCore實現。

    4.1.1. 卡口狀態監控

    4.1.1.1. 統計卡口壞攝像頭
    def main(args: Array[String]): Unit = {//獲取數據源val sparkSession = ContextUtils.getSparkSession("Hello01MonitorState")//讀取數據MockDataUtil.mock2view(sparkSession)//------------------------------統計卡口攝像頭通過的車輛的合計----------------------------import sparkSession.implicits._//開始讀取數據val dataFrame: DataFrame = sparkSession.sql("select * from " + MockDataUtil.MONITOR_FLOW_ACTION + " where date = '2021-08-19' ")//開始操作val mcRdd: RDD[(String, Int)] = dataFrame.map(ele => Tuple2(ele.getString(1) + ":" + ele.getString(2), 1)).rdd//開始進行合并val flowRdd: RDD[(String, Int)] = mcRdd.reduceByKey(_ + _)//------------------------------統計卡口所有的攝像頭----------------------------val cameraDataFrame = sparkSession.sql("select * from " + MockDataUtil.MONITOR_CAMERA_ACTION)val cameraRdd: RDD[(String, Int)] = cameraDataFrame.map(ele => ((ele.getString(0) + ":" + ele.getString(1)), 1)).rdd//------------------------------合并車流量和攝像頭RDD----------------------------val allRDD: RDD[(String, (Option[Int], Int))] = flowRdd.rightOuterJoin(cameraRdd).filter(ele => ele._2._1.isEmpty)allRDD.foreach(println)}

    4.1.1.2. 統計每個區域車流量
    def main(args: Array[String]): Unit = {//獲取數據源val sparkSession = ContextUtils.getSparkSession("Hello02MonitorFlowCount")//讀取數據MockDataUtil.mock2view(sparkSession)//------------------------------統計卡口通過的車輛的合計----------------------------import sparkSession.implicits._//開始讀取數據val dataFrame: DataFrame = sparkSession.sql("select * from " + MockDataUtil.MONITOR_FLOW_ACTION + " where date = '2021-08-23' ")//開始操作val mcRdd: RDD[(String, Int)] = dataFrame.map(ele => Tuple2(ele.getString(1), 1)).rdd//開始進行合并val flowRdd: RDD[(String, Int)] = mcRdd.reduceByKey(_ + _)flowRdd.foreach(println)}

    4.1.1.3. 統計每個區域的攝像頭
    def main(args: Array[String]): Unit = {val sparkSession = ContextUtils.getSparkSession("Hello03MonitorStateAnalyze")MockDataUtil.mock2view(sparkSession)//---------------------開始操作車流量信息,假設任務編號為1 日期參數為今天val flowInfo: RDD[(String, String)] = sparkSession.sql("select * from " + MockDataUtil.MONITOR_FLOW_ACTION + " where date = '2021-08-23' ").rdd.map(row => (row.getString(1), row)).groupByKey().map(ele => {val monitorId: String = ele._1val cameraIdSet = new mutable.HashSet[String]()ele._2.foreach(row => cameraIdSet.add(row.getString(2)))//拼接字符串val info: String = Constants.FIELD_MONITOR_ID + "=" + monitorId + "|" + Constants.FIELD_AREA_ID + "=浦東新區|" + Constants.FIELD_CAMERA_IDS + "=" + cameraIdSet.mkString("-") + "|" + Constants.FIELD_CAMERA_COUNT + "=" + cameraIdSet.size + "|" + Constants.FIELD_CAR_COUNT + "=" + ele._2.size//返回結果(monitorId, info)})//-----------------------開始操作攝像頭數據val monitorInfo: RDD[(String, String)] = sparkSession.sql("select * from " + MockDataUtil.MONITOR_CAMERA_ACTION).rdd.map(row => (row.getString(0), row.getString(1))).groupByKey().map(ele => {val monitorId: String = ele._1//拼接字符串val info: String = Constants.FIELD_CAMERA_IDS + "=" + ele._2.toList.mkString("-") + "|" + Constants.FIELD_CAMERA_COUNT + "=" + ele._2.size//返回結果(monitorId, info)})//-----------------------將數據Join到一起monitorInfo.leftOuterJoin(flowInfo).foreach(println)}

    4.1.1.5 卡口流量分析 代碼解析

    4.1.2. 區域車流量Top3及其速度

    • 區域車流量top3
    def main(args: Array[String]): Unit = {val sparkSession = ContextUtils.getSparkSession("AreaTop3Road")MockDataUtil.mock2view(sparkSession)//開始計算val fRdd: RDD[Row] = sparkSession.sql("select * from " + MockDataUtil.MONITOR_FLOW_ACTION + " where date = '2021-08-23' ").rddfRdd.map(row => (row.getString(7) + "_" + row.getString(6) + "&" + (Math.random() * 30 + 10).toInt, 1)).reduceByKey(_ + _).map(ele => {val area_road_random = ele._1val count = ele._2(area_road_random.split("_")(0), area_road_random.split("_")(1).split("&")(0) + "_" + count)}).groupByKey().map(ele => {val map = new mutable.HashMap[String, Int]()ele._2.foreach(e => {val key = e.split("_")(0)val value = e.split("_")(1).toIntmap.put(key, map.get(key).getOrElse(0) + value)})"區劃【" + ele._1 + "】車輛最多的三條道路分別為:" + map.toList.sortBy(_._2).takeRight(3).reverse.mkString("-")}).foreach(println)}

    • 區域各路速度
    def main(args: Array[String]): Unit = {val sparkSession = ContextUtils.getSparkSession("AreaTop3Speed")MockDataUtil.mock2view(sparkSession)val sRdd: RDD[Row] = sparkSession.sql("select * from " + MockDataUtil.MONITOR_FLOW_ACTION + " where date = '2021-08-23' ").rddsRdd.map(e=>{((e.getString(7),e.getString(6)),e.getString(5).toInt)}).groupByKey().map(e=>{val list: List[Int] = e._2.toListval i: Int = list.sum/list.size(e._1._1,(e._1._2,i))}).groupByKey().map(e=>{val tuples = e._2.toList.sortBy(_._2).reverse.take(3)var strBui: StringBuilder = new StringBuilderfor (i <- tuples ){val str: String = i._1 + "-均速度為:" + i._2strBui.append(">>>"+str)}(e._1,strBui)}).foreach(println)}

    4.1.3. 區域中高低速數量

    object Hello04MonitorTopNSpeed {def main(args: Array[String]): Unit = {val sparkSession = ContextUtils.getSparkSession("Hello04MonitorTopNSpeed")MockDataUtil.mock2view(sparkSession)//---------------------開始操作車流量信息,假設任務編號為1 日期參數為今天val flowRdd: RDD[Row] = sparkSession.sql("select * from " + MockDataUtil.MONITOR_FLOW_ACTION + " where date = '2021-08-20' ").rddval monitor2speedRDD: RDD[(String, Iterable[String])] = flowRdd.map(row => (row.getString(1), row.getString(5))).groupByKey()val speedCount2monitorRDD: RDD[(SpeedCount, String)] = monitor2speedRDD.map(ele => {//獲取卡口號val monitorId: String = ele._1//聲明一個Map[0,60,100,120]var high = 0;var normal = 0;var low = 0;//獲取所有的速度的車輛技術ele._2.foreach(speed => {//判斷速度if (speed.toInt > 100) {high += 1} else if (speed.toInt > 60) {normal += 1} else {low += 1}})//創建速度對象(SpeedCount(high, normal, low), monitorId)})speedCount2monitorRDD.sortByKey(false).map(x => (x._2, x._1)).foreach(println)} }case class SpeedCount(high: Int, normal: Int, low: Int) extends Ordered[SpeedCount] with KryoRegistrator {override def compare(that: SpeedCount): Int = {var result = this.high - that.highif (result == 0) {result = this.normal - that.normalif (result == 0) {result = this.low - that.low}}return result}override def registerClasses(kryo: Kryo): Unit = {kryo.register(SpeedCount.getClass)} }

    4.1.3. 指定卡口對應卡口車輛軌跡

    def main(args: Array[String]): Unit = {val sparkSession = ContextUtils.getSparkSession("Hello04MonitorTopNSpeed")MockDataUtil.mock2view(sparkSession)//獲取數據val area01Rdd: RDD[Row] = sparkSession.sql("select * from " + MockDataUtil.MONITOR_FLOW_ACTION + " where date = '2021-08-23' and area_id = '01' ").rddval area02Rdd: RDD[Row] = sparkSession.sql("select * from " + MockDataUtil.MONITOR_FLOW_ACTION + " where date = '2021-08-23' and area_id = '02' ").rddval area01CarRdd = area01Rdd.map(row => (row.getString(3), row.getString(7))).groupByKey()val area02CarRdd = area02Rdd.map(row => (row.getString(3), row.getString(7))).groupByKey()area01CarRdd.join(area02CarRdd).foreach(println)}

    4.2、行車軌跡

    4.2.1. 車輛行車軌跡

    def main(args: Array[String]): Unit = { val sparkSession = ContextUtils.getSparkSession("AreaCar") MockDataUtil.mock2view(sparkSession)//查詢 車子行駛軌跡 跟車分析 val c1Rdd: RDD[Row] = sparkSession.sql("select * from " + MockDataUtil.MONITOR_FLOW_ACTION + " where date = '2021-08-23' ").rdd val carRdd: RDD[(String, StringBuilder)] = c1Rdd.map(e => { (e.getString(3), (e.getString(4), e.getString(6), e.getString(2))) }).groupByKey() .map(e => { val tuples: List[(String, String, String)] = e._2.toList.sortBy(_._1) val list = new StringBuilder for (i <- tuples) { //println(i) val str: String = i._2 + ":" + i._3 list.append(str + "-") } (e._1, list) }) //carRdd.foreach(println) }

    4.2.2. 車輛套牌

    def main(args: Array[String]): Unit = {val sparkSession = ContextUtils.getSparkSession("AreaCar")MockDataUtil.mock2view(sparkSession) //假設任何的卡口距離都是 10分鐘車程 ,如果同一分鐘出現在不同的卡口就懷疑是套牌val deckRdd: RDD[Row] = sparkSession.sql("select * from " + MockDataUtil.MONITOR_FLOW_ACTION + " where date = '2021-08-23' ").rdddeckRdd.map(e => {val dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss")(e.getString(3), (dateFormat.parse(e.getString(4)),e.getString(1)))}).groupByKey(1).map(e => {val list: List[(util.Date, String)] = e._2.toList.sortBy(x=>x._1)var bool = falsevar d: util.Date = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").parse("2021-08-23 00:00:00")var mid="?"for (i <- list) {if (d.getTime - i._1.getTime < 600000 && i._2!=mid )bool = trued = i._1mid=i._2}(e._1, bool)}).filter(f => f._2).foreach(println)}

    4.2.3. 車輛抽樣–蓄水池抽樣算法

    def main(args: Array[String]): Unit = {val sparkSession = ContextUtils.getSparkSession("Hello04MonitorTopNSpeed")MockDataUtil.mock2view(sparkSession)//獲取數據val flowRdd: RDD[Row] = sparkSession.sql("select * from " + MockDataUtil.MONITOR_FLOW_ACTION + " where date = '2021-08-21' ").rdd//yyyy-MM-dd_HH , rowval hourRDD: RDD[(String, Row)] = flowRdd.map(row => (DateUtils.getDateHour(row.getString(4)), row))//車流量的總數,并進行廣播val flowAllCount: Long = hourRDD.count()val broadcastFlowAllCount: Broadcast[Long] = sparkSession.sparkContext.broadcast(flowAllCount)//計算每個小時的比例 并進行廣播val hourRatio: collection.Map[String, Double] = hourRDD.countByKey().map(e => {(e._1, e._2 * 1.0 / broadcastFlowAllCount.value)})val broadcastHourRatio: Broadcast[collection.Map[String, Double]] = sparkSession.sparkContext.broadcast(hourRatio)//開始進行抽樣val sampleRDD: RDD[Row] = hourRDD.groupByKey().flatMap(ele => {val hour: String = ele._1val list: List[Row] = ele._2.iterator.toList//計算本時段要抽樣的數據量val sampleRatio: Double = broadcastHourRatio.value.get(hour).getOrElse(0)val sampleNum: Long = Math.round(sampleRatio * 100)//開始進行取樣(蓄水池抽樣)val sampleList: ListBuffer[Row] = new ListBuffer[Row]()sampleList.appendAll(list.take(sampleNum.toInt))for (i <- sampleNum until list.size) {//隨機生成一個數字val num = (Math.random() * list.size).toIntif (num < sampleNum) {sampleList.update(num, list(i.toInt))}}sampleList})sampleRDD.foreach(println)}

    4.2.4. 道路轉換率

    def main(args: Array[String]): Unit = {//創建會話val sparkSession = ContextUtils.getSparkSession("Hello07MonitorConvertRatio")MockDataUtil.mock2view(sparkSession)//開始計算val flowRdd: RDD[Row] = sparkSession.sql("select * from " + MockDataUtil.MONITOR_FLOW_ACTION + " where date = '2021-08-23' ").rdd//計算每個卡口的總通車量val monitorCountMap: collection.Map[String, Long] = flowRdd.map(row => (row.getString(1), row)).countByKey()//計算卡口到卡口的通行率val sortRDD: RDD[(String, List[Row])] = flowRdd.map(row => (row.getString(3), row)).groupByKey().map(ele => (ele._1, ele._2.iterator.toList.sortBy(_.getString(4))))val m2mMap: collection.Map[String, Long] = sortRDD.flatMap(ele => {//存放映射關系val map: mutable.HashMap[String, Int] = mutable.HashMap[String, Int]()val list: List[Row] = ele._2.toListfor (i <- 0 until list.size; j <- i + 1 until list.size) {//拼接Keyval key = list(i).getString(1) + "->" + list(j).getString(1)map.put(key, map.get(key).getOrElse(0) + 1);}//返回結果map.toList}).countByKey()//開始進行計算m2mMap.foreach(ele => {println("卡口[" + ele._1 + "]的轉換率為:" + ele._2.toDouble / monitorCountMap.get(ele._1.split("->")(0)).get)}) }

    4.3、區域道路流量Top3

    • 數據傾斜問題
      • key添加后綴擴組,減小數據傾斜

    4.3.1 RDD解決

    def main(args: Array[String]): Unit = {//創建會話val sparkSession = ContextUtils.getSparkSession("Hello07MonitorConvertRatio")MockDataUtil.mock2view(sparkSession)//開始計算val flowRdd: RDD[Row] = sparkSession.sql("select * from " + MockDataUtil.MONITOR_FLOW_ACTION + " where date = '2021-08-23' ").rdd//開始計算flowRdd.map(row => (row.getString(7) + "_" + row.getString(6) + "&" + (Math.random() * 30 + 10).toInt, 1)).reduceByKey(_ + _).map(ele => {val area_road_random = ele._1val count = ele._2(area_road_random.split("_")(0), area_road_random.split("_")(1).split("&")(0) + "_" + count)}).groupByKey().map(ele => {val map = new mutable.HashMap[String, Int]()ele._2.foreach(e => {val key = e.split("_")(0)val value = e.split("_")(1).toIntmap.put(key, map.get(key).getOrElse(0) + value)})"區劃【" + ele._1 + "】車輛最多的三條道路分別為:" + map.toList.sortBy(_._2).takeRight(3).reverse.mkString("-")}).foreach(println) }

    4.3.2. Java連接Hive—SQL解決

    • hive中導入模擬數據

  • 打開hive手動創建database 為traffic 。

  • 生產模擬數據,將模擬數據提交到linux上。

  • 將data2hive代碼 打包,提交到客戶端運行。

  • 查詢hive中數據庫為traffic中monitor_flow_action和monitor_camera_info兩張數據庫表是否導入數據。

  • 若出現mysql數據庫亂碼的問題

    在安裝mysql的linux節點路徑/etc/my.cnf中加入:

    • 在[client]下添加
      default-character-set=utf8
    • 在[mysqld]下添加
      default-character-set=utf8

    如圖:

    運行項目中AreaTop3RoadFlowAnalyze代碼

    4.4、Streaming 實時

    4.4.1. 道路實時擁堵情況 --kafka

    • 生產者
    public class MockRealTimeData extends Thread {private static final Random random = new Random();private static final String[] locations = new String[]{"魯", "滬", "滬", "滬", "滬", "京", "京", "深", "京", "京"};private static final String topic = "RoadRealTimeLog";private KafkaProducer<String, String> producer;public MockRealTimeData() {//創建配置文件列表Properties properties = new Properties();// kafka地址,多個地址用逗號分割properties.put("bootstrap.servers", "192.168.100.101:9092,192.168.100.102:9092,192.168.100.103:9092");//設置寫出數據的格式properties.put("key.serializer", "org.apache.kafka.common.serialization.StringSerializer");properties.put("value.serializer", "org.apache.kafka.common.serialization.StringSerializer");//寫出的應答方式properties.put("acks", "all");//錯誤重試properties.put("retries", 1);//批量寫出properties.put("batch.size", 16384);//創建生產者對象producer = new KafkaProducer<String, String>(properties);}public void run() {while (true) {String date = DateUtils.getTodayDate();String baseActionTime = date + " " + StringUtils.fullFill(random.nextInt(24) + "");baseActionTime = date + " " + StringUtils.fullFill((Integer.parseInt(baseActionTime.split(" ")[1]) + 1) + "");String actionTime = baseActionTime + ":" + StringUtils.fullFill(random.nextInt(60) + "") + ":" + StringUtils.fullFill(random.nextInt(60) + "");String monitorId = StringUtils.fullFill(4, random.nextInt(9) + "");String car = locations[random.nextInt(10)] + (char) (65 + random.nextInt(26)) + StringUtils.fullFill(5, random.nextInt(99999) + "");String speed = random.nextInt(260) + "";String roadId = random.nextInt(50) + 1 + "";String cameraId = StringUtils.fullFill(5, random.nextInt(9999) + "");String areaId = StringUtils.fullFill(2, random.nextInt(8) + "");//封裝消息對象ProducerRecord<String, String> banRecordBlue = new ProducerRecord<>(topic, "traffic_" + monitorId, date + "\t" + monitorId + "\t" + cameraId + "\t" + car + "\t" + actionTime + "\t" + speed + "\t" + roadId + "\t" + areaId);//發送消息producer.send(banRecordBlue);try {Thread.sleep(50);} catch (InterruptedException e) {e.printStackTrace();}}}/*** 啟動Kafka Producer** @param args*/public static void main(String[] args) {MockRealTimeData mockRealTimeData = new MockRealTimeData();mockRealTimeData.start();} }
    • 消費者
    object Hello10RealRoadState {def main(args: Array[String]): Unit = {//創建Confval sparkConf = new SparkConf().setAppName("Hello10RealRoadState").setMaster("local[2]")val streamingContext = new StreamingContext(sparkConf, Seconds(2))//創建Kafka讀取數據//配置信息val kafkaParams = Map[String, Object]("bootstrap.servers" -> "node01:9092,node02:9092,node03:9092","key.deserializer" -> classOf[StringDeserializer],"value.deserializer" -> classOf[StringDeserializer],"group.id" -> "traffic","auto.offset.reset" -> "earliest","enable.auto.commit" -> (false: java.lang.Boolean))val topics = Array("RoadRealTimeLog")//開始創建Kafkaval linesDStream: InputDStream[ConsumerRecord[String, String]] = KafkaUtils createDirectStream(streamingContext, PreferConsistent, Subscribe[String, String](topics, kafkaParams))//窗口函數linesDStream.map(_.value()).window(Seconds(10), Seconds(10)).map(ele => (ele.split("\t")(1), ele.split("\t")(5).toInt)).groupByKey().map(ele => {(ele._1, ele._2.toList.sum.toDouble / ele._2.size)}).foreachRDD(rdd => {rdd.foreach(ele => {println(ele._1 + "--" + ele._2)})})//啟動任務streamingContext.start()streamingContext.awaitTermination() } }

    4.4.2. 動態改變廣播變量(布控)

    總結

    以上是生活随笔為你收集整理的spark 车流量项目实战的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    www.久久久| 日韩视频免费播放 | 久久国产三级 | 久久伦理电影 | 日韩成人免费观看 | 久久综合网色—综合色88 | 国产精品久久综合 | 黄a在线观看 | 99久久精品久久久久久动态片 | 久久免费毛片 | 精品主播网红福利资源观看 | 国产视频第二页 | 欧美日韩一区久久 | 日韩国产精品久久 | 91大神精品视频在线观看 | 国产一级免费片 | 在线观看香蕉视频 | 香蕉影视 | 中文字幕 国产视频 | 国产欧美日韩精品一区二区免费 | 美女一区网站 | 99久久精品电影 | 色婷婷综合久久久中文字幕 | 国模精品一区二区三区 | 国产精品久久伊人 | 在线观看亚洲精品 | 天天草天天干天天射 | 欧美综合在线视频 | 国产精品高潮久久av | 最新国产精品拍自在线播放 | 欧美精品免费在线观看 | 欧美精品久久久久久久久老牛影院 | 日韩精品视频第一页 | 国产精品美女久久久久久久 | 日韩理论在线观看 | 免费日韩精品 | 中文字幕观看在线 | 综合国产在线观看 | 黄色毛片在线观看 | 国产精品一区二区在线观看 | 久久精品视频免费观看 | 国内精自线一二区永久 | 狠狠色伊人亚洲综合网站色 | av视屏在线播放 | 亚洲综合网站在线观看 | 久久精品一区二区三区四区 | 日批网站在线观看 | 欧美成人xxxxx| 99视频国产精品免费观看 | 天天操天天摸天天射 | 免费成人av网站 | 日本久久久亚洲精品 | 国产精品粉嫩 | 亚洲美女精品视频 | 中文字幕国产精品一区二区 | 麻豆免费视频 | 欧美人操人 | 欧美性生活大片 | 国产欧美综合在线观看 | 亚洲激情 在线 | 国产一区精品在线观看 | 国内精品久久久久久久影视麻豆 | 中文字幕在线播放日韩 | 久久免费观看少妇a级毛片 久久久久成人免费 | 中文字幕视频一区 | 黄色一级片视频 | 天天拍天天草 | 色婷婷视频网 | 久久五月婷婷丁香社区 | 成人av直播 | 午夜aaaa| 波多野结衣在线观看一区二区三区 | 在线观看国产永久免费视频 | 成人小电影在线看 | 中文字幕麻豆 | 曰本免费av| 精品嫩模福利一区二区蜜臀 | 97在线视频免费播放 | 日日天天干| 日本公乱妇视频 | 成人9ⅰ免费影视网站 | 亚洲精品女 | 国产又粗又猛又色 | 91人人网 | 久久婷婷色综合 | 狠狠色丁香婷婷综合基地 | 91av电影| 国产a视频免费观看 | 色综合天天综合网国产成人网 | a天堂中文在线 | 精品一区二区精品 | 久久久久久久av麻豆果冻 | 久久成人国产精品入口 | 在线视频久久 | 久久久综合精品 | 91色九色 | 国产精品嫩草69影院 | 波多野结衣视频一区二区三区 | 午夜三级福利 | 探花视频在线观看免费版 | 久久久久北条麻妃免费看 | 免费激情网 | 超碰在线色 | 一区在线播放 | 在线 视频 一区二区 | 久久看片网 | 久草免费新视频 | 欧美日韩免费网站 | 夜夜高潮夜夜爽国产伦精品 | 天天插狠狠插 | 亚洲国产日韩av | 在线视频日韩一区 | 久久无码精品一区二区三区 | 中文字幕国语官网在线视频 | 亚洲成人av一区二区 | 99久久久久久国产精品 | 国产日韩欧美自拍 | 美女网站色免费 | 福利精品在线 | 久久婷婷五月综合色丁香 | 在线 国产 亚洲 欧美 | 91大神视频网站 | 伊甸园永久入口www 99热 精品在线 | 综合激情 | 国产人成看黄久久久久久久久 | 91精品国自产拍天天拍 | 日韩欧美精品一区 | av青草| 国产成人福利在线观看 | 91粉色视频| 五月婷婷av | 99精品视频在线观看 | 日韩激情精品 | 91视频免费播放 | 久久精品视频免费播放 | 亚洲影视九九影院在线观看 | 亚洲精品福利在线 | 狠狠五月婷婷 | 免费在线一区二区 | 欧美日本中文字幕 | 色香com. | 亚洲欧美日韩在线一区二区 | 成人免费观看在线视频 | 九九国产视频 | 五月激情电影 | 在线观看不卡的av | 久久呀 | 国产精品视频免费在线观看 | 中文字幕亚洲综合久久五月天色无吗'' | 福利片视频区 | 亚洲精品黄网站 | 狠狠狠狠狠狠狠 | 中文字幕在线播放一区二区 | 成片人卡1卡2卡3手机免费看 | 亚洲综合欧美精品电影 | 麻花豆传媒mv在线观看网站 | 东方av在线免费观看 | 手机av在线不卡 | av视屏在线| 久草久视频 | 欧美精品中文字幕亚洲专区 | 999久久国产精品免费观看网站 | 麻豆极品 | 日韩电影一区二区三区 | 在线免费视频a | 奇米网在线观看 | 91麻豆精品国产自产在线 | 国产日产欧美在线观看 | 公与妇乱理三级xxx 在线观看视频在线观看 | 在线视频 一区二区 | 久久久久久久精 | 色婷婷88av视频一二三区 | 国产精久久久久久久 | 国产精品免费麻豆入口 | 91看片在线免费观看 | 成人一区二区在线观看 | 99免费在线视频 | 中文字幕欧美日韩va免费视频 | 国产精品麻豆一区二区三区 | 色婷婷午夜| 在线播放国产一区二区三区 | 中文在线中文资源 | 久热色超碰 | 久久精品日韩 | 欧美另类z0zx | 99 视频 高清 | 99精品黄色片免费大全 | 超碰免费久久 | 亚洲精品视频在线播放 | 国产黄色片久久 | 久久艹国产 | 欧美va天堂va视频va在线 | 亚洲国产精品久久久久婷婷884 | 五月天色综合 | 久久福利影视 | 青青久视频 | 亚洲黄色成人网 | 伊人av综合 | 欧美视频一区二 | 92国产精品久久久久首页 | 手机av资源 | 国产精品免费一区二区 | 97超碰在线免费观看 | 国产精品一区二区三区在线看 | 国产麻豆精品在线观看 | 成人免费视频在线观看 | 国产精品久久久久久影院 | 免费av电影网站 | 精品一区二区在线免费观看 | www.香蕉视频 | 亚洲精品资源在线观看 | 久久成人欧美 | 99国产精品久久久久老师 | 欧美一级电影在线观看 | 久久最新视频 | 久久国产精品系列 | 天天操夜操视频 | 在线观看理论 | 国产成人福利在线观看 | 亚洲欧美婷婷六月色综合 | 免费看的黄色小视频 | 丁香网婷婷 | 99r国产精品| 久久99精品国产99久久 | 久久免费视频精品 | 国产亚洲精品成人av久久影院 | www.久热| 日韩电影一区二区三区 | 久久久久久久久久久久99 | www.天天干.com | 亚洲一区不卡视频 | 麻豆mv在线观看 | 伊人亚洲综合网 | 一区二区欧美日韩 | 欧美三级高清 | 欧美污在线观看 | 日韩大片免费在线观看 | 美女又爽又黄 | 色婷婷免费 | 国产在线免费观看 | 久草手机视频 | 天天操天 | 日本久久不卡视频 | 99精品久久只有精品 | 97视频免费| 精品久久精品 | 韩国精品福利一区二区三区 | 日韩天堂在线观看 | 色多多视频在线 | 五月婷丁香网 | 国产免费又黄又爽 | 久久久这里有精品 | 欧美一二三视频 | 国产欧美精品xxxx另类 | 精品免费视频123区 午夜久久成人 | 亚洲人成人99网站 | 久久人人爽人人爽人人 | 精品久久一二三区 | 国产成人精品av在线观 | 九九九九热精品免费视频点播观看 | 亚洲一级黄色大片 | 久久久久久久久黄色 | www免费网站在线观看 | 久久免费国产精品1 | 天天射天天射天天 | 久久乐九色婷婷综合色狠狠182 | 国内精品久久久久久久久久清纯 | 最新日本中文字幕 | 欧美亚洲国产精品久久高清浪潮 | japanesexxxxfreehd乱熟 | 欧美日韩一区久久 | 久草www | 欧美日韩中文国产一区发布 | 国产福利精品一区二区 | 伊人国产在线播放 | 亚洲精品国产精品国产 | 国产精品久久久久一区二区三区共 | 亚洲最新毛片 | 97超碰免费在线观看 | 国产精品毛片久久久 | 日韩在线观看高清 | 999成人精品 | 国产精品av在线免费观看 | 在线免费观看国产 | 中文av字幕在线观看 | 狠狠色丁香久久婷婷综合五月 | 91精品国产自产在线观看永久 | 成年人视频免费在线播放 | 97香蕉久久国产在线观看 | 丁香花在线视频观看免费 | 欧美成人精品欧美一级乱黄 | 97热久久免费频精品99 | 深爱开心激情 | 99久久精品国| 99热超碰 | 黄色不卡av| 亚洲好视频 | 免费看污片 | 丁香六月在线观看 | 欧美激情精品久久久久久 | 激情久久综合 | 伊人影院99| 区一区二区三在线观看 | 九九免费精品视频 | 精品国产乱码久久久久 | 成人午夜电影在线 | 婷婷免费在线视频 | 免费aa大片 | 国产日韩欧美视频 | 在线亚洲午夜片av大片 | 国产日韩高清在线 | 国产剧情在线一区 | 亚洲午夜久久久综合37日本 | av免费网| 色综合久久久久久久 | 日本中文字幕一二区观 | 日韩超碰| av在线免费播放网站 | 国产成人亚洲在线观看 | 二区精品视频 | 国产免费久久精品 | 国产精品久久久久久久午夜片 | 欧美在线久久 | 黄色网在线免费观看 | 国产手机在线观看视频 | 99精品视频一区二区 | 久久免费视频在线观看 | 国产精品18久久久久久久 | 99热在线国产 | 亚洲精品午夜一区人人爽 | 91麻豆精品国产自产在线游戏 | av中文字幕在线电影 | 欧美精品久久久久久久 | 国产一区二区视频在线播放 | 亚洲色图 校园春色 | 日韩视频一区二区三区在线播放免费观看 | 中文在线免费观看 | 婷婷播播网 | 丝袜足交在线 | 免费a级毛片在线看 | www.亚洲视频.com| 国产91影院| 亚洲视频网站在线观看 | 亚洲好视频 | 久久国产女人 | 国产成人一区二区三区 | 制服丝袜在线 | 国产精品一区二区三区久久 | 免费在线| 日韩av一区二区在线播放 | 丁香花在线观看免费完整版视频 | 天天操人人干 | 亚洲人人精品 | 国产精品黄色影片导航在线观看 | 天天摸天天舔天天操 | 亚洲最大av在线播放 | 美女精品在线观看 | 亚洲欧洲在线视频 | 久久精品三级 | 色九色| 日韩欧美在线视频一区二区 | 在线看岛国av | 亚洲综合在线观看视频 | 中字幕视频在线永久在线观看免费 | 97精品国自产拍在线观看 | 日韩精品一区二区三区丰满 | 久久国产精品免费一区 | 激情大尺度视频 | 中文字幕在线观看日本 | 四虎影视精品永久在线观看 | 久久久久久国产精品久久 | 99r在线播放| 免费a网 | 国产综合福利在线 | 国内精品亚洲 | 亚洲国产丝袜在线观看 | 欧美色综合天天久久综合精品 | 国产精品女视频 | 欧美另类成人 | 精品国产三级a∨在线欧美 免费一级片在线观看 | av电影在线观看完整版一区二区 | 99久久久久成人国产免费 | 五月婷婷六月综合 | 久久久综合香蕉尹人综合网 | av 一区二区三区 | 国产日韩欧美视频在线观看 | 国产黄色片免费看 | www免费网站在线观看 | 日韩黄色中文字幕 | 激情伊人五月天久久综合 | 国产精品成人品 | 日本久久电影网 | 欧美精品一区二区性色 | 91桃花视频 | 天天碰天天操视频 | 九七在线视频 | 国产一区二区免费看 | 久草网视频在线观看 | 四虎国产精| 亚洲乱码一区 | 日韩精品一卡 | 99热高清 | 综合网中文字幕 | 国产资源精品 | 欧美日韩免费在线视频 | 久久这里只有精品9 | 午夜av影院| 亚洲成人av影片 | 欧美日韩中文在线视频 | 精品久久久免费 | 欧美一区二区在线免费看 | 免费福利小视频 | 久草观看 | 狠狠操91| 亚洲天堂免费视频 | 日本成人中文字幕在线观看 | 成人app在线播放 | 在线国产视频一区 | 国产一区二区高清 | 99精品国产免费久久久久久下载 | 久久久久久久网 | 欧美韩国日本在线观看 | 亚洲欧美乱综合图片区小说区 | 在线影院av | 久久爱影视i | 亚洲国产精品成人va在线观看 | 91av观看| av在线一级| 香蕉日日 | 在线看片视频 | 久久99国产视频 | 亚洲一区二区黄色 | 人人干天天射 | 久久久福利视频 | 亚洲在线视频观看 | 精品一区二区在线观看 | 黄p网站在线观看 | 8x成人免费视频 | 国产精品美女在线 | 在线亚洲成人 | 亚洲午夜精品一区 | 婷婷国产v亚洲v欧美久久 | 国产手机在线观看视频 | 欧美性天天 | 综合激情 | 国产高清视频在线播放 | 91女人18片女毛片60分钟 | 久久久亚洲麻豆日韩精品一区三区 | 国产精品一区二区无线 | 欧美日一级片 | 久久久久免费精品国产小说色大师 | 精品96久久久久久中文字幕无 | 久久久久国产成人免费精品免费 | zzijzzij亚洲日本少妇熟睡 | 亚洲精品乱码久久久久久蜜桃动漫 | 久草爱视频 | 久久综合久久八八 | 精品国产一区二区三区久久久蜜月 | 久久免费高清 | 99久久久国产精品 | 天天操夜操视频 | 久久久久免费网 | 免费视频资源 | 爱爱av在线 | 国产视频久久久久 | 久久亚洲电影 | 日韩系列在线 | 欧美激情另类文学 | 色狠狠干 | 欧美日韩高清一区二区三区 | 国产精品99久久久久的智能播放 | 午夜黄色一级片 | 91精品久久香蕉国产线看观看 | 五月婷婷综| 久久久www成人免费精品张筱雨 | 国产精品久久婷婷六月丁香 | 国产精品第一页在线 | 狠色狠色综合久久 | 天天天色综合a | 久久久久这里只有精品 | 久久精品一区二区三区四区 | 成 人 黄 色 视频免费播放 | 麻豆视频免费网站 | 久久国产影视 | 亚洲女同ⅹxx女同tv | www.在线观看av | 美女久久久久久久久久 | 中文字幕在线免费97 | 久久女教师 | 久久亚洲区 | 天天操夜夜操夜夜操 | 久久精品国产亚洲 | 二区视频在线观看 | 日韩视频在线观看免费 | 久久精彩 | 在线导航福利 | 日韩欧美第二页 | 黄网站大全 | 久久久久免费观看 | 国产精品久久电影网 | 青青河边草免费视频 | 欧美国产不卡 | 国产一二三精品 | 日韩大片在线免费观看 | 国产亚洲永久域名 | 色综合亚洲精品激情狠狠 | 成人黄在线 | 久久久午夜精品理论片中文字幕 | 一区二区 精品 | 国产精品麻 | 亚洲精品欧美精品 | 亚洲欧美视频一区二区三区 | 日本特黄特色aaa大片免费 | 国产精品白丝av | 97在线观看视频国产 | 日本爽妇网 | av中文在线影视 | 狠狠色噜噜狠狠狠狠2022 | 精品久久视频 | av在线com| 欧美 激情 国产 91 在线 | 丰满少妇久久久 | 久久尤物电影视频在线观看 | 久久国产精品久久久 | 精品色综合 | 四虎在线观看视频 | 2000xxx影视 | 激情亚洲综合在线 | 精品国产欧美一区二区三区不卡 | 国产视频网站在线观看 | 少妇bbbb揉bbbb日本 | 91日韩在线专区 | 日韩欧美有码在线 | 色在线亚洲 | 亚洲视频免费在线看 | 亚洲国产欧洲综合997久久, | 永久中文字幕 | 国产午夜一区 | 天天操天 | 欧美日韩国产综合一区二区 | 久久激情小说 | 国产私拍在线 | 69视频永久免费观看 | 亚洲精品中文字幕视频 | 综合久久2023 | 伊人久久一区 | 久久久久综合视频 | 欧美福利片在线观看 | 在线激情小视频 | 欧美日韩aa | 81国产精品久久久久久久久久 | 中日韩欧美精彩视频 | 国产亚洲亚洲 | 在线中文字母电影观看 | 在线免费视 | 国产黄色在线网站 | 一本一本久久a久久精品牛牛影视 | 欧美精品乱码久久久久久 | 波多野结衣亚洲一区二区 | 国产一区二区三区在线免费观看 | 在线观看成人小视频 | 精品久久久久久国产偷窥 | 精品国产乱码久久久久久三级人 | 激情婷婷网 | 亚洲精品麻豆视频 | 中文字幕制服丝袜av久久 | 成人一级黄色片 | 综合伊人av | 日本精品一二区 | 国产精品久久网站 | 国产亚洲片 | 91视频这里只有精品 | 欧美激精品 | 欧美天天综合网 | 欧美日韩国产精品一区二区三区 | 国产999精品 | 国产免费资源 | 天天做天天射 | 四虎在线免费视频 | 中文字幕字幕中文 | 91av在线不卡 | 五月婷婷综合久久 | 色.www| 日韩视频在线播放 | 在线观看亚洲精品视频 | 欧美激情xxxx性bbbb | 国产在线观看一 | 人人爱爱 | 久久久久久久久久久久影院 | 色综合天天爱 | 日韩婷婷| 成年人免费观看国产 | 欧美va天堂在线电影 | 国产精品久久久久久久久久ktv | 亚洲天堂网在线视频观看 | 看黄色91 | 免费观看性生活大片 | 成年人在线看片 | 中文字幕有码在线 | 日韩av在线一区二区 | 人人舔人人干 | 99视频| 美女性爽视频国产免费app | 97在线精品国自产拍中文 | 四虎影视成人永久免费观看亚洲欧美 | 一区二区毛片 | 免费观看国产成人 | 国产精品一二 | 国产视频2区 | 久久精品直播 | 99热这里只有精品久久 | 99久热精品| 日本特黄特色aaa大片免费 | 六月激情 | 5月丁香婷婷综合 | 91重口视频| 中文字幕免费播放 | 蜜臀av网站 | 香蕉视频国产在线观看 | 又长又大又黑又粗欧美 | 在线看日韩 | 五月天激情在线 | 欧美成人在线免费观看 | 欧美人体xx | 国产精品岛国久久久久久久久红粉 | 欧美老少交| 91在线色| 日韩在线二区 | 极品久久久久久久 | 亚洲精品视频在线观看免费视频 | 久草在线播放视频 | 九九免费在线观看 | 久草在线久草在线2 | 国产精彩在线视频 | 97热在线观看 | 国产福利精品在线观看 | 毛片网在线播放 | 在线免费日韩 | 麻豆一级视频 | 97品白浆高清久久久久久 | 天天射天天射天天射 | 成人免费视频网 | 色大片免费看 | 97视频在线免费播放 | 伊人黄色网| 国产三级香港三韩国三级 | 九九热精品在线 | 国产精品ⅴa有声小说 | 五月婷婷中文网 | 日韩黄色免费在线观看 | 黄色一级网 | 国产一区私人高清影院 | av九九| 亚洲最快最全在线视频 | 欧美最新大片在线看 | 中文字幕在线看 | 婷婷色视频 | 国产精品免费观看国产网曝瓜 | 亚洲精品一区二区三区新线路 | 欧美-第1页-屁屁影院 | 国产美女精品视频免费观看 | 婷婷视频导航 | 国产精品午夜在线 | 97精产国品一二三产区在线 | 99精品在线视频播放 | 国产不卡精品 | 天天摸日日摸人人看 | 狠狠的操狠狠的干 | 国产精品99久久久久久大便 | 日韩精品在线一区 | 五月婷婷丁香激情 | 在线中文字幕播放 | 丁香六月天| 婷婷久操 | 国偷自产视频一区二区久 | 亚洲乱码精品 | 视频一区二区视频 | 国产精品综合av一区二区国产馆 | 四虎影视精品永久在线观看 | 欧美日韩亚洲精品在线 | 欧美成人亚洲 | 国产精品12| 久久精品视频在线观看 | 国产一二区视频 | 日韩电影在线观看一区二区三区 | 五月天天天操 | 日本最新中文字幕 | 九九精品久久 | 国产在线观看你懂得 | 婷婷色网站 | 精品久久精品久久 | 91在线麻豆 | 天天色天天综合 | 黄色小视频在线观看免费 | 69亚洲精品 | 色噜噜狠狠色综合中国 | 97电影网站| 国产一级黄色av | 亚洲视频在线播放 | 亚洲精品在线观看不卡 | 97视频在线观看网址 | 国产黄色精品网站 | 美女网站一区 | 最近的中文字幕大全免费版 | 国产69久久久 | 欧美日韩成人 | 高潮久久久久久久久 | 亚洲福利精品 | 久久精品超碰 | 中文字幕一区二区在线播放 | 成人黄色小说在线观看 | 国产性天天综合网 | 国产成人精品国内自产拍免费看 | 丁香在线 | 四虎8848免费高清在线观看 | 一本一道久久a久久精品蜜桃 | 中文国产在线观看 | 欧美激情精品一区 | 伊人宗合网 | 玖玖爱免费视频 | 中文国产成人精品久久一 | 99久久999久久久精玫瑰 | 亚洲一区av | 久久国内免费视频 | 国产精品18久久久 | 国产无遮挡猛进猛出免费软件 | 激情影音先锋 | 国产黄a三级三级三级三级三级 | 欧美成人tv | 国产一区成人在线 | 色综合亚洲精品激情狠狠 | 91九色在线 | 国产高清视频在线 | 91亚洲免费 | 久久久福利 | 亚洲精品国精品久久99热 | 91传媒免费在线观看 | 91福利小视频 | 亚洲午夜久久久影院 | 久青草视频在线观看 | 91成年视频 | 国产亚州精品视频 | 日韩欧美国产精品 | 亚洲精品tv久久久久久久久久 | 在线观看国产永久免费视频 | 成人免费视频网站在线观看 | 成年人毛片在线观看 | 国产高清一| 国产精品免费视频网站 | 亚洲女欲精品久久久久久久18 | 国产成人免费 | 在线观看视频免费播放 | 97成人精品 | 久9在线 | 97在线观看免费高清 | 亚洲精品白浆高清久久久久久 | 久久精品高清 | 国产五月色婷婷六月丁香视频 | 日韩中文字幕视频在线 | 国产精品久久久久久久久久不蜜月 | 在线观看中文字幕dvd播放 | 免费看黄在线看 | 深爱激情久久 | 日韩精品一区二区免费视频 | 色播99| 国内精品久久久久影院日本资源 | 国产999精品 | 国产资源中文字幕 | 日本精品久久久久中文字幕5 | 国产精品久久久久久久久久久免费看 | 国产一区二区免费在线观看 | 国产免费视频一区二区裸体 | 成人在线观看资源 | 黄色影院在线免费观看 | 97综合在线 | 99久免费精品视频在线观看 | 国产成人一区二 | 久久综合色一综合色88 | 成人一区在线观看 | 国产亚洲精品久 | 国产免费高清 | 亚洲在线视频播放 | 欧美日韩在线免费观看视频 | 在线色资源 | 久久优 | 狠狠狠色丁香婷婷综合久久五月 | 人人舔人人爽 | 精品国产一二三四区 | 蜜臀av性久久久久蜜臀aⅴ四虎 | 开心婷婷色 | 久久不卡日韩美女 | 最新高清无码专区 | 国产成人精品一区二区三区福利 | 九九免费观看全部免费视频 | 日日干夜夜干 | 伊人影院在线观看 | 91精品在线播放 | 欧美人zozo | 免费91麻豆精品国产自产在线观看 | 国产在线播放观看 | 欧美精品你懂的 | 亚洲涩涩一区 | 精品一区二区亚洲 | 五月天久久狠狠 | 三级av在线播放 | 一区二区视频在线看 | 狠狠干夜夜操天天爽 | 天天色天天上天天操 | 久久久久久免费视频 | 色吊丝在线永久观看最新版本 | 国产一二三四在线观看视频 | 成年人看片网站 | 日韩在线在线 | 99c视频在线 | 国产视频2| 精品国模一区二区 | 不卡电影一区二区三区 | 91精品久久久久久综合乱菊 | 久久国产精品99久久人人澡 | 一区二区不卡 | 欧美日韩在线视频免费 | 国产一级黄色电影 | 久久tv视频 | 在线观看中文 | 深爱激情婷婷网 | 中文字幕亚洲精品在线观看 | 国内精品99 | 九九视频免费观看视频精品 | 中文视频一区二区 | 亚洲欧洲一区二区在线观看 | 国产精品网站一区二区三区 | 亚洲区另类春色综合小说校园片 | 免费观看一级成人毛片 | 日韩久久片 | 久久伊人操 | 国偷自产视频一区二区久 | 天天操天天射天天爽 | 天天久久夜夜 | 最近高清中文字幕 | 中文字幕在线观看免费高清电影 | 日日操夜 | 国产不卡一 | 国产区精品在线 | 三级视频片| 久久免费在线 | 天操夜夜操 | 黄色片免费电影 | 九九视频在线播放 | 亚洲.www | 色视频在线 | 色偷偷88欧美精品久久久 | 久久九九免费视频 | 国产欧美日韩视频 | 日韩一区二区三区高清免费看看 | 日韩欧美在线综合网 | 亚洲欧美成人在线 | 久久成人一区二区 | 国产精品亚洲片在线播放 | 日韩中文字幕免费看 | 国产成人精品一区二区三区福利 | 97超碰成人 | 国产精品99久久久久久久久 | 日本精品一区二区三区在线播放视频 | 国产男女无遮挡猛进猛出在线观看 | 久久日本视频 | 日日夜夜网 | 日韩黄色影院 | 成人动漫一区二区三区 | 欧美一级网站 | 国产 日韩 在线 亚洲 字幕 中文 | 久久精品久久精品久久精品 | 久久久久久久久久免费视频 | 在线之家官网 | 天天插天天干天天操 | 日韩欧美xxx | 成人欧美一区二区三区在线观看 | 久久亚洲综合国产精品99麻豆的功能介绍 | 日日射天天射 | 国产伦理久久精品久久久久_ | av+在线播放在线播放 | 日韩视频在线播放 | 成人免费视频观看 | 久久免费国产电影 | 香蕉在线视频观看 | 久久99久久99精品免观看粉嫩 | 欧美伦理一区 | 91在线视频免费 | 一本一本久久a久久精品牛牛影视 | 一区二区欧美激情 | 久草在线久 | av网站在线观看免费 | 色香com. | 国产视频中文字幕 | 久久精品精品电影网 | 超碰在线98 | 最近中文字幕大全中文字幕免费 | av无限看 | 97视频免费观看 | 在线免费黄色 | 免费看的黄色小视频 | 精品电影一区二区 | 亚洲天堂在线观看完整版 | 国产在线一区二区 | 国内视频一区二区 | 96亚洲精品久久 | 伊人天天综合 | 99热超碰在线 | 欧美日韩伦理一区 | 亚洲成av片人久久久 | 免费看的黄网站软件 | 亚洲视频一级 | 久草在线视频网站 | 亚洲精品一区二区18漫画 | 在线观看中文字幕第一页 | 中文字幕乱偷在线 | 国产午夜三级一区二区三桃花影视 | 日韩啪啪小视频 | 亚洲国产黄色片 | 国产精品女主播一区二区三区 | 久久综合爱| 日本中文字幕视频 | 日韩天堂在线观看 | 天天干天天草天天爽 | 国产美女久久 | 久久艹久久 | 91视频高清 | 草在线视频 | 亚洲性少妇性猛交wwww乱大交 | 五月婷婷六月丁香 | 视频福利在线观看 | 又黄又爽又刺激的视频 | 久久久福利 | 久久精品亚洲一区二区三区观看模式 | 国产 日韩 在线 亚洲 字幕 中文 | 欧美性天天 | 一本一道波多野毛片中文在线 | 亚洲日本在线一区 | 国产精品欧美一区二区三区不卡 | av观看网站 | 久草视频看看 | 99热国产在线中文 | 免费日韩视频 | 91禁在线看 | 精品亚洲欧美一区 | 欧美男男tv网站 | 国产打女人屁股调教97 | av软件在线观看 | 亚州精品在线视频 | 最近最新mv字幕免费观看 | 福利电影一区二区 | 精品久久久久久一区二区里番 | av高清一区二区三区 | 久久精品视频免费 | 日本在线中文在线 | 亚洲天堂在线观看完整版 | 日韩精品久久久久久久电影竹菊 | 少妇bbw搡bbbb搡bbb | 99久久er热在这里只有精品66 | 日韩在线电影一区 | 97超碰网 | 五月花激情| 久久久久久久久久久免费视频 | 911在线| 国产一在线精品一区在线观看 | 久艹视频在线观看 | 在线观看aaa | 国产91学生粉嫩喷水 | 日韩激情久久 | 中文字幕av在线电影 | 精品一区二区三区香蕉蜜桃 | 中文字幕第一页在线视频 | av手机版| 中文字幕一区二区三区久久蜜桃 | 91入口在线观看 | 黄色毛片网站在线观看 | 午夜精品婷婷 | 日本大片免费观看在线 | 国产91aaa | 欧美日韩不卡一区 | 国产亚洲成人网 | 国产91影院| 国产精品久久久久av免费 | 中文字幕在线影视资源 | av免费在线播放 | 国产在线视频不卡 | 天天操天天色天天 | 在线亚洲小视频 | 伊人射 | 久久精品www人人爽人人 | 亚洲国产操 | 久久99亚洲精品久久久久 | 亚洲精品高清在线 | 久久精品一区二区三 | 中文字幕黄色网 | 综合色伊人 | 91秒拍国产福利一区 | 欧美一级在线观看视频 | 国产视 |