精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

SparkStreaming項目實戰,實時計算Pv和Uv

大數據 Spark
日志數據從flume采集過來,落到hdfs供其它離線業務使用,也會sink到kafka,sparkStreaming從kafka拉數據過來,計算pv,uv,uv是用的redis的set集合去重,最后把結果寫入mysql數據庫,供前端展示使用。

[[403404]]

本文轉載自微信公眾號「Java大數據與數據倉庫」,作者柯少爺。轉載本文請聯系Java大數據與數據倉庫公眾號。

最近有個需求,實時統計pv,uv,結果按照date,hour,pv,uv來展示,按天統計,第二天重新統計,當然了實際還需要按照類型字段分類統計pv,uv,比如按照date,hour,pv,uv,type來展示。這里介紹最基本的pv,uv的展示。

id uv pv date hour
1 155599 306053 2018-07-27 18

關于什么是pv,uv,可以參見這篇博客:https://blog.csdn.net/petermsh/article/details/78652246

1、項目流程

日志數據從flume采集過來,落到hdfs供其它離線業務使用,也會sink到kafka,sparkStreaming從kafka拉數據過來,計算pv,uv,uv是用的redis的set集合去重,最后把結果寫入mysql數據庫,供前端展示使用。

2、具體過程

1)pv的計算

拉取數據有兩種方式,基于received和direct方式,這里用direct直拉的方式,用的mapWithState算子保存狀態,這個算子與updateStateByKey一樣,并且性能更好。當然了實際中數據過來需要經過清洗,過濾,才能使用。

定義一個狀態函數

  1. // 實時流量狀態更新函數 
  2.   val mapFunction = (datehour:String, pv:Option[Long], state:State[Long]) => { 
  3.     val accuSum = pv.getOrElse(0L) + state.getOption().getOrElse(0L) 
  4.     val output = (datehour,accuSum) 
  5.     state.update(accuSum) 
  6.     output 
  7.   } 

這樣就很容易的把pv計算出來了。

2)uv的計算

uv是要全天去重的,每次進來一個batch的數據,如果用原生的reduceByKey或者groupByKey對配置要求太高,在配置較低情況下,我們申請了一個93G的redis用來去重,原理是每進來一條數據,將date作為key,guid加入set集合,20秒刷新一次,也就是將set集合的尺寸取出來,更新一下數據庫即可。

  1. helper_data.foreachRDD(rdd => { 
  2.         rdd.foreachPartition(eachPartition => { 
  3.         // 獲取redis連接 
  4.           val jedis = getJedis 
  5.           eachPartition.foreach(x => { 
  6.             // 省略若干... 
  7.             jedis.sadd(key,x._2) 
  8.             // 設置存儲每天的數據的set過期時間,防止超過redis容量,這樣每天的set集合,定期會被自動刪除 
  9.             jedis.expire(key,ConfigFactory.rediskeyexists) 
  10.           }) 
  11.           // 關閉連接 
  12.           closeJedis(jedis) 
  13.         }) 
  14.       }) 

3)結果保存到數據庫

結果保存到mysql,數據庫,10秒刷新一次數據庫,前端展示刷新一次,就會重新查詢一次數據庫,做到實時統計展示pv,uv的目的。

  1. /** 
  2.  * 插入數據 
  3.     * @param data (addTab(datehour)+helperversion) 
  4.     * @param tbName 
  5.     * @param colNames 
  6.     */ 
  7.   def insertHelper(data: DStream[(String, Long)], tbName: String, colNames: String*): Unit = { 
  8.     data.foreachRDD(rdd => { 
  9.       val tmp_rdd = rdd.map(x => x._1.substring(11, 13).toInt) 
  10.       if (!rdd.isEmpty()) { 
  11.         val hour_now = tmp_rdd.max() // 獲取當前結果中最大的時間,在數據恢復中可以起作用 
  12.         rdd.foreachPartition(eachPartition => { 
  13.           try { 
  14.             val jedis = getJedis 
  15.             val conn = MysqlPoolUtil.getConnection() 
  16.             conn.setAutoCommit(false
  17.             val stmt = conn.createStatement() 
  18.             eachPartition.foreach(x => { 
  19.               // val sql = .... 
  20.               // 省略若干 
  21.               stmt.addBatch(sql) 
  22.             }) 
  23.             closeJedis(jedis) 
  24.             stmt.executeBatch() // 批量執行sql語句 
  25.             conn.commit() 
  26.             conn.close() 
  27.           } catch { 
  28.             case e: Exception => { 
  29.               logger.error(e) 
  30.               logger2.error(HelperHandle.getClass.getSimpleName + e) 
  31.             } 
  32.           } 
  33.         }) 
  34.       } 
  35.     }) 
  36.   } 
  37.    
  38. // 計算當前時間距離次日零點的時長(毫秒) 
  39. def resetTime = { 
  40.     val now = new Date() 
  41.     val todayEnd = Calendar.getInstance 
  42.     todayEnd.set(Calendar.HOUR_OF_DAY, 23) // Calendar.HOUR 12小時制 
  43.     todayEnd.set(Calendar.MINUTE, 59) 
  44.     todayEnd.set(Calendar.SECOND, 59) 
  45.     todayEnd.set(Calendar.MILLISECOND, 999) 
  46.     todayEnd.getTimeInMillis - now.getTime 
  47.  } 

4)數據容錯

流處理消費kafka都會考慮到數據丟失問題,一般可以保存到任何存儲系統,包括mysql,hdfs,hbase,redis,zookeeper等到。這里用SparkStreaming自帶的checkpoint機制來實現應用重啟時數據恢復。

checkpoint

這里采用的是checkpoint機制,在重啟或者失敗后重啟可以直接讀取上次沒有完成的任務,從kafka對應offset讀取數據。

  1. // 初始化配置文件 
  2. ConfigFactory.initConfig() 
  3.  
  4. val conf = new SparkConf().setAppName(ConfigFactory.sparkstreamname) 
  5. conf.set("spark.streaming.stopGracefullyOnShutdown","true"
  6. conf.set("spark.streaming.kafka.maxRatePerPartition",consumeRate) 
  7. conf.set("spark.default.parallelism","24"
  8. val sc = new SparkContext(conf) 
  9.  
  10. while (true){ 
  11.  val ssc = StreamingContext.getOrCreate(ConfigFactory.checkpointdir + DateUtil.getDay(0),getStreamingContext _ ) 
  12.     ssc.start() 
  13.     ssc.awaitTerminationOrTimeout(resetTime) 
  14.     ssc.stop(false,true

checkpoint是每天一個目錄,在第二天凌晨定時銷毀StreamingContext對象,重新統計計算pv,uv。

注意:ssc.stop(false,true)表示優雅地銷毀StreamingContext對象,不能銷毀SparkContext對象,ssc.stop(true,true)會停掉SparkContext對象,程序就直接停了。

應用遷移或者程序升級

在這個過程中,我們把應用升級了一下,比如說某個功能寫的不夠完善,或者有邏輯錯誤,這時候都是需要修改代碼,重新打jar包的,這時候如果把程序停了,新的應用還是會讀取老的checkpoint,可能會有兩個問題:

執行的還是上一次的程序,因為checkpoint里面也有序列化的代碼;

直接執行失敗,反序列化失敗;

其實有時候,修改代碼后不用刪除checkpoint也是可以直接生效,經過很多測試,我發現如果對數據的過濾操作導致數據過濾邏輯改變,還有狀態操作保存修改,也會導致重啟失敗,只有刪除checkpoint才行,可是實際中一旦刪除checkpoint,就會導致上一次未完成的任務和消費kafka的offset丟失,直接導致數據丟失,這種情況下我一般這么做。

這種情況一般是在另外一個集群,或者把checkpoint目錄修改下,我們是代碼與配置文件分離,所以修改配置文件checkpoint的位置還是很方便的。然后兩個程序一起跑,除了checkpoint目錄不一樣,會重新建,都插入同一個數據庫,跑一段時間后,把舊的程序停掉就好。以前看官網這么說,只能記住不能清楚明了,只有自己做時才會想一下辦法去保證數據準確。

5)保存offset到mysql

如果保存offset到mysql,就可以將pv, uv和offset作為一條語句保存到mysql,從而可以保證exactly-once語義。

  1. var messages: InputDStream[ConsumerRecord[String, String]] = null 
  2.       if (tpMap.nonEmpty) { 
  3.         messages = KafkaUtils.createDirectStream[String, String]( 
  4.           ssc 
  5.           , LocationStrategies.PreferConsistent 
  6.           , ConsumerStrategies.Subscribe[String, String](topics, kafkaParams, tpMap.toMap) 
  7.         ) 
  8.       } else { 
  9.  
  10.         messages = KafkaUtils.createDirectStream[String, String]( 
  11.           ssc 
  12.           , LocationStrategies.PreferConsistent 
  13.           , ConsumerStrategies.Subscribe[String, String](topics, kafkaParams) 
  14.         ) 
  15.       } 
  16.  
  17.        
  18.       messages.foreachRDD(rdd => { 
  19.           .... 
  20. }) 

從mysql讀取offset并且解析:

  1. /** 
  2.     * 從mysql查詢offset 
  3.     * 
  4.     * @param tbName 
  5.     * @return 
  6.     */ 
  7.   def getLastOffsets(tbName: String): mutable.HashMap[TopicPartition, Long] = { 
  8.     val sql = s"select offset from ${tbName} where id = (select max(id) from ${tbName})" 
  9.     val conn = MysqlPool.getConnection(config) 
  10.     val psts = conn.prepareStatement(sql) 
  11.     val res = psts.executeQuery() 
  12.     var tpMap: mutable.HashMap[TopicPartition, Long] = mutable.HashMap[TopicPartition, Long]() 
  13.     while (res.next()) { 
  14.       val o = res.getString(1) 
  15.       val jSONArray = JSON.parseArray(o) 
  16.       jSONArray.toArray().foreach(offset => { 
  17.         val json = JSON.parseObject(offset.toString) 
  18.         val topicAndPartition = new TopicPartition(json.getString("topic"), json.getInteger("partition")) 
  19.         tpMap.put(topicAndPartition, json.getLong("untilOffset")) 
  20.       }) 
  21.     } 
  22.     MysqlPool.closeCon(res, psts, conn) 
  23.     tpMap 

6)日志

日志用的log4j2,本地保存一份,ERROR級別的日志會通過郵件發送到手機,如果錯誤太多也會被郵件轟炸,需要注意。

  1. val logger = LogManager.getLogger(HelperHandle.getClass.getSimpleName) 
  2.   // 郵件level=error日志 
  3.   val logger2 = LogManager.getLogger("email"

 

責任編輯:武曉燕 來源: Java大數據與數據倉庫
相關推薦

2021-06-06 13:10:12

FlinkPvUv

2021-11-01 13:11:45

FlinkPvUv

2015-07-31 10:35:18

實時計算

2021-03-10 08:22:47

FlinktopN計算

2022-12-29 09:13:02

實時計算平臺

2015-08-31 14:27:52

2025-03-05 08:40:00

RedisJava開發

2017-09-26 09:35:22

2015-10-09 13:42:26

hbase實時計算

2019-11-21 09:49:29

架構運維技術

2013-08-04 21:02:59

實時計算存儲阿里巴巴和仲

2019-10-17 09:25:56

Spark StreaPVUV

2016-10-16 13:48:54

多維分析 UVPV

2019-02-18 15:23:21

馬蜂窩MESLambda

2021-07-05 10:48:42

大數據實時計算

2021-07-16 10:55:45

數倉一體Flink SQL

2016-11-02 09:02:56

交通大數據計算

2021-03-10 14:04:10

大數據計算技術

2011-10-28 09:05:09

2017-01-15 13:45:20

Docker大數據京東
點贊
收藏

51CTO技術棧公眾號

国产69精品久久久久9| 欧美日韩中国免费专区在线看| 国产精品成人va在线观看| 人妻精品久久久久中文| 成人开心激情| 中文字幕一区二区三区四区不卡| 亚洲一区中文字幕| 色播视频在线播放| 禁断一区二区三区在线| 91精品国产一区二区| 日本一区午夜艳熟免费| 青青青草网站免费视频在线观看| 蜜臀av亚洲一区中文字幕| 欧美高清videos高潮hd| 波多野结衣a v在线| 欧美在线一级| 精品福利在线观看| 中文字幕一区二区三区四区五区六区 | 亚洲图色一区二区三区| 欧美性极品xxxx做受| 超碰在线免费观看97| 欧美zzoo| 成人免费视频播放| 91久久精品美女| 二区视频在线观看| 欧美三级乱码| 日韩在线视频国产| 三上悠亚ssⅰn939无码播放 | 黄色a一级视频| 日本成人精品| 欧美人狂配大交3d怪物一区| 精品国产免费av| 丁香高清在线观看完整电影视频| 欧美韩日一区二区三区四区| 国模一区二区三区私拍视频| 国产后入清纯学生妹| 免费观看一级特黄欧美大片| 97av在线影院| 久久免费视频99| 亚洲国产精品成人| 少妇高潮久久77777| 久久久久久久久久久国产精品| 亚洲一区 二区| 337p亚洲精品色噜噜噜| 九热视频在线观看| 色8久久影院午夜场| 香蕉久久一区二区不卡无毒影院 | 91传媒理伦片在线观看| 韩国一区二区三区视频| 欧美日韩一级二级三级| 波多结衣在线观看| 四虎成人在线| 欧美在线|欧美| 日本熟妇人妻中出| 中文字幕av一区二区三区佐山爱| 五月婷婷激情综合| 国产精品入口芒果| а√天堂中文在线资源8| 亚洲综合另类小说| 精品少妇人欧美激情在线观看| 91最新在线视频| 亚洲男人的天堂一区二区| 亚洲免费av网| 91精选在线| 一区二区高清在线| 成人性免费视频| 午夜影视一区二区三区| 欧美网站在线观看| 欧美激情精品久久久久久小说| 午夜日韩成人影院| 欧美三级在线视频| 成人高清在线观看视频| 51亚洲精品| 亚洲国产高清高潮精品美女| 免费观看一级一片| 欧洲美女日日| 久久久成人精品视频| 懂色av懂色av粉嫩av| 精品1区2区3区4区| 青青草原成人在线视频| 国产一区免费看| 精品一区二区国语对白| 99国内精品久久久久久久软件| 国产99999| bt7086福利一区国产| 久久国产欧美精品| yourporn在线观看视频| 亚洲美女免费视频| 日韩精品―中文字幕| a一区二区三区| 欧美日韩大陆在线| 荫蒂被男人添免费视频| 国产精选一区| 久久这里只有精品视频首页| 久久精品国产亚洲av无码娇色| 老司机一区二区三区| 成人美女av在线直播| 国产91麻豆视频| 国产欧美1区2区3区| 国产女人18毛片| 色在线中文字幕| 欧美精品亚洲二区| 女人被狂躁c到高潮| 日韩欧美视频在线播放| 欧美大片大片在线播放| 国产污视频网站| 国内成人自拍视频| 欧美激情一区二区三区在线视频| 欧美日韩在线资源| 婷婷国产在线综合| 肉色超薄丝袜脚交| 亚洲最好看的视频| 欧美精品免费在线| 中文字幕日日夜夜| jvid福利写真一区二区三区| 亚洲午夜精品久久久中文影院av | 亚洲免费在线电影| 污污视频网站免费观看| 国产精品tv| 久久久精品亚洲| 日韩精品一区二区亚洲av观看| 粉嫩13p一区二区三区| 亚洲美女网站18| 欧美日韩在线观看首页| 日韩一卡二卡三卡| 女人18毛片毛片毛片毛片区二| 一本久道久久久| 亚洲xxx自由成熟| 992tv免费直播在线观看| 亚洲国产精品一区二区久久恐怖片| 午夜免费一区二区| 亚洲三级网页| 97婷婷大伊香蕉精品视频| 国产婷婷一区二区三区久久| 国产日韩欧美电影| 成人观看免费完整观看| 国产欧美啪啪| 国模私拍一区二区三区| aaa一区二区| 综合婷婷亚洲小说| 午夜剧场在线免费观看| 欧美伦理在线视频| 国产精品欧美一区二区| 国内在线精品| 一本久久精品一区二区| 亚洲国产果冻传媒av在线观看| 亚洲天堂男人| 国产精品一区二区欧美| 国产探花视频在线观看| 日韩欧美高清在线| 免费人成在线观看| 国产精品综合久久| av日韩在线看| jizz性欧美23| 久久久久久久一| 亚洲女人18毛片水真多| 亚洲一区二区三区四区在线| 91成人在线观看喷潮蘑菇| 极品裸体白嫩激情啪啪国产精品| 成人国产1314www色视频| 国产天堂在线播放视频| 亚洲黄色av女优在线观看| 中文字幕精品三级久久久| 91在线播放网址| 欧美一级黄色片视频| 精品国产乱码久久久久久蜜坠欲下 | 99青草视频在线播放视| 欧美视频中文一区二区三区在线观看| 中文字幕av久久爽一区| 美国一区二区三区在线播放| 亚洲一区高清| 亚洲国产aⅴ精品一区二区| 欧美日韩成人网| 头脑特工队2免费完整版在线观看 头脑特工队2在线播放 | 欧美日本精品一区二区三区| 北条麻妃在线观看视频| 国产精品亚洲一区二区三区妖精 | 欧美aa国产视频| 国产乱码精品一区二区三区卡| 国产精品yjizz视频网| 亚洲天堂男人天堂| 99re只有精品| 精品久久久在线观看| 久久精品视频18| 韩国三级中文字幕hd久久精品| 国产在线无码精品| 亚洲都市激情| 91精品久久久久久久久久久久久久 | 经典三级在线一区| 女人帮男人橹视频播放| 日韩精选在线| 国产又爽又黄的激情精品视频| 色呦呦网站在线观看| 国产视频精品免费播放| 136福利视频导航| 亚洲综合色视频| 日韩视频在线观看免费视频| 国产精品一卡二卡| 欧美污视频网站| 亚洲欧洲日韩| 麻豆成人av| 日本一区二区三区电影免费观看| 91av国产在线| 在线观看中文字幕的网站| 国产视频亚洲精品| 亚洲国产综合网| 色成人在线视频| 久久无码精品丰满人妻| 欧美韩日一区二区三区四区| 日本69式三人交| 久久91精品国产91久久小草| 国产视频九色蝌蚪| 欧美视频不卡| 天天成人综合网| 精品视频免费在线观看| 国产伦精品一区二区三区免费视频| 日本中文字幕一区二区| 91黑丝高跟在线| 国产成人高清精品| 色悠悠久久88| 激情小说 在线视频| 亚洲成人精品久久| 国产偷拍一区二区| 在线不卡的av| 久久影视中文字幕| 欧美性猛交xxxx黑人猛交| 91在线播放观看| 国产精品成人一区二区三区夜夜夜| avtt香蕉久久| 北岛玲一区二区三区四区| 视频免费1区二区三区| 三级在线观看一区二区| 免费 成 人 黄 色| 国产精品a久久久久| 国产麻豆电影在线观看| 成久久久网站| 日本精品免费| 亚洲色图丝袜| 美日韩精品免费| 日韩在线黄色| 久久久久成人精品免费播放动漫| 91麻豆精品激情在线观看最新 | 欧美高清中文字幕| 久久久久久久久丰满| 在线不卡视频一区二区| 欧美一二区在线观看| 欧洲精品亚洲精品| 免费看成人吃奶视频在线| 久久精品美女| 久久综合欧美| 日韩欧美亚洲日产国产| 波多野结衣一区| 亚洲欧美日韩国产成人综合一二三区| 国产欧美久久一区二区三区| 欧美一区二区在线| 精品视频免费在线观看| 亚洲高清不卡一区| 91欧美大片| 麻豆传媒网站在线观看| 欧美国产91| 日本在线xxx| 久久久久久自在自线| 97在线播放视频| 日韩成人av影视| 中国黄色片免费看| 国产一区二区精品在线观看| 91欧美一区二区三区| 国产999精品久久久久久| 91人妻一区二区| 91蜜桃免费观看视频| 亚洲v国产v欧美v久久久久久| 国产日韩欧美一区二区三区乱码 | 免费看av成人| 亚洲一区二区三区精品动漫| 91久久久精品国产| 屁屁影院ccyy国产第一页| 亚洲人人精品| youjizzxxxx18| 国产精品伊人色| 久久久久亚洲AV成人无码国产| 91浏览器在线视频| 日本成人免费在线观看| 亚洲欧美视频一区| 久久艹免费视频| 欧美人妖巨大在线| 五月婷婷开心中文字幕| 中文精品99久久国产香蕉| 18av在线播放| 日韩av电影在线播放| 日韩一区二区三区四区五区| 国产精品免费一区二区三区| 亚洲香蕉视频| 亚洲高潮无码久久| 美女尤物久久精品| 老女人性生活视频| 久久亚洲一区二区三区四区| www.com.av| 精品动漫一区二区| 97视频免费在线| 亚洲欧美国产精品| 在线观看三级视频| 国产97色在线| a级日韩大片| 亚洲一区二区三区加勒比| 亚洲精品极品| 在线免费黄色网| 久久久久综合网| 久草视频中文在线| 欧美人伦禁忌dvd放荡欲情| 五月天婷婷激情网| 久操成人在线视频| 国产精品一区二区免费福利视频| 99九九电视剧免费观看| 成人在线国产| 青青艹视频在线| 国产高清不卡一区| 99久久99久久精品免费| 欧美午夜激情视频| 国模私拍视频在线| 超碰精品一区二区三区乱码| 成入视频在线观看| 成人精品一二区| 欧美大片aaaa| 一区二区三区视频在线观看免费| www.爱久久.com| 久草国产在线视频| 7777精品伊人久久久大香线蕉完整版| 嫩草研究院在线观看| 欧美激情图片区| 精品精品视频| gogogo免费高清日本写真| 日韩在线一区二区| 精品成人av一区二区三区| 亚洲地区一二三色| 亚洲第一第二区| 免费成人高清视频| 婷婷成人av| 亚洲欧美日韩精品综合在线观看| 久久蜜桃资源一区二区老牛| 内射中出日韩无国产剧情| 亚洲成人av一区二区三区| 亚洲成人一级片| 九九热在线精品视频| 国产在线视频欧美一区| 国产精品jizz在线观看老狼| 麻豆免费精品视频| 国产中文字幕久久| 欧美无砖专区一中文字| 国产高清在线| 国产精品视频自在线| 菠萝蜜一区二区| gai在线观看免费高清| 国产精品视频在线看| 亚洲天堂视频在线| 久久精品国产电影| av日韩久久| 黄网站色视频免费观看| 国产大陆精品国产| 国产精品成人网站| 日韩精品视频免费专区在线播放| 三级在线观看视频| 欧美一区国产一区| 日本午夜精品一区二区三区电影 | 国产精品一区二区黑人巨大| 久久亚洲精品视频| youjizz亚洲| 鲁一鲁一鲁一鲁一澡| 久久一日本道色综合| 在线免费看av的网站| 北条麻妃一区二区三区中文字幕| 综合久久av| 野外做受又硬又粗又大视频√| 91在线视频观看| 中文字幕在线一| 欧美www在线| 国产精品x8x8一区二区| 六月丁香婷婷激情| 国产精品久99| 日韩中文字幕影院| 国产999精品久久久| 小处雏高清一区二区三区| 年下总裁被打光屁股sp| 日韩欧美成人区| 理论片午午伦夜理片在线播放| 风间由美久久久| 天堂成人免费av电影一区| 日韩一卡二卡在线观看| 亚洲第一天堂av| 精品国模一区二区三区| 国产精品igao激情视频| 久久伊人蜜桃av一区二区| 91精东传媒理伦片在线观看| 久久久久一本一区二区青青蜜月| 国产一区二区观看| 制服下的诱惑暮生| 91久久久免费一区二区| 亚洲资源一区| 视频一区不卡| 成人午夜在线视频| 中文在线观看免费高清|