吐血整理:盘点19种大数据处理的典型工具

发布时间:2024-02-13 点击:98
大数据的生命周期分为数据获取(data acquisition)、数据存储(data storage)、数据分析(data analysis)以及结果(result),并且将前述大数据处理的三代技术中相关的工具映射至数据获取、数据存储和数据分析三个环节来进行分类讨论,详情如表1-2所示。
▲表1-2 大数据处理的典型工具
在数据获取阶段,通常涉及从多源异构的数据源获取数据,这些数据源可能是批处理数据源,也有可能是实时流数据源;
在数据存储阶段,需要对前一阶段已经获取到的数据进行存储,以便进行后续的分析与处理,常见的存储方式有磁盘(disk)形式和无盘(diskless)形式。
在数据分析阶段,针对不同的应用需求,会运用各类模型和算法来对数据进行分析与处理。
在表1-2中,三代技术中不同的处理阶段所涉及的工具存在重叠。此外,对于混合计算技术,其本身同时涉及批处理技术和实时处理技术,实现混合计算模型的技术也要比单纯的批处理技术和实时处理技术更加复杂;鉴于混合计算技术的上述特点,这里不对在数据的获取、存储与分析方面所涉及的具体工具做特别的划分。
01 hdfs
hadoop分布式文件系统(hadoop distributed file system,hdfs)目前是apache hadoop项目的一个子项目,与已有的分布式文件系统有很多相似之处。
此外,作为专门针对商业化硬件(commodity hardware)设计的文件系统,hdfs的独特之处也很明显:首先其具有很高的容错性,其次可以部署在较为廉价的硬件上,最后能够提供高吞吐量的应用数据访问能力。
对于终端用户而言,hdfs就是一个传统的文件系统,具有文件和目录的创建、修改、删除等常规操作。
hdfs采用主/从(master/slave)体系结构。单个hdfs集群仅包含一个名称节点(namenode),其提供元数据服务,管理文件系统的命名空间(namespace),并引导用户对文件的访问。此外,单个hdfs集群可以包含多个数据节点(datanode),数据节点负责管理与自身相关联的存储空间。
hdfs对外给出文件系统的命名空间作为用户对数据进行访存的接口。
在hdfs内部,单个文件通常被分割成多个块(block),这些块存储在一系列数据节点上。由名称节点在整个hdfs集群的命名空间上执行文件和目录的打开、读取和关闭等操作。文件的块与数据节点之间的映射也是由名称节点管理的。数据节点基于名称节点的指令来实施块的创建、复制和删除等。
02 sqoop
sqoop是一个在hadoop和关系数据库服务器之间传送数据的工具,方便大量数据的导入导出工作,其支持多种类型的数据存储软件。
sqoop的核心功能为数据的导入和导出。
导入数据:从诸如mysql、sql server和oracle等关系数据库将数据导入到hadoop下的hdfs、hive和hbase等数据存储系统。 导出数据:从hadoop的文件系统中将数据导出至关系数据库。
sqoop的一个显著特点是可以使用mapreduce将数据从传统的关系数据库导入到hdfs中。sqoop作为一个通用性的工具,只需要在一个节点上安装,因此安装和使用十分便捷。
03 flume
flume是由hadoop生态系统中著名的软件公司cloudera于2011年发布,该软件能够支持分布式海量日志的采集、集成与传输,以实时的方式从数据发送方获取数据,并传输给数据接收方。
flume具有两个显著的特点:可靠性和可扩展性。
针对可靠性,其提供了从强到弱的三级保障,即end-to-end、store on failure和best effort。 针对可扩展性,其采用三层的体系结构,即agent、collector和storage,每层都可以在水平方向上进行扩展。
flume以agent的方式运行,单个agent包含source、channel和sink三个组件,由agent对数据进行收集,然后交付给存储机制。从多个数据源收集到的日志信息依次经过上述三个组件,然后存入hdfs或hbase中。因此,通过flume可以将数据便捷地转交给hadoop体系结构。
04 scribe
scribe是由facebook开发的分布式日志系统,在facebook内部已经得到了广泛的应用。scribe能够针对位于不同数据源的日志信息进行收集,然后存储至某个统一的存储系统,这个存储系统可以是网络文件系统(network file system,nfs),也可以是分布式文件系统。
scribe的体系结构由三部分组成:scribe agent、scribe和storage。
第一部分scribe agent为用户提供接口,用户使用该接口来发送数据。 第二部分scribe接收由scribe agent发送来的数据,根据各类数据所具有的不同topic再次分发给不同的实体。 第三部分storage包含多种存储系统和介质。
scribe的日志收集行为只包括主动写入的日志,scribe自身没有主动抓取日志的功能。因此,用户需要主动向scribe agent发送相关的日志信息。
05 hbase
hbase的全称为hadoop database,是基于谷歌bigtable的开源实现,其使用hadoop体系结构中的hdfs作为基本的文件系统。谷歌根据bigtable的理念设计实现了谷歌文件系统gfs,但是该方案未开源。hbase可以称为bigtable的山寨版,是开源的。
hbase在hadoop体系结构中的位置介于hdfs和mapreduce之间,其架构为主/从形式,内部的两个核心构件为master和regionserver。
hbase是建立在hdfs之上的分布式面向列的数据库,能够针对海量结构化数据实现随机的实时访问,其设计理念和运行模式都充分利用了hdfs的高容错性。
由于hbase是面向列的,因此它在数据库的表中是按照行进行排序的。在hbase中,所有的存储内容都是字节,任何要存储的内容都需要先转换成字节流的形式,此外数据库的行键值按照字节进行排序,同时形成了索引。
06 mapreduce
mapreduce是hadoop体系结构中极为重要的核心构件之一。作为一个分布式的并行计算模型,mapreduce包含的两个单词分别具有特定的含义:“map”表示“映射”;“reduce”表示“归约”。上述两个概念的基本理念源于函数式编程语言(functional programming language)。
与传统的编程语言不同,函数式编程语言是一类非冯诺依曼式的程序设计语言,其编程范式的抽象程度很高,主要由原始函数、定义函数和函数型构成。
mapreduce的这种设计思想使分布式并行程序设计的难度得以简化,用户将已有的代码稍加修改就能够运行在分布式环境下。在实际应用场景中,大多数情况下收集到的大量多源异构数据都不具有特定的规律和特征。
mapreduce的工作过程能够在一定程度上将上述数据按照某种规律进行归纳和总结。在“map”阶段,通过指定的映射函数提取数据的特征,得到的结果的形式为键值对 。在“reduce”阶段,通过指定的归约函数对“map”阶段得到的结果进行统计。对于不同的具体问题,所需要的归约函数的个数可能千差万别。
总体来说,mapreduce具有开发难度低、扩展性强和容错性高三个显著特点。尽管其分布式并行计算模型能大幅度提高海量数据的处理速度,但受限于大数据的规模,通常mapreduce的作业例程的执行时间为分钟级,随着数据量的增加,耗时若干天也很普遍。
07 hive
hive针对数据仓库来提供类似sql语句的查询功能,其能够将以结构化形式存储的数据映射成数据库表,主要应用场景为多维度数据分析和海量结构化数据离线分析。hive的体系结构主要包含用户接口、元数据存储、解释器、编译器、优化器和执行器。
虽然使用mapreduce也能够实现查询,但是对于逻辑复杂度高的查询,用户在实现时难度较大。hive提供类似于sql的语法接口,降低了学习成本,提高了开发效率。
hive基于sql的语法来定义名为hiveql或hql的查询语言,其支持常规的索引化和基本的数据查询,更重要的是能够将基于sql的查询需求转化为mapreduce的作业例程。
除了自身具有的功能之外,用户可以在hive中编写自定义函数,具体来说分为三种:
用户自定义函数(user defined function,udf) 用户自定义聚合函数(user defined aggregation function,udaf) 用户自定义表生成函数(user defined table-generating function,udtf)
08 pig
pig是一个面向过程的高级程序设计语言,能够分析大型数据集,并将结果表示为数据流,其内置了多种数据类型,并且支持元组(tuple)、映射(map)和包(package)等范式。
pig有两种工作模式:local模式和mapreduce模式。
在local模式下

阿里云服务器年租金
拼多多网店挂阿里云服务器安全吗
双12校园云服务器哪里买划算
阿里云换服务器需要重新备案吗
数字证书的应用场景及数字证书办理步骤
网页打不开么么么么么么么
Ubuntu下SSH代理设置
更换宿主机-云服务器问题