当前位置:
首页
文章
后端
详情

书籍1 实战大数据(Hadoop+spark+Flink)2

第二章是搭建IDEA开发环境和Linux虚拟机

这章的内容较少,但需要花费的时间较长,毕竟都是实操部分
首先是搭建IDEA开发环境
每一个IT开发人员都得有一个合适的开发工具,IDEA是大数据开发的首选,在Windows上安装IDEA,然后构建Maven项目。

  1. 最首先的还是安装JDK,因为大数据开发的很多地方都是得需要用到Java的。
    具体的安装和环境配置这里不再说明。
  2. Maven的安装与配置
    这是专门用于构建和管理Java相关项目的工具。使用它有两点好处,1是Maven管理的Java项目都有着相同的项目结构;二是便于统一维护jar包
  3. IDEA的安装与配置
    全称Intellij IDEA,是进行Java编程的集成环境
  4. 虚拟机的搭建,这个在之前的学习中就已经搭建完毕,这里不再赘述。

第三章基于Hadoop构建大数据平台

大数据项目得运行在大数据平台之上,而构建Hadoop集群是构建大数据平台的核心。
前文也说过,至少得先安装部署三个集群,分别是HDFS、YARN、和zookeeper集群。

3.1 Zookeeper分布式协调服务

编写单机的应用比较简单,但是编写分布式应用就比较困难,主要是因为会出现部分失败。部分失败就是在网络节点中传输时,如果网络错误就无法得知消息是否传递成功。zookeeper是一个分布式应用的协调服务,他可以对部分失败进行正确处理(不是避免)。
zookeeper提供一些服务给分布式应用,分布式应用可以基于此构建出更高级的服务,比如分布式锁、配置管理、分布式消息队列、分布式通知与协调服务等等。
zookeeper的基本架构
zookeeper服务自身组成了一个集群,其中有两种角色,主节点leader和从节点follower。前者负责投票的发起和决议,更新系统状态;后者接受客户端请求并向客户端返回结果。
工作原理
zookeeper就是原子广播,就是对zookeeper上的所有主机发送数据包,由此保证了各个服务器间的数据同步。
zookeeper集群工作前的准备工作
首先准备好Hadoop三个节点,zookeeper是由Java编写的,运行在JVM上,所以zookeeper的节点得先安装JDK的运行环境。

  • 配置hosts文件,方便集群间通过hostname相互通信
  • 时钟同步
  • SSH免密登录
  • 安装JDK

3.2 HDFS分布式文件系统

HDFS是Hadoop的核心子项目
他是分布式计算中数据存储的基础,是基于流式数据访问和处理超大文件需求而开发的。
背景:他出现的背景也很简单,就是数据量太大了,大到一个操作系统管辖的范围内存储不下,所以需要分配到更多的操作系统管理的磁盘中存储,但是这样会导致数据的管理和存储不方便,HDFS应运而生。
能力:有4个,分别是能够存储大量数据;能够支持流计算;数据有一致性,不易修改;硬件故障时能快速应对。
系统架构通常是建立在由网络连接起来的一组计算机组成的集群上。不同的计算机(或者叫节点)都有着不同的分工。比如:
NameNode:主节点NN
SecondaryNameNode:备用节点
DataNode:从节点DN
HDFS客户端
以上部分是一个HDFS最基本的架构。一个主节点,一个备用节点,至少一个从节点,和若干客户端。

那么HDFS具体是储存在哪的呢?

实际上数据文件被切分成数据块(Block),然后均匀的放在DN的节点当中,再通过NN来进行管理。

免责申明:本站发布的内容(图片、视频和文字)以转载和分享为主,文章观点不代表本站立场,如涉及侵权请联系站长邮箱:xbc-online@qq.com进行反馈,一经查实,将立刻删除涉嫌侵权内容。

同类热门文章

深入了解C++中的new操作符:使用具体实例学习

C++中的new操作符是动态分配内存的主要手段之一。在程序运行时,我们可能需要动态地创建和销毁对象,而new就是为此提供了便利。但是,使用new也常常会引发一些问题,如内存泄漏、空指针等等。因此,本文将通过具体的示例,深入介绍C++中的new操作符,帮助读者更好地掌握其使用。


深入了解C++中的new操作符:使用具体实例学习

怎么用Java反射获取包下所有类? 详细代码实例操作

Java的反射机制就是在运行状态下,对于任何一个类,它能知道这个类的所有属性和方法;对于任何一个对象,都能调用这个对象的任意一个方法。本篇文章将通过具体的代码示例,展示如何通过Java反射来获取包下的所有类。


怎么用Java反射获取包下所有类? 详细代码实例操作

员工线上学习考试系统

有点播,直播,在线支付,三级分销等功能,可以对学员学习情况的监督监控,有源码,可二次开发。支持外网和局域网私有化部署,经过测试源码完整可用!1、视频点播:视频播放,图文资料,课件下载,章节试学,限时免

员工线上学习考试系统

了解Java中的volati关键字的作用 以及具体使用方法

本篇文章将和大家分享一下Java当中的volatile关键字,下面将为各位小伙伴讲述volatile关键字的作用以及它的具体使用方法。


了解Java中的volati关键字的作用 以及具体使用方法

Java Map 所有的值转为String类型

可以使用 Java 8 中的 Map.replaceAll() 方法将所有的值转为 String 类型: 上面的代码会将 map 中所有的值都转为 String 类型。 HashMap 是 Java

Java Map 所有的值转为String类型