【基于Spark的电影推荐系统】环境准备

概览

本科毕设做过电影推荐系统,但当时的推荐算法只有一个,现在已经忘记大部分了,当时也没有记录,因此写这个博客重新来记录一下。此外,技术栈由于快秋招原因来不及做过多的部分,因此只实现简单的功能,在此不做搜索引擎部分。

技术栈:Vue+Element-ui、SpringBoot、Spark、Redis、Mongodb、Flume、Kafka、Azkaban

1 云服务器选择

  • 由于电脑比较老,开太多应用实在太卡(之前做毕设的体会),因此选用了云服务器。
  • 之前使用过云服务器,但由于大数据需要的内存比较大些,实在没钱。发现轻量服务器貌似便宜一点,因此使用腾讯的轻量服务器4cpu+16GB来开发。

2 大数据环境搭建

  • 时间原因+服务器配置原因,在此我只用买了一台来进行开发,这是出于开发的简单,旦可能这样做一台机器上压力比较大。
  • 由于配置实在太费时间(之前每次配置都心累),因此直接使用docker拉取镜像
  • 操作系统:centos7.6

2.1 docker安装

2.2 使用docker-compose快速部署spark环境

  1. 安装docker-compose见docker-compose安装
  • 我使用curl方式安装,若遇见curl: (35) Encountered end of file,则原因可能是云服务器没有开放443端口(解决方案:443端口开放
  1. 快速部署Spark环境
    (1)新建test文件夹并进入,依次执行下列命令
wget https://raw.githubusercontent.com/zq2599/blog_demos/master/sparkdockercomposefiles/docker-compose.yml
wget https://raw.githubusercontent.com/zq2599/blog_demos/master/sparkdockercomposefiles/hadoop.env 
# 在test文件下执行该命令,该命令需要等待一会
docker-compose up -d

(2)使用docker-compose ps查看当前的镜像

image.png

(3)使用docker-compose ps查看当前运行的情况

  • 这里我出现两个exit,查询日志(docker-compose logs)检查错误原因
# 发现错误
could only be replicated to 0 nodes instead of minReplication (=1).  There are 1 datanode(s) running and no node(s) are excluded in this operation.
  • 可能是因为端口原因,设置云服务器全部端口开放(有风险但先暂时这样做),重新启动docker-compose up -d,成功
    image.png

(4)查看HDFS(xxxx:50070)

image.png
(5)查看Spark界面(xxxx:8080)

image.png

总结

  • 为了快速回顾之前的项目,因此是怎么简单怎么来,但如果有时间的话,建议用三台机器,也可以考虑CDH搭建。
  • 下一节将介绍数据准备、离线推荐功能开发
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
基于Spark电影推荐系统是使用Spark框架来构建和训练的推荐系统,它可以根据用户的历史行为和电影的属性,为用户推荐可能感兴趣的电影。下面是一个简单的步骤来构建基于Spark电影推荐系统: 1. 数据准备:收集电影数据集,包括用户行为数据和电影属性数据。用户行为数据可以包括用户对电影的评分、观看历史、收藏等信息,电影属性数据可以包括电影的类型、导演、演员等信息。 2. 数据预处理:使用Spark的DataFrame API加载和处理数据。对于用户行为数据,可以进行数据清洗、去重、转换等操作;对于电影属性数据,可以进行特征提取、编码等操作。 3. 特征工程:将用户行为数据和电影属性数据转换为特征向量。可以使用特征提取方法如TF-IDF、Word2Vec等,将电影和用户表示为稠密向量。 4. 模型训练:使用Spark的机器学习库(如MLlib)训练推荐模型。常用的推荐模型包括协同过滤、基于内容的推荐、矩阵分解等。可以使用交叉验证和超参数调优来选择最佳模型。 5. 推荐生成:使用训练好的模型对新用户进行推荐。可以根据用户的特征向量和电影的特征向量计算用户与电影之间的相似度,并为用户推荐相似度高的电影。 6. 评估和优化:通过离线评估指标(如准确率、召回率等)来评估推荐系统的性能,并进行优化。可以尝试不同的模型算法、特征工程方法和参数设置来提高推荐效果。 请注意,以上只是一个基本的框架,实际构建电影推荐系统还需要根据具体需求和数据进行调整和优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

编程小白呀

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值