草庐IT

num_records

全部标签

hadoop - 为什么我的 Hadoop 作业得到 Map task num = 1 ,并生成了 300 多个结果文件?

我有这样一份Hadoop工作。MR只有map,没有reduce。所以设置job.setNumReduces(0)。输入文件约300+然后我运行作业,我可以看到只有1个maptask在运行。完成它大约需要1个小时。然后我检查结果,我可以在输出文件夹中看到300多个结果文件。有什么问题吗?或者这是正确的做法?我真的希望Map应该等于输入文件的数量(而不是1)。我也不知道为什么输出文件数与输入文件数相同。hadoop作业是从oozie提交的。非常感谢您的热心帮助。新松 最佳答案 当您将reducer数量设置为0时,生成的输出对应于map任

hadoop - 解释 "There can be many keys (and their associated values) in each partition, but the records for any given key are all in a single partition"

“每个分区中可以有许多键(及其相关值),但任何给定键的记录都在一个分区中。”这是一本著名的hadoop教科书的一行。我没有理解它的第二部分的全部含义,即“但是任何给定键的记录都在一个分区中。”这是否意味着单个键的所有记录都应该在单个分区或其他地方。 最佳答案 buttherecordsforanygivenkeyareallinasinglepartition如果您有一个键,则该键及其相关联的值必须位于单个分区上。有时该值可能相当大。但这是对值大小的限制。它必须足够小以适合单个分区。请注意,键和值上可能还有其他常量,具体取决于您用于

csv - 最佳实践 : how to handle data records with changing "schema"/ "columns"

这是一个最佳实践问题。我们的设置是一个hadoop集群,将(日志)数据存储在hdfs中。我们获取csv格式的数据,每天一个文件。在hadoop中对这些文件运行MR作业没问题,只要文件的“架构”(尤其是列数)不变即可。但是,我们面临的问题是,我们要分析的日志记录最终会发生变化,因为可能会添加或删除列。我想知道你们中的一些人是否愿意分享针对此类情况的最佳实践。我们目前能想到的最好的方式是将数据存储为json格式而不是csv。但是,这会增加(至少增加一倍)所需的存储空间。我们还遇到了ApacheAvro和ApacheParquet,并且刚刚开始对此进行研究。欢迎就此问题提出任何想法和意见。

mysql - Oracle 11g 对比 MySQL 对比 Hadoop :- benchmarking for 10^6 to 10^9 records

我需要针对10^6到10^9条记录(MySQL中的行)对Oracle11g、MySQL和Hadoop进行基准测试。将使用实时数据全天候进行广泛的数据挖掘查询。我想知道哪个数据库会更好,尤其是在某些实际统计数据方面。future几个月的数据肯定会超出这个范围。是否有针对此的任何开源基准测试工具?或者谁有一些有用的数据?提前致谢。编辑:-Hadoop不是数据库。它是一个分布式文件系统。让我更详细地解释一下我的要求。这就是我现在所拥有的,我的所有数据都在mysql中,我计划将其导出到hadoop并在其上运行我的数据挖掘算法。算法结束后,最后的结果会发送到mysql更新当前数据。我现在真的不能

java - Hadoop 中的默认 Record Reader,全局或本地字节偏移量

我们知道Hadoop中的映射器(以及缩减器)只能处理键值对作为输入和输出。RecordReader是将原始输入从文件转换为键值对的东西。您可以编写自己的“RecordReader”。Hadoop提供的默认RecordReader称为TextInputFormat,它读取文本文件的行。它为拆分的每条记录发出的键是读取的行的字节偏移量(作为LongWritable),值是行的内容直到终止\n字符(作为文本对象)。我们还知道每个输入文件拆分的映射器由平台实例化。假设有一个巨大的文件F存储在HDFS上,它的拆分存储在几个不同的节点上;文件F是行分隔的,并且正在由一些使用默认RecordRead

hadoop - Sqoop 导出作业的 sqoop.export.records.per.statement 是否有限制?

有谁知道Sqoop批量导出作业的sqoop.export.records.per.statement的值是否有限制?我有非常大的数据,例如200,000,000行数据要从Impala导出到Vertica。我将得到[Vertica][VJDBC](5065)ERROR:ToomanyROScontainersexistforthefollowingprojections如果recordsperstatement设置得太低,或者java.lang.OutOfMemoryError:GC如果每个语句的记录数设置得太高,则超出开销限制。有人知道如何解决这个问题吗?谢谢!

xml - How to read compressed bz2 (bzip2) Wikipedia dumps into stream xml record reader for hadoop map reduce

我正在使用HadoopMapReduce对维基百科数据转储(以bz2格式压缩)进行研究。由于这些转储太大(5T),我无法将xml数据解压缩到HDFS中,只能使用hadoop提供的StreamXmlRecordReader。Hadoop确实支持解压缩bz2文件,但它会任意拆分页面并将其发送给映射器。因为这是xml,所以我们需要拆分为标签。有没有办法把hadoop自带的bz2解压和streamxmlrecordreader一起使用? 最佳答案 维基媒体基金会刚刚为HadoopStreaming接口(interface)发布了一个Inpu

scala - Apache Spark : Get number of records per partition

我想检查一下我们如何获取有关每个分区的信息,例如总号。以yarn集群部署方式提交Spark作业时,驱动端各分区的记录数,以便在控制台进行日志或打印。 最佳答案 我会使用内置函数。它应该尽可能高效:importorg.apache.spark.sql.functions.spark_partition_iddf.groupBy(spark_partition_id).count 关于scala-ApacheSpark:Getnumberofrecordsperpartition,我们在St

php - Laravel:如何更改默认登录错误消息: 'these credentials do not match our records'

我想更改默认的登录验证错误消息,例如:Username&Passworddoesn'tmatch代替thesecredentialsdonotmatchourrecords如何做到这一点? 最佳答案 您可以将此消息更改为此文件中的另一条消息:resources/lang/en/auth.php这是一行:'failed'=>'Thesecredentialsdonotmatchourrecords.', 关于php-Laravel:如何更改默认登录错误消息:'thesecredential

php - 银条 3.4 : How to add default records to db from model

无法在SilverStripeDocumentation中定位如何让数据对象模型在/dev/build上注入(inject)一组默认记录谁能给我指出正确的方向这就是我目前拥有的,显然我想将预配置选项注入(inject)到我的模块的这个恰当命名的配置模型中。classConfigurationextendsDataObject{privatestatic$db=array('Option'=>'Varchar','Value'=>'Varchar');privatestatic$summary_fields=array('Option'=>'Option','Value'=>'Value