范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文
国学影视

Hadoop学习(12)陌陌聊天数据分析

  1 陌陌聊天数据分析案例需求 1.1 目标
  基于Hadoop和Hive实现聊天数据统计分析,构建聊天数据分析报表。
  1.2 需求统计今日总消息量统计今日每小时消息量、发送和接收用户数统计今日各地区发送消息数据量统计今日发送消息和接收消息的用户数统计今日发送消息最多的Top10用户统计今日接收消息最多的Top10用户统计发送人的手机型号分布情况统计发送人的设备操作系统分布情况1.3 数据内容数据大小:两个文件共14万条数据列分隔符:制表符 	数据字典及样例数据
  2 基于Hive数仓使用SQL实现需求开发 2.1 建库建表、加载数据2.1.1 建库建表--如果数据库已存在就删除 drop database if exists db_msg cascade ; --创建数据库 create database db_msg ; --切换数据库 use db_msg ; --列举数据库 show databases ; --如果表已存在就删除 drop table if exists db_msg.tb_msg_source ; --建表 create table db_msg.tb_msg_source( msg_time string comment "消息发送时间" , sender_name string comment "发送人昵称" , sender_account string comment "发送人账号" , sender_sex string comment "发送人性别" , sender_ip string comment "发送人ip地址" , sender_os string comment "发送人操作系统" , sender_phonetype string comment "发送人手机型号" , sender_network string comment "发送人网络类型" , sender_gps string comment "发送人的GPS定位" , receiver_name string comment "接收人昵称" , receiver_ip string comment "接收人IP" , receiver_account string comment "接收人账号" , receiver_os string comment "接收人操作系统" , receiver_phonetype string comment "接收人手机型号" , receiver_network string comment "接收人网络类型" , receiver_gps string comment "接收人的GPS定位" , receiver_sex string comment "接收人性别" , msg_type string comment "消息类型" , distance string comment "双方距离" , message string comment "消息内容" ) --指定分隔符为制表符 row format delimited fields terminated by "	" ;2.1.2 加载数据HDFS上创建目录 hdfs dfs -mkdir -p /momo/data 上传到HDFS hdfs dfs -put /export/data/data1.tsv /momo/data/ hdfs dfs -put /export/data/data2.tsv /momo/data/ 加载到Hive表中 load data inpath "/momo/data/data1.tsv" into table db_msg.tb_msg_source; load data inpath "/momo/data/data2.tsv" into table db_msg.tb_msg_source; 验证结果 select  msg_time,sender_name,sender_ip,sender_phonetype,receiver_name,receiver_network  from tb_msg_source limit 10;2.2 ETL数据清洗2.2.1 原始数据内容
  数据来源:聊天业务系统中导出的2021年11月01日一天24小时的用户聊天数据,以TSV文本形式存储在文件中。
  2.2.2 数据问题问题1:当前数据中,有一些数据的字段为空,不是合法数据。问题2:需求中,需要统计每天、每个小时的消息量,但是数据中没有天和小时字段,只有整体时间字段,不好处理。问题3:需求中,需要对经度和维度构建地区的可视化地图,但是数据中GPS经纬度为一个字段,不好处理。2.2.3 ETL需求需求1:对字段为空的不合法数据进行过滤
  Where过滤需求2:通过时间字段构建天和小时字段
  Substr函数需求3:从GPS的经纬度中提取经度和维度
  Split函数需求4:将ETL以后的结果保存到一张新的Hive表中
  Create table …… as select ……2.2.4 ETL实现--如果表已存在就删除 drop table if exists db_msg.tb_msg_etl; --将Select语句的结果保存到新表中 create table db_msg.tb_msg_etl as select *, substr(msg_time,0,10) as dayinfo, substr(msg_time,12,2) as hourinfo, --获取天和小时 split(sender_gps,",")[0] as sender_lng, split(sender_gps,",")[1] as sender_lat --提取经度纬度 from db_msg.tb_msg_source --过滤字段为空的数据 where length(sender_gps) > 0 ;
  查看结果select msg_time,dayinfo,hourinfo,sender_gps,sender_lng,sender_lat from db_msg.tb_msg_etl limit 10;2.3 需求指标统计2.3.1 指标1:统计今日消息总量--保存结果表 create table if not exists tb_rs_total_msg_cnt  comment "今日消息总量" as select  dayinfo, count(*) as total_msg_cnt from db_msg.tb_msg_etl group by dayinfo;2.3.2 指标2:统计每小时消息量、发送和接收用户数--保存结果表 create table if not exists tb_rs_hour_msg_cnt  comment "每小时消息量趋势" as select  dayinfo, hourinfo, count(*) as total_msg_cnt, count(distinct sender_account) as sender_usr_cnt, count(distinct receiver_account) as receiver_usr_cnt from db_msg.tb_msg_etl group by dayinfo,hourinfo;2.3.3 指标3:统计今日各地区发送消息总量--保存结果表 create table if not exists tb_rs_loc_cnt comment "今日各地区发送消息总量" as select  dayinfo, sender_gps, cast(sender_lng as double) as longitude, cast(sender_lat as double) as latitude, count(*) as total_msg_cnt from db_msg.tb_msg_etl group by dayinfo,sender_gps,sender_lng,sender_lat;2.3.4 指标4:统计今日发送和接收用户人数--保存结果表 create table if not exists tb_rs_usr_cnt comment "今日发送消息人数、接受消息人数" as select  dayinfo, count(distinct sender_account) as sender_usr_cnt, count(distinct receiver_account) as receiver_usr_cnt from db_msg.tb_msg_etl group by dayinfo;2.3.5 指标5:统计发送消息条数最多的Top10用户--保存结果表 create table if not exists tb_rs_susr_top10 comment "发送消息条数最多的Top10用户" as select  dayinfo, sender_name as username, count(*) as sender_msg_cnt from db_msg.tb_msg_etl group by dayinfo,sender_name order by sender_msg_cnt desc limit 10;2.3.6 指标6:统计接收消息条数最多的Top10用户--保存结果表 create table if not exists tb_rs_rusr_top10 comment "接受消息条数最多的Top10用户" as select  dayinfo, receiver_name as username, count(*) as receiver_msg_cnt from db_msg.tb_msg_etl group by dayinfo,receiver_name order by receiver_msg_cnt desc limit 10;2.3.7 指标7:统计发送人的手机型号分布情况--保存结果表 create table if not exists tb_rs_sender_phone comment "发送人的手机型号分布" as select  dayinfo, sender_phonetype, count(distinct sender_account) as cnt from tb_msg_etl group by dayinfo,sender_phonetype;2.3.8 指标8:统计发送人的操作系统分布--保存结果表 create table if not exists tb_rs_sender_os comment "发送人的OS分布" as select  dayinfo, sender_os, count(distinct sender_account) as cnt from tb_msg_etl group by dayinfo,sender_os;
  3 基于FineBI实现可视化报表 3.1 FineBI的介绍及安装FineBI 是帆软软件有限公司推出的一款商业智能(Business Intelligence)产品。FineBI 是定位于自助大数据分析的 BI 工具,能够帮助企业的业务人员和数据分析师,开展以问题导向的探索式分析。FineBI的特点通过多人协作来实现最终的可视化构建不需要通过复杂代码来实现开发,通过可视化操作实现开发适合于各种数据可视化的应用场景支持各种常见的分析图表和各种数据源支持处理大数据3.2 FineBI配置数据源及数据准备FineBI与Hive集成的官方文档3.2.1 驱动配置问题:如果使用FineBI连接Hive,读取Hive的数据表,需要在FineBI中添加Hive的驱动jar包。解决:将Hive的驱动jar包放入FineBI的lib目录下。找到提供的【Hive连接驱动】
  放置
  将这些文件放入FineBI的安装目录下的:webappswebrootWEB-INFlib目录中。3.2.2 插件安装问题:我们自己放的Hive驱动包会与FineBI自带的驱动包产生冲突,导致FineBI无法识别我们自己的驱动包。解决:安装FineBI官方提供的驱动包隔离插件。找到隔离插件
  安装插件
  重启FineBI3.2.3 构建连接新建连接
  配置连接
  3.2.4 数据准备新建分组
  添加业务包
  添加表
  更新业务包

我公司,承诺每年涨薪百分之十。我现在月薪4500,要继续吗?如果光就涨薪幅度而言,每年涨薪10还是不错的,但你这个每年涨薪10的基数到底是多少,这个没有说明啊,所以有点悬。我跟你说句实话吧,每年工资涨幅10不是关键,关键是这个10是以什么基用过华为手机的你,还会继续支持吗?关注今日头条找靓机,每天分享各种数码资讯,互动还送奖品哦!作为华为P20Pro的第一批用户,不得不称赞一下这段时间华为的进步。由最早的农业重金属配色到现在的极光色,机器ID设计方面农村的学生大量进入县城读书,农村新建的学校都空起来了,什么原因?怎么解决?农村的学生大量进入县城读书,新建的学校都空起来了,归根到底还是城乡之间发展差距和教育资源分配的不均衡造成的。外出务工的父母尝够了没文化之苦,所以拼命在外挣钱,送孩子到县城读书,希望我外甥女农村户口考上研究生学校让迁户口到学校,迁还是不迁?谢谢各位朋友好友的真诚建议,我会用心考虑的,由于国家的宅基地和土地政策,我是为孩子们高兴了好一阵子的,农村户口反过来竟然是好事,因此大外甥和外甥女都没有迁到学校,现在外甥女考研了,花生壳种花有营养吗?我是好摄农夫,头条号乡村搜罗社。一个喜欢野生兰花的农夫,用自己的实践与实例说事,如果喜欢就点个赞留下你的评论。花生壳种花有营养吗?花生壳是很多兰友喜欢用的植料,花生壳在用作植料时有常吃生黑芝麻有什么好处?谢谢!早餐最喜欢吃麻球,用糯米做的,上面裹着黑芝麻,油炸后酥酥脆脆的非常好吃!黑芝麻的营养含有人体需要的氨基酸和维生素和矿物质,卵磷脂,脂肪和蛋白质。其中钙镁硒等矿物质含量特别丰富在未来有发展潜力的科技股有哪些?我给大家分析中外股市的科技股行情,实际上就是概念与实质的差别,同时,我们也要看到中资科技股也是经历了这样涅槃重生,才有了改变。比如说网易,其从2001年7月26日创下的最低价0。5月工资1500在绵阳怎么生活?像今天这样的生活水平1500只够吃住行了,就不想要想买其他东西了。如果你在自己家吃住还好,1500还是够花的,比如充个话费100买衣服买鞋子就不要买牌子的,又时候在外面偶尔吃顿饭。铁路公安的工作累吗?任何工作都没有定性的累或者不累,铁路公安也是如此。首先,铁路公安据我所知分为两种1跟火车的铁路公安。2火车站派出所的铁路公安。两种铁路公安有什么区别?跟火车的,也就是需要长期在火车白细胞低的原因是什么?有什么危害?一什么是白细胞?医学上,所谓白细胞(WBC),是血液中,一类常规细胞。一般包括中性粒细胞嗜酸性粒细胞嗜碱性粒细胞单核细胞淋巴细胞等。白细胞具有吞噬细菌防御疾病等作用。简单地说,就像怎样让很努力学习,成绩却一直提不上来的学生不丧失信心呢?找到成绩上不来的原因,继续鼓励学生!实际学习中,很多学生确实很努力,但成绩一直提不上来。家长要帮学生找到成绩上不来的原因,找到改进方法,继续鼓励学生坚定信心。1。学生成绩上不来的原
4款高端性能的千元机,没有一款是多余的,总有合适你的随着智能手机市场竞争愈发激烈,很多品牌为了吸引消费者,推出了性价比很高的手机,有些千元机具有高端性能,但是价格却十分便宜,这次我们聊聊4款高端性能的千元机,没有一款是多余的,总有合为什么懂行的都在买45W标压笔记本电脑?科普CPU功耗是怎么确定的前言喜欢关注笔记本电脑的网友,肯定知道像联想华为小米荣耀等厂商都在大力地推广标压笔记本电脑。甚至有些极端网友说低压笔记本就是智商税,要买就要买标压笔记本。那到底什么是标压笔记本呢?评测新款天梭PRXPowermatic80实用且全面几个月前,我们介绍了一款相当帅气且制作精良的天梭表PRX。那时我们唯一的轻微疑虑是这款手表配备了石英机芯。现在,我们的祈祷似乎得到了钟表之神的回应。自2021年初推出以来,PRX已谷歌也在研究折叠屏,折叠屏手机曝光我们平时所见到的折叠屏手机可能是不多,但是现在毋庸置疑的是大部分的手机品牌都开始卷进了折叠屏手机的赛道中,而一直在手机制造中耕耘的谷歌也被爆出了关于折叠平手机的消息。不久前谷歌官方定制传感器蜂鸟超级防抖,vivoS15Pro拍照更稳了说到vivo,相信你肯定会想到vivo旗下的S系列手机。自从2019年vivo推出S系列产品线以来,3年时间里vivoS系列已经拥有了近3000万的用户。而用户们之所以被vivoS30万2。0T以下车型购置税减半平均每天减税超2。5亿元据央视新闻报道,国家税务总局数据显示,今年68月,全国约355。3万辆车享受了车辆购置税减征政策,累计减征车购税230。4亿元,平均每天减免购置税2。5亿元。其中,6月109。7万拜仁还是果断换帅吧2223赛季欧冠联赛小组赛第二轮,拜仁慕尼黑主场迎战巴塞罗那。上半场两队0比0互交白卷!比赛还未结束,就可以看出拜仁在纳格尔斯曼的调教下发生了明显的退步,前场进攻效率后场倒脚效果,01!中超最新排名出炉八冠王丢分,黑马第一,3队保级形势吃紧强如齐达内穆帅,也有烦恼愁丝,带队总是未知,郑智亦如此,13日晚,郑智带领广州队与李玮锋接手的广州城相遇,两队排名皆为倒数,赢球就有望脱离降级区,本场比赛输赢极为关键,双方都注重攻欧冠0力克巴萨两战全胜北京时间9月14日凌晨3点,202223赛季欧冠小组赛C组第二轮的一场焦点战在慕尼黑安联球场打响,德甲霸主拜仁慕尼黑坐镇主场对阵西甲豪门巴塞罗那。上半场,帕瓦尔受伤被换下下半场,卢孕检惊魂我今年34怀的二胎,相比一胎就查了个四维,这胎比之前检查项目多的多,更重视,结果越重视越心惊肉跳。先是我九号染色体倒位,医生说一半几率生正常孩子,一半几率流产。我大孩子都九岁了,去观潮戏水,别样小清新!厦门前日迎来天文大潮来源台海网台海网9月14日讯(海峡导报记者朱黄郑丽金文叶鑫洋图)大晴天,穿着雨鞋玩水坐在一片汪洋中,喝着咖啡,看潮起潮落早早地穿好拖鞋,蹚着潮水,让海水在趾缝间流过前天,厦门海域迎