spark mongo java_让Spark,Java和MongoDB协同工作

类似于

my question here,但这次它是Java,而不是Python,导致我出现问题.

我已经按照建议的步骤(据我所知)here,但由于我使用的是hadoop-2.6.1,我认为我应该使用旧的API,而不是示例中提到的新API.

我正在研究Ubuntu和我拥有的各种组件版本

> Spark spark-1.5.1-bin-hadoop2.6

> Hadoop hadoop-2.6.1

> Mongo 3.0.8

> Maven包含Mongo-Hadoop连接器罐

> Java 1.8.0_66

> Maven 3.0.5

我的Java程序是基本的

import org.apache.spark.api.java.*;

import org.apache.spark.SparkConf;

import org.apache.spark.api.java.function.Function;

import com.mongodb.hadoop.MongoInputFormat;

import org.apache.hadoop.conf.Configuration;

import org.bson.BSONObject;

public class SimpleApp {

public static void main(String[] args) {

Configuration mongodbConfig = new Configuration();

mongodbConfig.set("mongo.job.input.format", "com.mongodb.hadoop.MongoInputFormat");

mongodbConfig.set("mongo.input.uri", "mongodb://localhost:27017/db.collection");

SparkConf conf = new SparkConf().setAppName("Simple Application");

JavaSparkContext sc = new JavaSparkContext(conf);

JavaPairRDD documents = sc.newAPIHadoopRDD(

mongodbConfig, // Configuration

MongoInputFormat.class, // InputFormat: read from a live cluster.

Object.class, // Key class

BSONObject.class // Value class

);

}

}

使用Maven(mvn包)和以下pom文件构建正常

edu.berkeley

simple-project

4.0.0

Simple Project

jar

1.0

org.apache.spark

spark-core_2.10

1.5.1

org.mongodb

mongo-java-driver

3.2.0

org.mongodb.mongo-hadoop

mongo-hadoop-core

1.4.2

org.apache.maven.plugins

maven-compiler-plugin

1.8

1.8

然后我提交罐子

/usr/local/share/spark-1.5.1-bin-hadoop2.6/bin/spark-submit --class "SimpleApp" --master local[4] target/simple-project-1.0.jar

并得到以下错误

Exception in thread "main" java.lang.NoClassDefFoundError: com/mongodb/hadoop/MongoInputFormat

at SimpleApp.main(SimpleApp.java:18)

注意

我在12月18日编辑了这个问题,因为它变得过于混乱和冗长.以前的评论可能看起来无关紧要然而,问题的背景是相同的.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值