1 Java基础:

视频方面:推荐毕老师《毕向东JAVA基础视频教程》。

学习hadoop不需要过度的深入,java学习到javase,在多线程和并行化多多理解实践即可。

书籍方面:推荐李兴华的《java开发实战经典》

2 Linux基础:

视频方面:(1)马哥的高薪Linux视频课程-Linux入门、

(2)兄弟连的新版Linux视频教程、

(3)老段的讲解鸟哥Linux基础+私房菜、

(4)老男孩的Linux。

看的过程中,不可只看不同步操作,这是最危险的一件事!不需全部看完。如:基本的Linux操作系统官网下载、安装(命令行界面和图形界面)、基本命 令、网络配置、快照、VMtools工具安装、虚拟机的菜单熟悉等等。这是必须要首先完成的。之后,可回过来再根据需要使用到哪些,再来学习即可。当作工具书!

书籍方面:

(1)《鸟哥的linux私房菜》,

(2)之后,进一步可以看书籍《鸟哥的服务架设篇》。

(3)Linux随身指南(4)老男孩Linux运维

系统学习只要多多实践,学习linux并不枯燥。

在这里还是要推荐下我自己建的大数据学习交流群:199427210,群里都是学大数据开发的,如果你正在学习大数据 ,小编欢迎你加入,大家都是软件开发党,不定期分享干货(只有大数据软件开发相关的),包括我自己整理的一份2018最新的大数据进阶资料和高级开发教程,欢迎进阶中和进想深入大数据的小伙伴加入。

3 hadoop书籍:

(1)《Hadoop实战 (第1版) 陆嘉恒》、《Hadoop实战 (第2版) 陆嘉恒》

(2)《hadoop definitive guide 》,中文书名是《Hadoop权威指南(第1版)曾大聃译》,《Hadoop权威指南 (第2版) 周敏奇译》,《Hadoop权威指南 (第3版 ) 华东师范大学数据科学与工程学院译》

(3)Hadoop技术内幕:《深入解析Hadoop common和HDFS架构设计与实现原理》 蔡斌

4)hadoop技术内幕:《深入解析YARN架构设计与实现原理》董西成

(5)Hadoop技术内幕:《深入理解MapReduce架构设计与实现原理》 董西成

(5)《Hadoop in Action》中文书名是《Hadoop实战》,

(6)《Hadoop应用开发技术详解 刘刚》

(7)《Hadoop 核心技术》翟周伟

平常多看看hadoop的官网,虽然是官网,但尽量多学习计算机方面的单词,对后续学习帮助极大。

4 Maven书籍:

强烈推荐书籍:Maven实战 许晓斌著。目前是第一版

5、spark书籍:

(1)《Spark大数据处理 技术、应用与性能优化 高彦杰》

(2)《深入理解Spark核心思想与源码分析 耿嘉安》

摘要: 致目前想要学习大数据,但是却不了解大数据,也不知道该从哪开始学起的同学,希望这篇文章能够帮到你们。

最近群里有很多朋友问我,"初学大数据,不知道怎么开始学","不知道大数据具体是什么东西,只是听说很厉害的样子","学习大数据,需要学习 哪些框架,只学习spark可以吗?" 等等...类似的问题,针对这些问题,一两句话解释不清楚,所以,就在这里写一些我自己的看法吧,希望可以帮助到初学者的你。

大数据初学者,总结下来,大致有这么几种情况:

  • 跨行业转过来的(这一种是最难的,之前可能都没接触过编程,这种属于真正的0基础)
  • 即将毕业的大四学员(包含计算机专业或者其他专业,这一种稍微好点,最起码大学的时候多少会接触一点编程)
  • 有软件开发经验的老司机(包含,javaweb,.net,c 等)

上面这几种情况的同学都有一个共性,对大数据都是0基础,相对而言,有软件开发经验的老司机学习起来不会很吃力,其余的刚开始学起来会比较吃力,但只要肯比别人多花点时间,多下点功夫,其实并没有你想象的那么难。有付出,才会有回报!

好了,废话不多说了,下面就直接说一下,针对所有大数据初学者的一些学习建议吧【适用于上面三种基础的同学】

大数据是什么?

有很多朋友问过我,大数据到底是什么?一句话来概括

  • 针对非软件行业的朋友
  • 根据你平时在超市,加油站,饭店等地方的一些消费行为,通过大数据这个技术,我们可以知道你现在的年龄范围,是否婚配,是否有孩子,孩子大致是几岁,是否有固定住宅,车大致是什么价位的等信息。
  • 针对软件行业的朋友
  • 平时我们写的程序都是在一台机器上运行,处理能力有限,当然,数据量也是有限的。大数据这个技术,其实就是可以实现把我们的代码分布在很多台机器上去并行处理海量的数据,然后从这些海量数据中获取有价值,有意义的信息。

学习大数据需要的基本功

1. linux基础是必须的,最起码需要掌握linux命令行下的基本操作命令

2. javase基础【包含mysql】,注意是javase,不是javaee。javaweb那一块的知识针对大数据工程师而言不是必须的

大数据技术板块划分

  • 数据采集
  • flume kafka logstash filebeat ...
  • 数据存储
  • mysql redis hbase hdfs ...
  • 虽然mysql不属于大数据范畴 但是我在这也列出来了,因为你在工作中离不开它
  • 数据查询
  • hive impala elasticsearch kylin ...
  • 数据计算
  • 实时计算
  • storm sparkstreaming flink ...
  • 离线计算
  • hadoop spark ...
  • 其他框架
  • zookeeper ...

下面有一张图,大致列出来了大数据生态圈周边的一些技术框架[不够全面,仅供参考]

其实这张图中主要列出来了hadoop生态圈的框架,后期有时间的话重新整理一份完整的 。

PDA设备号

这个图中列出来了很多框架,其实,学习大数据,就是要学习大数据生态圈周边的各种框架。

大数据学习步骤

上面虽然列出来了很多框架,但是最开始学习的时候没必要全部都学,就算是在工作中,这些框架也不一定会全部用到。

下面我就大致列一下,各种框架的一个学习步骤吧:

注意:下面列出来的顺序只是个人建议,可以根据个人实际情况来调整顺序

  1. linux基础和javase基础【包含mysql】
  • 这些是基本功,刚开始也不可能学的很精通,最起码要对linux中的一些基本的命令混个脸熟,后面学习各种框架的时候都会用到,用多了就熟悉了。javase的话建议主要看面向对象,集合,io,多线程,以及jdbc操作即可。
  1. zookeeper
  • zookeeper是很多大数据框架的基础,中文名称是动物园的意思,因为目前的大数据框架的图标很多都是动物的形状,所以zookeeper其 实就是可以管理很多大数据框架的。针对这个框架,主要掌握如何搭建单节点和集群,以及掌握如何在zkcli客户端下对zookeeper的节点进行增删改 查操作即可。
  1. hadoop
  • 目前企业中一般都是用hadoop2.x的版本了,所以就没有必要再去学hadoop1.x版本了,hadoop2.x主要包含三大块
  • hdfs 前期,主要学习hdfs的一些命令即可,上传,下载,删除,移动,查看等命令...
  • mapreduce 这个需要重点学习下,要理解mr的原理以及代码实现,虽然现在工作中真正写mr的代码次数很少了,但是原理还是要理解的。
  • yarn 前期了解即可,只需要知道yarn是一个资源调度平台,主要负责给任务分配资源即可,yarn不仅可以给mapreduce任务调度资源,还可以为 spark任务调度资源...yarn是一个公共的资源调度平台,所有满足条件的框架都可以使用yarn来进行资源调度。
  1. hive
  • hive是一个数据仓库,所有的数据都是存储在hdfs上的,具体【数据仓库和数据库】的区别大家可以去网上搜索一下,有很多介绍。其实如果对 mysql的使用比较熟悉的话,使用hive也就简单很多了,使用hive主要是写hql,hql是hive的sql语言,非常类似于mysql数据库的 sql,后续学习hive的时候主要理解一些hive的语法特性即可。其实hive在执行hql,底层在执行的时候还是执行的mapredce程序。
  • 注意:其实hive本身是很强大的,数据仓库的设计在工作中也是很重要的,但是前期学习的时候,主要先学会如何使用就好了。后期可以好好研究一下hive。
  1. hbase
  • hbase是一个nosql 数据库,是一个key-value类型的数据库,底层的数据存储在hdfs上。在学习hbase的时候主要掌握 row-key的设计,以及列簇的设计。要注意一个特点就是,hbase基于rowkey查询效率很快,可以达到秒级查询,但是基于列簇中的列进行查询, 特别是组合查询的时候,如果数据量很大的话,查询性能会很差。
  1. redis
  • redis也是一个nosql 数据库和key-value类型的数据库,但是这个数据库是纯基于内存的,也就是redis数据库中的数据都是存储在内存中的,所以它的一个特点就是适用 于快速读写的应用场景,读写可以达到10W次/秒,但是不适合存储海量数据,毕竟机器的内存是有限的,当然,redis也支持集群,也可以存储大量数据。 在学习redis的时候主要掌握string,list,set,sortedset,hashmap这几种数据类型的区别以及使用,还有 pipeline管道,这个在批量入库数据的时候是非常有用的,以及transaction事务功能。
  1. flume
  • flume是一个日志采集工具,这个还是比较常用的,最常见的就是采集应用产生的日志文件中的数据。一般有两个流程,一个是flume采集数据存 储到kafka中,为了后面使用storm或者sparkstreaming进行实时处理。另一个流程是flume采集的数据落盘到hdfs上,为了后期 使用hadoop或者spark进行离线处理。在学习flume的时候其实主要就是学会看flume官网的文档,学习各种组建的配置参数,因为使用 flume就是写各种的配置。
  1. kafka
  • kafka 是一个消息队列,在工作中常用于实时处理的场景中,作为一个中间缓冲层,例如,flume->kafka->storm/sparkstreaming。学习kafka主要掌握topic,partition,replicate等的概念和原理。
  1. storm
  • storm是一个实时计算框架,和hadoop的区别就是,hadoop是对离线的海量数据进行处理,而storm是对实时新增的每一条数据进行 处理,是一条一条的处理,可以保证数据处理的时效性。学习storm主要学习topology的编写,storm并行度的调整,以及storm如何整合 kafka实时消费数据。
  1. spark
  • spark 现在发展的也很不错,也发展成了一个生态圈,spark里面包含很多技术,spark core,spark steaming,spark mlib,spark graphx。
  • spark生态圈里面包含的有离线处理spark core,和实时处理spark streaming,在这里需要注意一下,storm和spark streaming ,两个都是实时处理框架,但是主要区别是:storm是真正的一条一条的处理,而spark streaming 是一批一批的处理。
  • spark中包含很多框架,在刚开始学习的时候主要学习spark core和spark streaming即可。这个一般搞大数据的都会用到。spark mlib和spark graphx 可以等后期工作需要或者有时间了在研究即可。
  1. elasticsearch
  • elasticsearch是一个适合海量数据实时查询的全文搜索引擎,支持分布式集群,其实底层是基于lucene的。在查询的时候支持快速模 糊查询,求count,distinct,sum,avg等操作,但是不支持join操作。elasticsearch目前也有一个生态 圈,elk(elasticsearch logstash kibana)是一个典型的日志收集,存储,快速查询出图表的一整套解决方案。在学习elasticsearch的时候,前期主要学习如何使用es进行增 删改查,es中的index,type,document的概念,以及es中的mapping的设计。

大数据Hadoop学习系列之Hadoop、Spark学习路线相关推荐

  1. 大数据学习系列之八----- Hadoop、Spark、HBase、Hive搭建环境遇到的错误以及解决方法

    大数据学习系列之八----- Hadoop.Spark.HBase.Hive搭建环境遇到的错误以及解决方法 参考文章: (1)大数据学习系列之八----- Hadoop.Spark.HBase.Hiv ...

  2. 大数据学习系列之七 ----- Hadoop+Spark+Zookeeper+HBase+Hive集群搭建 图文详解

    引言 在之前的大数据学习系列中,搭建了Hadoop+Spark+HBase+Hive 环境以及一些测试.其实要说的话,我开始学习大数据的时候,搭建的就是集群,并不是单机模式和伪分布式.至于为什么先写单 ...

  3. Hadoop学习系列之Hadoop、Spark学习路线(很值得推荐)

    Hadoop学习系列之Hadoop.Spark学习路线(很值得推荐) 文章出自:http://www.cnblogs.com/zlslch/p/5448857.html 1 Java基础: 视频方面: ...

  4. Hadoop学习系列之Hadoop、Spark学习路线

    1 Java基础: 视频方面:推荐毕老师<毕向东JAVA基础视频教程>. 学习hadoop不需要过度的深入,java学习到javase,在多线程和并行化多多理解实践即可. 书籍方面:推荐李 ...

  5. 大数据讲课笔记2.3 初探Hadoop世界

    文章目录 零.学习目标 一.导入新课 二.新课讲解 (一)Hadoop的前世今生 1.Google处理大数据三大技术 2.Hadoop如何诞生 3.Hadoop主要发展历程 (二)Hadoop的优势 ...

  6. 大数据学习(09)--spark学习

    文章目录 目录 1.spark介绍 1.1 spark介绍 1.2 scale介绍 1.3 spark和Hadoop比较 2.spark生态系统 3.spark运行框架 3.1 基本概念 3.2 架构 ...

  7. Hadoop精华问答 | 非大数据的项目能否用Hadoop?

    戳蓝字"CSDN云计算"关注我们哦! 技术的日新月异,让我们见证了Hadoop十年从无到有,再到称王.2006年项目成立的一开始,"Hadoop"这个单词只代表 ...

  8. 深圳大数据培训技术分享:Hadoop集群同步

    深圳大数据培训技术分享:Hadoop集群同步 分享--是技术突飞猛进的很好体验!在千锋学习大数据技术,开始学会了分享,班里五十个人,每个人就能得到49份不同技术探讨.每次到分享的时刻,总会收获不同的想 ...

  9. 国内跨云端平台应用的大数据平台供应商,基于Hadoop的互联网大数据平台解决方案,武汉数道云...

    跨云端大数据平台是什么?有何实质性的价值呢?如何去实现跨云端大数据平台技术呢?这是耐人深思的话题. 高速发展的信息技术,不断扩张的数据库容量,互联网作为信息传播和再生的平台,"信息泛滥&qu ...

最新文章

  1. 《JavaScript高级程序设计(第3版)》教程大纲
  2. guava之Stopwatch
  3. MySQL的几个概念:主键,外键,索引,唯一索引
  4. SAP loyalty management点击了公式超链接后的处理逻辑
  5. java中重新加载指定文件_java-更改后重新加载属性文件
  6. 手机相机自动识别语音提示
  7. 数组的合并,去重,排序
  8. CodeForces 980 E The Number Games
  9. OpenStack还是OpenStack,云已不是那朵云!
  10. 李沐亚马逊资深首席科学家 - 动手学深度学习v2 -2安装
  11. 【J2EE规范】什么是JNDI
  12. 全栈开发之基于云开发实现微信聊天功能
  13. 多列堆积柱形图怎么做_Excel2010中进行制作多列堆积图的操作方法|多列堆积柱状图...
  14. 基于单片机的智能家居环境监控系统的设计
  15. 【历史上的今天】5 月 19 日:Java 之父诞生;中国首家互联网公司成立;CP/M 操作系统发明者出生
  16. Python中Oracle的连接、增删改查
  17. 关于未来趋势的几点预测:
  18. html相同数据合并单元格合并单元格,Javascript合并表格中具有相同内容单元格示例...
  19. Java筑基18-布置作业啦(考查抽象类、内部类、工厂模式等)
  20. 摩托车结构与维修视频教程

热门文章

  1. 【C语言】例3.1 华氏温度转化为摄氏温度
  2. 为什么说Java不适合做游戏开发,劣势在哪里?
  3. B站小迪安全第五天-系统及数据库
  4. Problem O: 显示单月的日历
  5. 【游戏精粹】AI系统(一):优化策略
  6. 很傻计算机的英语,谨慎使用这5句英文:会让聪明的你听起来很傻
  7. 湖南大学21夏训练三18.写出来吧
  8. 科普 | 什么是NFT?有何价值?
  9. python设计查询余额程序_【Python】查询账户余额demo---创蓝253云通讯平台案例
  10. Linux中的文件传输优化