草庐IT

custom-sort

全部标签

hadoop - Apache pig : Can we convert a custom Writable object to Pig format?

我们有一个自定义可写值对象的SequenceFile,该对象本质上等同于Pig中的复杂包数据类型。有没有一种方便的方法,我们可以编写自定义函数将hadoopWritable对象转换为bag数据类型,然后使用pig脚本对其进行处理? 最佳答案 一种选择是查看elephant-bird-如果你向下滚动这个github页面到README部分,它有一个关于Pig的部分:PigIncludesconverterinterfaceforturningTuplesintoWritablesandviceversa我从来没有用过它,我想你必须自己实

sorting - sort_array 按不同列排序,Hive

我有两列,一列是产品,一列是购买日期。我可以通过应用sort_array(dates)函数对日期进行排序,但我希望能够在购买日期之前对sort_array(products)进行排序。有没有办法在Hive中做到这一点?表名是ClientIDProductDate100Shampoo2016-01-02101Book2016-02-04100Conditioner2015-12-31101Bookmark2016-07-10100Cream2016-02-12101Book22016-01-03然后,为每个客户获取一行:selectclientID,COLLECT_LIST(Produc

sorting - 在 MapReduce 中使用分区器进行二次排序有什么意义?

如果您需要在传递给reduce阶段时对给定键的值进行排序,例如移动平均线,或者模仿SQL中的LAG/LEAD分析函数,您需要在MapReduce中实现二次排序.在Google上搜索之后,常见的建议是:A)在映射阶段发出复合键,其中包括,B)创建一个“复合键比较器”类,其目的是为了二次排序,比较键后比较要排序的值,从而使传递给reducer的Iterable被排序。C)创建一个“自然键分组比较器”类,其目的是用于主要排序,仅比较要排序的键,以便传递给缩减器的Iterable包含属于给定键的所有值。D)创建一个“自然键分区器类”,我不知道它的目的,也是我的问题的目的。来自here:Then

python - Hive 转换使用 Python : Unable to initialize custom script

我正在尝试通过将Python脚本作为映射器来测试HiveTRANSFORM。我的hive脚本是:addfile/full/path/to/mapper.py;setmapred.job.queue.name=queue_name;usemy_database;selecttransform(s.year,s.month,s.day,s.hour)using'mapper.py'frommy_tableslimit10;我的Python映射器脚本只是试图回应输入:#!/usr/local/bin/pythonimportsysforlineinsys.stdin:printline我尝试

hadoop - 为什么要对 map reduce 中生成的中间键进行 SORT?

我理解为什么中间键值按键分组但为什么要对它们进行排序? 最佳答案 分组就是这样实现的。当您按键排序时,它们会组合在一起。它是否已排序并不重要……重要的是相同的键彼此相邻。排序可能不是最好的方法。也许某种哈希算法会更快:O(N)而不是O(NlogN)。它被实现为排序只是因为有一些应用程序需要排序的键(例如HBase/BigTable)。最近开发了一种可插入排序,并且在测试版中可用。我还没有机会尝试一下。http://hadoop.apache.org/docs/stable/hadoop-mapreduce-client/hadoop

scala - Spark : Custom key compare method for reduceByKey

我需要在Scala中使用我自己的类作为键/值对中的键。特别是,我有一个包含两个变量id1和id2的简单类,我希望元素仅根据id2和不是id1。我在网上找不到任何关于如何以及在何处可以重写reduceByKey()方法的比较方法的信息,以便它可以根据我的自定义compare()方法。感谢任何帮助。谢谢你。 最佳答案 您不能覆盖reduceByKey的比较,因为它无法利用这样一个事实,即您的数据通常在整个集群中的不同执行程序上按key进行混洗。不过,您可以更改key(请注意,根据您使用的转换/操作,这可能会重新洗牌周围的数据)。RDD中

java - 象夫 : To read a custom input file

我在玩Mahout,发现FileDataModel接受以下格式的数据userId,itemId,pref(long,long,Double).我有一些格式的数据String,long,double在Mahout上使用此数据集的最佳/最简单方法是什么? 最佳答案 一种方法是创建FileDataModel的扩展.您需要覆盖readUserIDFromString(Stringvalue)使用某种解析器进行转换的方法。您可以使用IDMigrator的实现之一。,正如肖恩建议的那样。例如,假设您有一个已初始化的MemoryIDMigrato

hadoop - Sort 在 MapReduce 阶段用在什么地方,为什么?

我是hadoop的新手。不清楚为什么我们需要在使用hadoopmapreduce时能够按键排序?在map阶段之后,我们需要将每个唯一键对应的数据分发给一定数量的reducer。这可以在不需要排序的情况下完成,对吗? 最佳答案 它就在那里,因为排序是对键进行分组的巧妙技巧。当然,如果您的工作或算法不需要您的key的任何顺序,那么您可以更快地通过一些哈希技巧进行分组。在Hadoop本身中,多年来已经有一个JIRA归档(source)。位于Hadoop之上的其他几个发行版已经具有这些功能,例如Hanborq(他们称之为避免排序)。(sou

sorting - 如何在 hadoop 的洗牌/排序阶段进行数字排序?

数据看起来像这样,第一个字段是一个数字,3...1...2...11...我想根据第一个字段按数字而不是按字母顺序对这些行进行排序,这意味着排序后它应该如下所示,1...2...3...11...但是hadoop一直给我这个,1...11...2...3...如何改正? 最佳答案 假设您正在使用HadoopStreaming,您需要使用KeyFieldBasedComparator类。-Dmapred.output.key.comparator.class=org.apache.hadoop.mapred.lib.KeyFieldB

hadoop - Hadoop中的Sort Comparator和Group Comparator有什么区别?

Hadoop中的排序比较器和组比较器有什么区别? 最佳答案 要了解GroupComparator,请看我对这个问题的回答——WhatistheuseofgroupingcomparatorinhadoopmapreduceSortComparator:用于定义map输出键如何排序摘自《Hadoop-权威指南》一书:键的排序顺序如下:如果属性mapred.output.key.comparator.class被显式设置或通过在Job上调用setSortComparatorClass(),然后使用该类的一个实例。(在旧API等效方法是J