相关推荐
数据分析系统的设计与实现
2024-11-10 15:44

大数据demo,参考自淘宝双11数据分析与预测课程案例 厦大数据库实验室博客 (xmu.edu.cn)

数据分析系统的设计与实现

  1. 操作系统 Linux (实验室版本为 Ubuntu1 8 .04 ,集群环境为 centos6.5
  2. Hadoop 版本: 2.9.0
  3. JDK 版本: 1.8
  4. Java IDE Eclipse 3.8
  5. Spark 版本: 2.3.0
  6. Mysql 8.0.29
  7. Tomcat 8.5
  8. Echarts 3.4.0
  9. Hive 3.1.2
  10. Sqoop 1.4.6

基于Dynamic Web + JSP + Hive +Mysql + Spark 实现的双十一购物数据可视化分析,使用Echarts可视化,spark 的 SVM进行回头客预测

image-20220609233133730

三个数据集分别是用户行为日志文件user_log.csv 、回头客训练集train.csv 、回头客测试集test.csv

用户行为日志user_log.csv,日志中的字段定义如下

  • user_id | 买家id
  • item_id | 商品id
  • cat_id | 商品类别id
  • merchant_id | 卖家id
  • brand_id | 品牌id
  • month | 交易时间:月
  • day | 交易事件:日
  • action | 行为,取值范围{0,1,2,3},0表示点击,1表示加入购物车,2表示购买,3表示关注商品
  • age_range | 买家年龄分段:1表示年龄<18,2表示年龄在[18,24],3表示年龄在[25,29],4表示年龄在[30,34],5表示年龄在[35,39],6表示年龄在[40,49],7和8表示年龄>=50,0和NULL则表示未知
  • gender | 性别:0表示女性,1表示男性,2和NULL表示未知
  • province| 收获地址省份

回头客数据集

  • user_id | 买家id
  • age_range | 买家年龄分段:1表示年龄<18,2表示年龄在[18,24],3表示年龄在[25,29],4表示年龄在[30,34],5表示年龄在[35,39],6表示年龄在[40,49],7和8表示年龄>=50,0和NULL则表示未知
  • gender | 性别:0表示女性,1表示男性,2和NULL表示未知
  • merchant_id | 商家id
  • label | 是否是回头客,0值表示不是回头客,1值表示回头客,-1值表示该用户已经超出我们所需要考虑的预测范围。NULL值只存在测试集,在测试集中表示需要预测的值。
 

Hive是基于Hadoop的一个数据仓库工具,用来进行数据提取、转化、加载,这是一种可以存储、查询和分析存储在Hadoop中的大规模数据的机制。

Hive数据仓库工具能将结构化的数据文件映射为一张数据库表,并提供SQL查询功能,能将SQL语句转变成MapReduce任务来执行。

 

创建Hive外部表

 

例如

 

Hive 可以使用类sql语句进行增删查改,对应的会自动转成mapreduce操作

使用Sqoop将数据从Hive导入MySQL

首先在mysql里面创建数据库

 

创建表

 

导入数据

 

利用Spark的SVM预测回头客

  1. 读取数据,从Hadoop

     
  2. 构建训练模型

     
  3. 评估模型,设置阈值并且输出得分和分类结果

     
  4. 上传到mysql

Tomcat+mysql+JSP 进行开发,使用Dynamic Web Project

思路

Java后端从数据库中查询数据 然后前端获取服务端的数据,JSP页面最后使用ECharts和查询的数据来展现可视化,并且代理到Web 8080端口显示界面

效果

所有卖家各消费行为对比

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-yMcTfMSH-1654792113133)(https://vvtorres.oss-cn-beijing.aliyuncs.com/image-20220610000233762.png)]

男女买家交易对比

image-20220610000302109

年龄段交易对比

image-20220610000443946

商品类别交易额对比

image-20220610000522760

各个省份成交量对比

image-20220610000545122

SVM回头客预测对比

image-20220610000807708

  1. 熟悉了Hive,Hive是基于Hadoop的一个数据仓库工具,用来进行数据提取、转化、加载,这是一种可以存储、查询和分析存储在Hadoop中的大规模数据的机制。Hive数据仓库工具能将结构化的数据文件映射为一张数据库表,并提供SQL查询功能,能将SQL语句转变成MapReduce任务来执行。十分适合对数据仓库进行统计分析

  2. 熟悉了Java Web(Dynamic Web Project)开发,使用eclipse IDE,Tomcat作为Web容器, java编写后端,JSP编写用户界面,Echarts来进行可视化图表,即可实现数据分析系统

  3. 熟悉了 SVM算法,以及Spark的ML库里面的SVM的使用 , 支持向量机SVM是一种二分类模型。在机器学习里面已经学习过了。而在Spark的Machine Learning库里面已经封装好了SVM,里面的SVM只支持最基础的二分类,可以设置迭代次数正则化等参数,如果设置了阈值,则会把大于阈值的结果当成正预测,小于阈值的结果当成负预测,可以通过AUC来评估。

关于Hive的外部表和内部表

Hive在导入数据到外部表,数据并没有移动到自己的数据仓库目录下,也就是说外部表中的数据并不是由它自己来管理的

删除外部表的时候,Hive仅仅删除外部表的元数据,数据是不会删除的

那么,应该如何选择使用哪种表呢?在大多数情况没有太多的区别,因此选择只是个人喜好的问题。但是作为一个经验,如果所有处理都需要由Hive完成,那么你应该创建内部表,否则使用外部表

Hive导入MySQL数据库失败

因为是编码问题,把Mysql编码全部改成utf-8 即可正常导入。 外部表中的数据并不是由它自己来管理的

删除外部表的时候,Hive仅仅删除外部表的元数据,数据是不会删除的

那么,应该如何选择使用哪种表呢?在大多数情况没有太多的区别,因此选择只是个人喜好的问题。但是作为一个经验,如果所有处理都需要由Hive完成,那么你应该创建内部表,否则使用外部表

Hive导入MySQL数据库失败

    以上就是本篇文章【数据分析系统的设计与实现】的全部内容了,欢迎阅览 ! 文章地址:http://sjzytwl.xhstdz.com/quote/2234.html 
     栏目首页      相关文章      动态      同类文章      热门文章      网站地图      返回首页 物流园资讯移动站 http://sjzytwl.xhstdz.com/mobile/ , 查看更多   
发表评论
0评