《深入理解Hadoop(原书第2版)》——第1章 为什么会有大数据 1.1 什么是大数据

简介:

本节书摘来自华章计算机《深入理解Hadoop(原书第2版)》一书中的第1章,第1.1节,作者 [美]萨米尔·瓦德卡(Sameer Wadkar),马杜·西德林埃(Madhu Siddalingaiah),杰森·文纳(Jason Venner),译 于博,冯傲风,更多章节内容可以访问云栖社区“华章计算机”公众号查看。

第1章

为什么会有大数据

随着近20多年来计算技术的不断革新,企业积累了大量数据。数字传感器的进步使得通信系统越来越广泛的使用,尤其是移动平台和移动终端的飞速增长;系统运行产生的大量日志以及越来越多的企业采用无纸化办公的工作方式,这些情况都使得企业积攒起了海量数据资源。并且随着人们对现代科技越来越多的依赖,数据将会以更快的速度增长下去。

摩尔定律告诉我们,大约每隔两年,计算机的性能将历史性地提升一倍。最初,计算资源的提升速度满足了飞速增长的数据的处理需求。好景不长,到2005年前后,数据处理需求增长的速度已经快于计算资源处理能力的提升速度。

计算机工业界想到了另外一个更加经济有效的解决办法,就是数据的并行处理。既然单台计算机无法满足大数据量的计算需求,那就用多台计算机来并行处理这些海量数据。Hadoop就是利用互相联网的多台计算机使用MapReduce(一种改进的单指令多数据流[SIMD]计算技术)来并行地处理计算大量数据。

像亚马逊、谷歌、微软这样的公司为我们提供了较为廉价的云计算服务,使得分布式并行计算的概念更加深入人心,相比于购买计算资源,我们只要花少量的费用就可以租用相应的计算资源。

本书是使用Hadoop平台来开发和运行软件的实用指南。Hadoop项目起初由Apache Software Foundation来负责管理,目前像Cloudera、MapR和Hortonworks这样的公司也加入到维护发展它的阵营中。本章会从整体上介绍大数据的由来以及Hadoop项目。

1.1 什么是大数据

就本书而言,大数据(Big Data)姑且定义为无法被符合服务等级协议(service level agreement,SLA)的单台计算机处理或(有些时候)存储的任何数据集。后续内容会有更精确的解释。理论上讲,单台计算机可以处理任意规模的数据。对于超过单台计算机存储量的海量数据,可以存放到类似网络附属存储(network attached storage,NAS)这样的共享存储设备中,然后输入到单台计算机去计算处理。但是,这样处理数据所花费的时间往往会大大超过允许的数据处理时间。

举个简单的例子。某个业务单元每次平均需要处理200GB的数据,数据的读取速率是每秒钟50MB。如果按照每秒钟50MB的数据读取速率来计算,顺序读取硬盘上的100MB数据,需要两秒钟,读取全部的200GB数据就大约需要一个小时了。然而这200GB的数据要求在5分钟之内处理完毕。如果这个业务处理的200GB数据可以被平均分布到100个计算节点,每个节点处理分配的数据(举一个简单的用例,假设用SALES_YEAR>2001这样一条简单的准则来划分数据集),去掉这100个计算节点的CPU处理时间和数据结果整合的时间,整个数据处理过程会在1分钟之内完成。

这个简单的例子说明,大数据是一个相对的概念,是相对于我们的业务需求而言的。

Jeff Dean 博士有一篇关于并行计算的论文,详见http://www.cs.cornell.edu/projects/ladis2009/talks/dean-keynote-ladis2009pdf 。从本地磁盘顺序读取1MB数据需要2千万纳秒。从速度为1 Gbps 的网络中读取1MB的数据需要2亿5千万纳秒(假定传输2KB的数据需要25万纳秒,还要返回传输确认,这样每传输2KB数据需要网络往返共50万纳秒的时间)。虽然文中的描述稍显过时,数据的传输读取绝对速度已经有了提高,但是这不妨碍我们在本章中拿来做比照,因为这些数据之间的相对值变化不大。

相关实践学习
基于MaxCompute的热门话题分析
Apsara Clouder大数据专项技能认证配套课程:基于MaxCompute的热门话题分析
相关文章
|
9月前
|
存储 分布式计算 Hadoop
从“笨重大象”到“敏捷火花”:Hadoop与Spark的大数据技术进化之路
从“笨重大象”到“敏捷火花”:Hadoop与Spark的大数据技术进化之路
491 79
|
分布式计算 Kubernetes Hadoop
大数据-82 Spark 集群模式启动、集群架构、集群管理器 Spark的HelloWorld + Hadoop + HDFS
大数据-82 Spark 集群模式启动、集群架构、集群管理器 Spark的HelloWorld + Hadoop + HDFS
528 6
|
存储 分布式计算 大数据
Flume+Hadoop:打造你的大数据处理流水线
本文介绍了如何使用Apache Flume采集日志数据并上传至Hadoop分布式文件系统(HDFS)。Flume是一个高可用、可靠的分布式系统,适用于大规模日志数据的采集和传输。文章详细描述了Flume的安装、配置及启动过程,并通过具体示例展示了如何将本地日志数据实时传输到HDFS中。同时,还提供了验证步骤,确保数据成功上传。最后,补充说明了使用文件模式作为channel以避免数据丢失的方法。
661 4
|
存储 分布式计算 Hadoop
数据湖技术:Hadoop与Spark在大数据处理中的协同作用
【10月更文挑战第27天】在大数据时代,数据湖技术凭借其灵活性和成本效益成为企业存储和分析大规模异构数据的首选。Hadoop和Spark作为数据湖技术的核心组件,通过HDFS存储数据和Spark进行高效计算,实现了数据处理的优化。本文探讨了Hadoop与Spark的最佳实践,包括数据存储、处理、安全和可视化等方面,展示了它们在实际应用中的协同效应。
578 2
|
存储 分布式计算 Hadoop
数据湖技术:Hadoop与Spark在大数据处理中的协同作用
【10月更文挑战第26天】本文详细探讨了Hadoop与Spark在大数据处理中的协同作用,通过具体案例展示了两者的最佳实践。Hadoop的HDFS和MapReduce负责数据存储和预处理,确保高可靠性和容错性;Spark则凭借其高性能和丰富的API,进行深度分析和机器学习,实现高效的批处理和实时处理。
470 1
|
分布式计算 Hadoop 大数据
大数据体系知识学习(一):PySpark和Hadoop环境的搭建与测试
这篇文章是关于大数据体系知识学习的,主要介绍了Apache Spark的基本概念、特点、组件,以及如何安装配置Java、PySpark和Hadoop环境。文章还提供了详细的安装步骤和测试代码,帮助读者搭建和测试大数据环境。
481 1
|
SQL 分布式计算 大数据
大数据平台的毕业设计01:Hadoop与离线分析
大数据平台的毕业设计01:Hadoop与离线分析
576 0
|
机器学习/深度学习 分布式计算 大数据
|
分布式计算 资源调度 Hadoop
大数据-80 Spark 简要概述 系统架构 部署模式 与Hadoop MapReduce对比
大数据-80 Spark 简要概述 系统架构 部署模式 与Hadoop MapReduce对比
301 2
|
存储 分布式计算 资源调度
大数据-04-Hadoop集群 集群群起 NameNode/DataNode启动 3台公网云 ResourceManager Yarn HDFS 集群启动 UI可视化查看 YarnUI(一)
大数据-04-Hadoop集群 集群群起 NameNode/DataNode启动 3台公网云 ResourceManager Yarn HDFS 集群启动 UI可视化查看 YarnUI(一)
287 5

热门文章

最新文章