2020版冲刺年薪30W超全大数据学习路线思维导图

1次阅读

共计 1632 个字符,预计需要花费 5 分钟才能阅读完成。

大数据学习路线

​ 下面和大家讲一下大数据学习的路线,帮助大家快速进入大数据行业。我会结合自己的实际经历还说明学习路线。该路线针对的对象是零基础小白,目标是到初中级大数据工程师,要求掌握数据建模,数据存储,数据存储,数据传输,数据分析等能力达到大数据岗位的应聘标准。

(一)Java 基础和 web 开发

​ 很多人问过我,学大数据要不要学 Java,我的答案是肯定的。首先 Java 是一门面向对象的编程语言,也是一门应用非常之广的语言,对于零基础的小白必须先有一些 基本的编码能力和面向对象编程的思想。其次很多框架的底层就是用 Java 进行开发的,比如 Hadoop,如果想要更近一步,源码是要看的。所以学习 Java 基础是十分必要的。Java 基础重点包括:

  • Java 常用类【特别是字符串处理相关的类】
  • 异常处理
  • 集合泛型
  • IO 流
  • 多线程
  • 反射
  • 网络编程
  • 常见设计模式
  • JVM【难点 + 重点,但比较花时间】

​ 那么 JavaWeb 开发要不要会呢?我的建议是了解就行,了解常见的 SSM 框架,了解 Web 项目大致的开发流程,对整个软件的开发有一个感性的认识,这样就足够了。当然学有余力请继续深入。

(二)工具类

软件开发都绕不开使用别人的轮子,好的工具让我们开发效率大大提升,下面工具必须掌握:

编辑器:Eclipse + IDEA

项目构建工具:Maven + Gradle(有余力)

数据库:Mysql【初期先了解增删改查,后面有时间能多深入就多深入】

操作系统:Linux【常见命令会就行】

脚本语言:Shell【看得懂就行】

虚拟机:VMware 创建 - 克隆虚拟机,拍摄 - 还原快照【操作过就行】

(三)Hadoop 生态系统

  • HDFS:学会搭建完全分布式集群,知道如何根据业务编写 MapReduce 程序,并放到集群上运行
  • YARN:知道它是个资源管理器和 k8s 一样,熟悉 Job 提交的过程
  • Mapreduce:编写业务程序【熟悉一些数据倾斜的解决方案和底层 Shuffle 过程】
  • Zookeeper:分布式协调框架【知道 Zookeeper 选举机制和常用命令】
  • Hive:数据仓库,底层是 MapReduce【重点掌握:HQL 语句书写,窗口函数,多做一些案例总结自己的套路,优化也要了解一下】
  • HBase:超大型分布式数据库,经常用来做实时查询【了解 HBase 架构,RowKey 设计原则,后面开发用到再来深入】
  • Flume:数据传输框架【知道 Flume 组成,拦截器和选择器使用】
  • Kafka:消息缓存框架【Kafka 架构 - 压测 - 监控 -ISR 同步队列 - 事务 - 高效读取】
  • Sqoop:关系型数据库和 HDFS,HBase 之间数据的传输框架
  • Ambari:用于配置、管理和监视 Hadoop 集群,基于 Web,界面友好
  • Impala:对存储在 Apache Hadoop 的 HDFS,HBase 的数据提供直接查询互动的 SQL

(四)Spark 生态

​ 到这里又要学习一门新的编程语言 Scala,初入 Scala 可能会对它的语法结构产生不习惯,熟悉之后你会发现 Java 代码是很繁琐的。编程语言是什么不重要,关键是背后的思想和逻辑才重要。

Scala:了解基础语法、函数式编程和隐式转换就行

Spark:可以看作是对 Hadoop 框架的优化,它是基于内存进行计算的,性能提高很多。【熟悉 Spark 部署方式 - 提交流程 - 参数设置 -RDD 血统 - 宽窄依赖 - 转换和行动算子 - 广播变量和累加器 - 性能调优】

Spark-Sql:spark 中负责和数据库交互的模块【熟悉 DataFrame-DataSet,SQL 语句书写,UDF 和 UDTF 函数使用】

Spark-Streaming:spark 中负责流式计算的模块【了解流式计算的原理,背压机制,窗口函数】

(五)Flink 框架

Flink 是目前最火的处理流式数据的框架应掌握一下内容

相关资料

本文配套GitHub:https://github.com/zhutiansam…

本文配套公众号:FocusBigData

回复【大数据面经】【大数据面试经验】【大数据学习路线图】会有惊喜哦

正文完
 0