基于大数据平台的毕业设计

前言

2022年最新大数据毕设文章:
基于大数据平台的毕业设计01:基于Docker的HDP集群搭建

最近有很多人问我,大数据专业有什么好的毕设项目,我就简单的回复了一下。也有直接问我要源码的…

所以就抽空写一写自己毕业设计的一个思路,大数据是我实习自学的,这个思路是我当初自己想的,就当做一份参考吧。

在我毕业那年,同学们毕业设计大多都是以Java语言开发的各种管理系统、xx商城为主,包括我刚开始的想法也是这样的。这也是计算机专业很常见的毕业设计选题。

这种选择的好处就是简单,网上模板多。动手能力强的同学,直接去github上拉下来源码,稍微修改一下,一个毕业设计项目就完成了。动手能力弱的同学,也可以使用钞能力低成本完成。

至于缺点嘛,就是这类毕设太常见了,除非UI设计和思路特别出彩,让老师眼前一亮。要不然见多识广的老师,就会带着一颗毫无波澜的内心,用空洞的眼神看完你的演示,机械般的给你打下一个及格分。

当然,对于大部分同学的内心想法就是:能过就行。也有的同学担心,自己的毕设项目和其他同学的重合度很高,老师可能会问一些细节(稀奇古怪)的问题。所以,毕设最好还是自己做,就算找的模板,也要把技术和架构搞清楚

同时,想要做一个与众不同的毕设,在技术上也一定要“花里胡哨”。

大数据毕设思路

大数据方向的毕设,归根结底还是基于大数据平台进行构思。对于管理系统、商城这种项目毕设来说,我们面向的是编程语言,而大数据主要还是还是面向平台。就像你一说大数据,别人接着就说,大数据…就是那个Hadoop吗?

是的。虽然这个回答很片面,但是对于大数据毕设来说,就是基于Hadoop来发散延伸。

我学的不是大数据专业,也曾有成为一名优©秀(V)的Java开发的梦想。后来,17年实习阴差阳错就接触到大数据,并开始自学大数据,所以在18年毕业的时候,就基于大数据完成了毕业设计。这里就简单说一下当初我的毕业设计流程。

  1. 在虚拟机搭建Hadoop、Hive、Kafka、Spark集群
  2. 使用Java(建议Python)采集了163w数据放入MySQL
  3. 用Flume将mysql中的数据实时写入到了Kafka中
  4. Scala开发sparkstreaming程序,读取kafka数据进行处理,然后写入Kafka
  5. 使用Flume将kafka数据写入到了HDFS,然后加载到hive进行hsql分析
  6. 使用Springboot和Vue,开发数据管理系统,对数据进行查询和图形化展示,对接了echarts和百度地图。

就很简单,很简单。大家可以在上面的思路上进行扩展。下面就展开说一下具体步骤。

大数据毕设实践

关于下文中提到的一些大数据概念,可以参考之前写的一篇大数据的文章。

0. 数据准备

大数据,大数据,数据肯定是大的无边无际。那多大才算大?自从18年负责一天1w亿条数据的接入、存储、处理工作之后,我就飘了~ 经常同事告诉我说,要接入一个大数据量的文件接口,我问他多少,他说一天一百亿条,我一般会轻飘飘地说一句,一百亿,算多吗 ~~~

其实,对于毕业设计来说,数据量并不需要那么大,数据在大数据平台中的流转,以此来模拟大数据中的ETL和实时处理,从而体现数据的价值。 那么,数据从哪里获取呢?

方法1,我们可以写一个程序来生成一些测试数据,但是这样的话,数据重合度太高,很难体现出数据分析价值。那么就采用方法二,开发爬虫进行采集网上的数据

当时我用Java开发了一个爬虫,采集了163w条POI位置数据,存到了MySQL中,完成了数据的准备工作。爬虫的开发还是推荐用Python,17年我还不会Python,后来18年开始学习Python,后来又做了很多爬虫开发工作,再后来写了爬虫系列由浅入深的学习文章,大家也可以参考一下。

1. 大数据平台搭建

欲抬手摘星望月,必先平地起高楼。

上面也说了,大数据还是围绕着平台来搞。当时我在笔记本上搭建了三台centos系统的虚拟机,主要用来搭建下面的集群。

在集群搭建之前,需要完成下列操作系统和环境的配置。

  1. 安装JDK、Scala
  2. 三台虚拟机之间进行互信操作
  3. 安装mysql数据,作为hive的元数据库

Hadoop - 基础核心

Hadoop集群作为大数据基础建设,同时也是大数据核心。其HDFS提供了分布式存储,Yarn提供了计算资源。

如果是毕设的话,可以选择一主两从的架构,即一个NameNode和两个DataNode的架构。如果想要玩的花一点,就选择HA高可用架构,即两主两从,这里就需要四台虚拟机。

关于HA,就是两个NameNode,但是一个NN处于工作状态(active),一个NN处于待命状态(standby)。你可以kill掉active的NN,然后让standby的NN接管集群。

关于HA,在大数据是随处可见的。在Hadoop生态中,集群中的多NN和多DN是HA,HDFS的副本机制也是HA,这一块在论文中还是能体现不少东西的。

下面就是Hadoop集群的NN和DN的基本信息。

NameNode

DataNode

Hive - 离线分析

Hive在我的毕设中的角色就是一个数据分析的工具,主要表述的是大数据ETL中L阶段,以及大数据平台的离线分析部分。

Hive是一个数据仓库,关于它的作用就是对HDFS上的数据进行离线分析,虽然它不是数据库,但是大家可以把它当做数据库来用。这里其他基础的概念就不多介绍了。

时至今日,也有很多hive的平替产品,例如号称比hive快800倍的clickhouse,以及druid,但是在应用场景方面和hive还是有一定出入的,有兴趣的可以去了解一下。

大数据在数仓方面,有很多值得玩的平台架构和一些基本概念,ETL描述的就是基于数据仓库进行的数据处理过程。

Spark、Kafka - 实时计算

现在提到实时计算,可能大家首先会想到flink。的确,flink在开源实时领域方面绝对算是TOP了。18年的时候,实时处理还是SparkStreaming应用的比较广泛。所以当时我安装的是Spark集群,来模拟的实时计算。

其实Spark/flink集群都是可以不搭建的,在Spark集群上运行程序属于standlone模式,如果使用yarn模式只需要有客户端就可以了。Spark程序运行在yarn上,能对cpu和内存进行资源隔离,而且不需要要单独维护一个Spark集群。

而作为实时处理配套,Kafka和Rabbitmq之间我还是倾向于Kafka。在Kafka搭建之前,先搭建zookeeper集群,zk是kafka的依赖组件,用来记录一些元数据。

下图命令操作就是消费写入Kafka的数据。

Kafka

我们要做的就是将数据库/数据仓库中的离线数据,转换为数据流(Data Stream),作为生产者实时写入到Kafka中。

我们开发的Spark/flink程序作为消费者实时读取Kafka中的数据,实时处理并数据计算结果。如下图,为SparkStreaming的程序监控页面。

SparkStreming程序,可以使用Java、Scala、Python开发,但是选择Scala比较好一些。一是Scala的语法结构更贴合流式处理,二是源码都是Scala写的。

Flume - 数据交换神器

当初刚接触Flume的时候,真的没玩明白,云里雾里的。后来深入研究了一下之后,数据在oracle、MySQL、Kafka、HDFS以及其他存储平台上,就可以进行同步。不过MySQL和oracle需要自己定义Source和Sink。

Flume的简单之处在于配置化。当初我将数据从MySql抽取到Kafka,部分配置如下。

Flume

顺带一提,在大数据量的情况下,Flume很多参数还是需要调的。当初我将1W亿/天的数据从Kafka落地到HDFS的时候,写了几千行的配置,调了很多参数。

3. 数据展示

最后就是前台的数据展示了,使用了Springboot和Vue做了一个POI数据管理系统。主要实现分类查询和POI搜索标点地图展示功能。

但是这个系统,我只找到了登录页面和地图搜索标点的截图了…

登录页面

地图

数据管理系统发挥的空间还是挺多的,比如页面样式的优化,再比如前台可以使用Node + Vue,后端使用Springboot来实现前后端分离架构。

结语

主要是给大家提供一个大数据平台毕业设计的基本思路,很多细节的地方还可以优化。我们也不难发现,这里的大数据集群都是独立安装的,我们同样可以使用Ambari进行统一的安装、管理、启动、状态监控。

最近也是在研究Ambari,前几周刚花了一个星期,完成了Ambari2.7.5的编译安装工作。后期的目标是配合docker在一台机器上完成大数据集群的搭建工作,当然这里主要是玩,构建测试环境,性能啥的就不要考虑了哈。

忙完这一阵,完成Scrapy系列文章,就开始着手准备大数据平台系列文章的编写。期待下一次相遇。

感谢每一次相遇

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/46545.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

博网即时通讯软件的设计与实现毕业设计(论文+PPT+源码)

幻灯片1 选题背景及意义 研究技术与方法 设计内容与模块 设计的环境、方法及措施 幻灯片2 选题背景及意义 1 即时通讯软件使人与人的沟通突破时空极限,突破环境极限,使自我突破心理极限。 1 背景 2 作为使用频率最高的网络软件,即时通…

数据可视化方向的毕业设计详细思路

距离我本科答辩顺利通过已经过去十几天了,我决定把本科阶段最后的小成果做个总结分享给想做此方向项目的小伙伴们,希望能让你们想在动手实操时有项目可供参考,有实现思路可供学习,演示视频先呈现给大家。 一、研究目的及意义 &a…

毕业设计-后台管理系统

关于代做毕业设计的历程: 关于毕设算是大学最重要和最能锻炼自己的课程设计之一了,但是相对于一部分大学生来说,要想自己凭空想出一个系统,而且是使用大学所学的技术是比较难做出一个像样的毕业设计,这是发自我个人的观…

毕业设计- 基于Android的教务管理系统(带流程图)

—— 等风来不如追风去,追逐的过程就是人生的意义。 项目介绍 系统用来管理班级的日常班务信息,系统角色分为三种管理员、班委和学生。 管理员:拥有最高权限,可以管理即增加、查询、修改和删除所有数据。 班委:不能申批…

本科毕业论文-软件开发类-《基于Android端开关控制系统的设计与实现》-论文模板

目 录 前言 一、任务书 二、目录 三、论文正文 摘要 ABSTRACT 1.引言 2.系统开发环境 2.1可行性分析 2.2 开发工具介绍 3.需求分析 3.1 功能需求分析 3.2 数据流程图 4.总体设计 4.1 系统整体模块设计 4.2 红外编码设计与蓝牙通信设计 4.3 系统功能结构设计 …

计算机毕业设计源码——基于Android的真人社交游戏辅助应用开发

编号 本科生毕业设计(论文) 题目: 真人社交游戏辅助应用开发 专业 学 号 学生姓名 指导教师 摘 要 时至今日,社交已成为人们生活中必不可少的一部分,社交网络的盛行已经成为一种必然趋势.与此同时&a…

Mixlab Insight:不同职业对GPT-4的看法

shadow LLM 、生成式人工智能,大量企业需要升级改造内部的岗位和工作流,至少包括:商业模式改造升级、团队岗位的职业要求和人才、虚拟/仿真的生产线。 MixGPT:在GPT4上线当天,我们开启了激烈的讨论,关于职业…

Android 大作业之个人博客新闻App

用到的技术: 网络编程、多线程编程、listview、数据库、等等 效果图 **注:**新闻数据来源“聚合数据”API接口,如果没显示出来,是调用次数超过了,最好自己申请API接口(免费) 本设计代码已上…

Android 优秀文章收集整理集合

转载 自 https://github.com/jiang111/awesome-android-tips 记录自己遇到的比较有价值的Android相关的blog MaHua是online md编辑器,挺好用。 本是自己记录一些有价值的blog,没成想有不少star的,为了方便查看,等有时间就会进行…

计算机技能高考素材,高中作文万能通用素材 2021高考必备作文素材

在平时的时候,多积累一些作文素材,有助于语文的写作!下面不妨和高三网小编一起来了解下关于2021高考必备作文素材,希望这些素材能帮助我们在作文中有更好的发挥。 高中作文万能通用素材:由“提笔忘字”谈汉字传承 曾几…

四级英语图表作文真题计算机,2016年四级作文模板之图片与图表

2016年四级作文模板之图片与图表 英语四六级考试改革之后,图画作文考的比较多,无论是图画作文还是主题作文,下面的结构是可以通用的,考生可以重点记下图画作文与主题作文的句型。 一、看图作文模板 第一段:简要描述图画…

个人仿制android QQ、android大作业

仿制android QQ说明 app下载地址:http://download.csdn.net/download/h18733517027/10258434 服务器下载:http://download.csdn.net/download/h18733517027/10258435 说明下载:http://download.csdn.net/download/h18733517027/10258480 …

仿写App,如何获取app内的图片资源?以安卓机为例

​ 获取到App的apk包 有些安卓手机中,长按该app图标,会有个弹窗,弹窗里有分享按钮, 分享出去的就是一个apk包 修改后缀 把apk包的后缀名改为.zip 解压zip包 使用解压工具,解压zip包,会获得该app内的所…

豁然开朗篇:安卓开发中关于内存那些事

你所写的每一句代码,在内存里是怎么分布的,搞清楚这个问题,你对编程的理解又上升到一个高度了 前言 首先,如果对于java虚拟机的内存划分不清楚的同学,可以先去了解一下java虚拟机把java程序加载到内存以及内存的分布是…

基于Android的背单词软件【源码+文档+答辩PPT】

目录 1、关于本课题 2、开发平台 3、系统分析 3.1 国外安卓应用发展的现状 3.2 国内安卓应用发展的现状 3.3 系统构建目标分析 3.4 系统构建功能分析 3.4.1 系统的总体架构 3.4.2 系统功能模块 3.4.3 应用功能规划图 4、系统设计 4.1 前台背单词展示子系统详细设计 …

自动驾驶:硬件平台

自动驾驶的研发流程 大致可以分为以下4个步骤: 软件在环 软件在环是基于仿真和模拟的软件仿真,类似于赛车类游戏。即是在软件系统里仿真模拟出真实的道路环境如光照、天气等自然环境,开发者可将自动驾驶代码开发完毕后,在仿真系…

自动驾驶(五十)---------Gtest测试

本文将介绍单元测试工具Google Test(GTest)在Linux操作系统中测试环境的搭建方法。本文属于Google Test使用的基础教程。在Linux中使用Google Test之前,需要对如下知识有一些了解: C/C编程方法 makefile的编写 Linux命令行操作 GT…

BEV感知:BEVDet

自动驾驶:BEVDet IntroductionMethodoloData AugmentationNetwork StructureScale-NMS 实验 Introduction 作者通过现有的算法(LSS)、独特的数据增强方案与新的NMS方案整合了一个BEV框架(BEVDet)。 如下图&#xff1a…

【自动驾驶】高级辅助驾驶系统与车联网

【自动驾驶】高级辅助驾驶系统与车联网 Note:本文是对刘春晖教授的 高级辅助驾驶系统与车联网(上),高级辅助驾驶系统与车联网(下) 论文进行排版整理,由于论文中插图较多,并没有全部整理进来,用能力的小伙伴请看原文 文…

自动驾驶技术

高精地图(HD Maps):支持其他模块 定位(Localization):讨论汽车如何确定他所处的位置,汽车利用激光和雷达数据,将这些传感器感知内容与高分辨地图进行对比,这种对比使得汽…