当前位置:   article > 正文

hadoop学习---基于hive的聊天数据分析报表可视化案例

hadoop学习---基于hive的聊天数据分析报表可视化案例

背景介绍:

聊天平台每天都会有大量的用户在线,会出现大量的聊天数据,通过对聊天数据的统计分析,可以更好的对用户构建精准的用户画像,为用户提供更好的服务以及实现高ROI的平台运营推广,给公司的发展决策提供精确的数据支撑。 我们将基于一个社交平台App的用户数据,完成相关指标的统计分析并结合BI工具对指标进行可视化展现。

目标:

基于Hadoop和Hive实现聊天数据统计分析,构建聊天数据分析报表

需求分析:

统计今日总消息量 统计今日每小时消息量、发送和接收用户数

统计今日各地区发送消息数据量

统计今日发送消息和接收消息的用户数

统计今日发送消息最多的Top10用户

统计今日接收消息最多的Top10用户

统计发送人的手机型号分布情况

统计发送人的设备操作系统分布情况

数据源:数据源

数据大小:30万条数据

列分隔符:Hive默认分隔符’\001’   

数据字典及样例数据

 构建数据库数据表hive:

  1. create database db_msg;
  2. use db_msg;
  3. --建表
  4. create table db_msg.tb_msg_source(
  5. msg_time string comment "消息发送时间",
  6. sender_name string comment "发送人昵称",
  7. sender_account string comment "发送人账号",
  8. sender_sex string comment "发送人性别",
  9. sender_ip string comment "发送人ip地址",
  10. sender_os string comment "发送人操作系统",
  11. sender_phonetype string comment "发送人手机型号",
  12. sender_network string comment "发送人网络类型",
  13. sender_gps string comment "发送人的GPS定位",
  14. receiver_name string comment "接收人昵称",
  15. receiver_ip string comment "接收人IP",
  16. receiver_account string comment "接收人账号",
  17. receiver_os string comment "接收人操作系统",
  18. receiver_phonetype string comment "接收人手机型号",
  19. receiver_network string comment "接收人网络类型",
  20. receiver_gps string comment "接收人的GPS定位",
  21. receiver_sex string comment "接收人性别",
  22. msg_type string comment "消息类型",
  23. distance string comment "双方距离",
  24. message string comment "消息内容"
  25. );

将数据源上传到Linux文件系统中,再上传到hadoop中:

  1. [hadoop@node1 ~]$ hadoop fs -mkdir -p /chatdemo/data
  2. [hadoop@node1 ~]$ hadoop fs -put chat_data-30W.csv /chatdemo/data

 将数据源从hadoop中下载到hive数据库中:

load data inpath '/chatdemo/data/chat_data-30W.csv' into table db_msg.tb_msg_source;

 

数据清洗:

问题1:当前数据中,有一些数据的字段为空,不是合法数据

问题2:需求中,需要统计每天、每个小时的消息量,但是数据中没有天和小时字段,只有整体时间字段,不好处理

问题3:需求中,需要对经度和维度构建地区的可视化地图,但是数据中GPS经纬度为一个字段,不好处理

数据清洗:

  1. select
  2. *,
  3. date(msg_time) as msg_day,
  4. hour(msg_time) as msg_hour,
  5. split(sender_gps,',')[0] as sender_lng,
  6. split(sender_gps,',')[1] as sender_lat
  7. from tb_msg_source
  8. where length(sender_gps)>0;

将清洗后的数据在放入新表中,添加新的字段:

  1. create table db_msg.tb_msg_etl(
  2. msg_time string comment "消息发送时间",
  3. sender_name string comment "发送人昵称",
  4. sender_account string comment "发送人账号",
  5. sender_sex string comment "发送人性别",
  6. sender_ip string comment "发送人ip地址",
  7. sender_os string comment "发送人操作系统",
  8. sender_phonetype string comment "发送人手机型号",
  9. sender_network string comment "发送人网络类型",
  10. sender_gps string comment "发送人的GPS定位",
  11. receiver_name string comment "接收人昵称",
  12. receiver_ip string comment "接收人IP",
  13. receiver_account string comment "接收人账号",
  14. receiver_os string comment "接收人操作系统",
  15. receiver_phonetype string comment "接收人手机型号",
  16. receiver_network string comment "接收人网络类型",
  17. receiver_gps string comment "接收人的GPS定位",
  18. receiver_sex string comment "接收人性别",
  19. msg_type string comment "消息类型",
  20. distance string comment "双方距离",
  21. message string comment "消息内容",
  22. msg_day string comment "消息日",
  23. msg_hour string comment "消息小时",
  24. sender_lng double comment "经度",
  25. sender_lat double comment "纬度"
  26. );

 将数据插入到新表:

  1. insert overwrite table db_msg.tb_msg_etl
  2. select
  3. *,
  4. date(msg_time) as msg_day,
  5. hour(msg_time) as msg_hour,
  6. split(sender_gps,',')[0] as sender_lng,
  7. split(sender_gps,',')[1] as sender_lat
  8. from tb_msg_source
  9. where length(sender_gps)>0;

将需求指标查询出来构建新表:

  1. -- 统计今日总消息量
  2. create table db_msg.tb_rs_total_msg_cnt comment '每日消息总量' as
  3. select msg_day, count(*) as total_msg_cnt from db_msg.tb_msg_etl group by msg_day ;
  4. -- 统计今日每小时消息量、发送和接收用户数
  5. create table db_msg.tb_rs_hour_msg_cnt comment '每小时消息量趋势' as
  6. select
  7. msg_hour,
  8. count(*) as total_msg_cnt,
  9. count(distinct sender_account) as sender_user_cnt,
  10. count(distinct receiver_account) as receiver_user_cnt
  11. from db_msg.tb_msg_etl
  12. group by msg_hour;
  13. -- 统计今日各地区发送消息数据量
  14. create table db_msg.tb_rs_loc_cnt comment '每日各地区发送消息总量' as
  15. select
  16. msg_day,sender_lng,sender_lat,count(*) as total_msg_cnt
  17. from db_msg.tb_msg_etl
  18. group by msg_day,sender_lng,sender_lat
  19. -- 统计今日发送消息和接收消息的用户数
  20. create table db_msg.tb_rs_user_cnt comment '每日发送和接收消息的人数' as
  21. select
  22. msg_day,
  23. count(distinct sender_account) as sender_user_cnt,
  24. count(distinct receiver_account) as receiver_user_cnt
  25. from db_msg.tb_msg_etl
  26. group by msg_day;
  27. -- 统计今日发送消息最多的Top10用户
  28. create table db_msg.tb_rs_s_user_top10 comment '发送消息最多的10个用户' as
  29. select
  30. sender_name,
  31. count(*) as sender_msg_cnt
  32. from db_msg.tb_msg_etl group by sender_name
  33. order by sender_msg_cnt desc
  34. limit 10;
  35. -- 统计今日接收消息最多的Top10用户
  36. create table db_msg.tb_rs_r_user_top10 comment '接受消息最多的10个用户' as
  37. select
  38. receiver_name,
  39. count(*) as receiver_msg_cnt
  40. from db_msg.tb_msg_etl group by tb_msg_etl.receiver_name
  41. order by receiver_msg_cnt desc
  42. limit 10;
  43. -- 统计发送人的手机型号分布情况
  44. create table db_msg.tb_rs_sender_phone comment '发送人的手机型号分布' as
  45. select
  46. sender_phonetype,
  47. count(*) as cnt
  48. from db_msg.tb_msg_etl group by sender_phonetype;
  49. -- 统计发送人的设备操作系统分布情况
  50. create table db_msg.tb_rs_sender_os comment '发送人的os分布' as
  51. select
  52. sender_os,
  53. count(*) as cnt
  54. from db_msg.tb_msg_etl group by sender_os;

 

基于FineBI完成指标的可视化展示:

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/繁依Fanyi0/article/detail/524260
推荐阅读
相关标签
  

闽ICP备14008679号