elastic 修改map

Apache Mahout是一个“可扩展的机器学习库”,其中包括各种单节点和分布式推荐算法的实现。 在上一篇博客文章中, 我描述了如何在单个节点上实现在线推荐系统来处理数据。 如果数据太大而无法放入内存(> 100M首选项数据点)怎么办? 然后我们别无选择,只能看一下Mahout的分布式推荐器实现!

分布式推荐器基于Apache Hadoop。 这是一项需要输入用户偏好列表,计算项目共现矩阵并为每个用户输出前K个建议的工作。 有关此博客如何工作以及如何在本地运行的介绍性博客,请参见此博客文章 。

我们当然可以在自定义的Hadoop群集上运行此作业,但是仅使用预先配置的作业(如EMR)会更快(且痛苦更少)。 但是,有一个小问题。 EMR上提供的最新Hadoop版本是1.0.3,其中包含Apache Lucene 2.9.4的jar。 但是,推荐程序作业取决于Lucene 4.3.0,这将导致以下漂亮的堆栈跟踪:

2013-10-04 11:05:03,921 FATAL org.apache.hadoop.mapred.Child (main): Error running child : java.lang.NoSuchMethodError: org.apache.lucene.util.PriorityQueue.<init>(I)Vat org.apache.mahout.math.hadoop.similarity.cooccurrence.TopElementsQueue.<init>(TopElementsQueue.java:33)at org.apache.mahout.math.hadoop.similarity.cooccurrence.RowSimilarityJob$UnsymmetrifyMapper.
map(RowSimilarityJob.java:405)at org.apache.mahout.math.hadoop.similarity.cooccurrence.RowSimilarityJob$UnsymmetrifyMapper.
map(RowSimilarityJob.java:389)at org.apache.hadoop.mapreduce.Mapper.run(Mapper.java:144)at org.apache.hadoop.mapred.MapTask.runNewMapper(MapTask.java:771)at org.apache.hadoop.mapred.MapTask.run(MapTask.java:375)at org.apache.hadoop.mapred.Child$4.run(Child.java:255)at java.security.AccessController.doPrivileged(Native Method)at javax.security.auth.Subject.doAs(Subject.java:415)at org.apache.hadoop.security.UserGroupInformation.doAs(UserGroupInformation.java:1132)at org.apache.hadoop.mapred.Child.main(Child.java:249)

如何解决呢? 好吧,我们“只是”需要在EMR Hadoop安装中更新Lucene。 我们可以为此使用引导操作 。 具体步骤如下:

  1. 下载lucene-4.3.0.tgz(例如从此处 )并将其上传到S3存储桶中; 将文件公开。
  2. 将该脚本也上传到存储桶中; 称之为例如update-lucene.sh
    #!/bin/bash
    cd /home/hadoop
    wget https://s3.amazonaws.com/bucket_name/bucket_path/lucene-4.3.0.tgz
    tar -xzf lucene-4.3.0.tgz
    cd lib
    rm lucene-*.jar
    cd ..
    cd lucene-4.3.0
    find . | grep lucene- | grep jar$ | xargs -I {} cp {} ../lib

    该脚本将在Hadoop节点上运行,并将更新Lucene版本。 确保更改脚本并输入正确的存储桶名称和存储桶路径,以使其指向公共Lucene存档。

  3. mahout-core-0.8-job.jar到存储桶
  4. 最后,我们需要将输入数据上传到S3。 输出数据也将保存在S3上。
  5. 现在,我们可以开始设置EMR作业流程。 转到Amazon控制台上的EMR页面,然后开始创建新的工作流程。 我们将使用“ Amazon Distribution” Hadoop版本,并使用“ Custom JAR”作为作业类型。

  6. “ JAR位置”必须指向我们上载Mahout jar的位置,例如s3n://bucket_name/bucket_path/mahout-0.8-job.jar (请确保将其更改为指向真实的存储桶!)。 至于jar参数,我们将运行RecommenderJob并使用对数似然性:
    org.apache.mahout.cf.taste.hadoop.item.RecommenderJob
    --booleanData
    --similarityClassname SIMILARITY_LOGLIKELIHOOD
    --output s3n://bucket_name/output
    --input s3n://bucket_name/input.dat

    这也是指定S3上输入数据的位置和输出写入位置的地方。

  7. 然后,我们可以选择要使用的计算机数量。 当然,这取决于输入数据的大小以及所需的结果速度。 这里主要要更改的是“核心实例组”计数。 2是测试的合理默认值。

  8. 我们可以保持高级选项不变
  9. 现在我们进入更重要的步骤之一:设置引导程序动作。 我们需要设置两个:
    • 内存密集型配置(否则您会很快看到一个OOM)
    • 我们的自定义update-lucene操作(路径应指向S3,例如s3://bucket_name/bucket_path/update-lucene.sh

就是这样! 现在,您可以创建并运行作业流程,在几分钟/几小时/几天之后,您将在S3上等待结果。

参考: Amazon Elastic Map Reduce可以通过 JCG合作伙伴 Adam Warski的Blog(Adam Warski博客) 使用Apache Mahout计算建议 。

翻译自: https://www.javacodegeeks.com/2013/10/amazon-elastic-map-reduce-to-compute-recommendations-with-apache-mahout.html

elastic 修改map

elastic 修改map_Amazon Elastic Map Reduce使用Apache Mahout计算建议相关推荐

  1. Amazon Elastic Map Reduce使用Apache Mahout计算建议

    Apache Mahout是一个"可扩展的机器学习库",其中包含各种单节点和分布式推荐算法的实现. 在我的上一篇博客文章中, 我描述了如何在单个节点上实现在线推荐系统来处理数据. ...

  2. Hadoop Map/Reduce教程

    Hadoop Map/Reduce教程 目的     先决条件     概述     输入与输出     例子:WordCount v1.0         源代码         用法        ...

  3. Hadoop Map/Reduce的工作流

    问题描述 我们的数据分析平台是单一的Map/Reduce过程,由于半年来不断地增加需求,导致了问题已经不是那么地简单,特别是在Reduce阶段,一些大对象会常驻内存.因此越来越顶不住压力了,当前内存问 ...

  4. Elastic:运用 Elastic Maps 实时跟踪,可视化资产分布及地理围栏告警(二)

    这是继上一篇文章 "Elastic:运用 Elastic Maps 实时跟踪,可视化资产分布及地理围栏告警(一)" 的续篇.在上一篇文章中,我详细地介绍了如何从 Web 服务摄入实 ...

  5. Hadoop完全分布式搭建过程、maven和eclipse配置hadoop开发环境、配置Map/Reduce Locations、简单wordcount测试!

    Hadoop完全分布式搭建及测试 项目开始前准备工作 1.下载并安装VM workstation pro 15安装包,这里选择: VMware-workstation-full-15.1.0-1359 ...

  6. 对云计算中几种基础设施(Dynamo,Bigtable,Map/Reduce等)的朴素看法

    前言 云计算的概念近期可谓如火如荼,备受关注.我先前听到"云"这个名词时,很是觉得太过玄乎--也不知道它用在哪里,更不了解它如何实现,总有雾里看花的感觉! 好在近期工作需要的缘故, ...

  7. Hadoop学习:Map/Reduce初探与小Demo实现

    一.    概念知识介绍 Hadoop MapReduce是一个用于处理海量数据的分布式计算框架.这个框架攻克了诸如数据分布式存储.作业调度.容错.机器间通信等复杂问题,能够使没有并行 处理或者分布式 ...

  8. Python进阶:函数式编程(高阶函数,map,reduce,filter,sorted,返回函数,匿名函数,偏函数)...啊啊啊...

    函数式编程 函数是Python内建支持的一种封装,我们通过把大段代码拆成函数,通过一层一层的函数调用,就可以把复杂任务分解成简单的任务,这种分解可以称之为面向过程的程序设计.函数就是面向过程的程序设计 ...

  9. Map Reduce和流处理

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由@从流域到海域翻译,发表于腾讯云+社区 map()和reduce()是在集群式设备上用来做大规模数据处理的方法,用户定义一个特定的映射 ...

最新文章

  1. Pytorch用tensorboarX查看损失图打不开
  2. VTK:网格之TableBasedClipDataSetWithPolyData2
  3. camel 使用_使用Camel从WildFly 8向WebLogic 12发送JMS消息
  4. 【随机过程】随机过程之更新过程(2)
  5. ORA-14402: 更新分区关键字导致分区的更改
  6. Oracle 存储过程笔记.
  7. OpenSSL 用SM3算法进行hash
  8. dedecms二次开发总结 变量参数
  9. LeetCode--宝石与石头
  10. JavaScript实现Fly Bird小游戏
  11. 校友小程序定制开发 带我们回到那个学生时代
  12. 快速理解数据,数据对象,数据元素,数据项间的关系
  13. c语言中char类型转int类型
  14. Neo4j3-Neo4j基础操作(中)
  15. android listview 导航条,Android侧边导航栏+ListView基础实践
  16. mac 蓝牙搜索不到SONY WI-1000X 耳机型号
  17. IEEE帐号的创建和ORCid
  18. MariaDB源码分析——CONNECT类
  19. python乒乓球比赛规则介绍_乒乓球比赛规则常识大全
  20. 精准营销服务平台设计-基于大数据和AI的商业智能平台

热门文章

  1. 【模拟】游戏(jzoj 1614)
  2. 13、play中实现信息国际化
  3. 面试官让我讲讲Java中的锁,我笑了
  4. 漫画:如何用栈实现队列
  5. MySQL coalesce()函数
  6. jQuery中position()与offset()区别
  7. 解析HTTP协议六种请求方法,get,head,put,delete,post有什么区别
  8. jQuery操作DOM元素案例
  9. java实现人脸识别源码【含测试效果图】——ServiceImpl层(UserServiceImpl)
  10. 手把手教会你(单/多)文件上传(并修改文件默认的最大最小值)