hadoop 读写 elasticsearch 初探

1、参考文档:

http://www.elasticsearch.org/guide/en/elasticsearch/hadoop/current/configuration.html

http://www.elasticsearch.org/guide/en/elasticsearch/hadoop/current/mapreduce.html#_emphasis_old_emphasis_literal_org_apache_hadoop_mapred_literal_api

 

2、Mapreduce相关配置

 

 

//以下ES配置主要是提供给ES的Format类进行读取使用

Configuration conf = new Configuration();

conf.set(ConfigurationOptions.ES_NODES, "127.0.0.1");

conf.set(ConfigurationOptions.ES_PORT, "9200");

conf.set(ConfigurationOptions.ES_INDEX_AUTO_CREATE, "yes");

//设置读取和写入的资源index/type

conf.set(ConfigurationOptions.ES_RESOURCE, "helloes/demo"); //read Target index/type

 

 

 

//假如只是想检索部分数据,可以配置ES_QUERY

//conf.set(ConfigurationOptions.ES_QUERY, "?q=me*");

 

//配置Elasticsearch为hadoop开发的format等

Job job = Job.getInstance(conf,ElasticsearchIndexMapper.class.getSimpleName());

job.setJarByClass(ElasticsearchIndexBuilder.class);

job.setSpeculativeExecution(false);//Disable speculative execution

job.setInputFormatClass(EsInputFormat.class);   

 

//假如数据输出到HDFS,指定Map的输出Value的格式。并且选择Text格式

job.setOutputFormatClass(TextOutputFormat.class);

job.setMapOutputValueClass(Text.class);

job.setMapOutputKeyClass(NullWritable.class);   

 

 

//如果选择输入到ES

job.setOutputFormatClass(EsOutputFormat.class);//输出到

job.setMapOutputValueClass(LinkedMapWritable.class);//输出的数值类 

job.setMapOutputKeyClass(Text.class);   //输出的Key值类

 

 

job.setMapperClass(ElasticsearchIndexMapper.class);

FileInputFormat.addInputPath(job, new Path("hdfs://localhost:9000/es_input"));

FileOutputFormat.setOutputPath(job, new Path("hdfs://localhost:9000/es_output"));

job.setNumReduceTasks(0);

job.waitForCompletion(true);

 

3、对应的Mapper类ElasticsearchIndexMapper

public class ElasticsearchIndexMapper extends Mapper {

@Override

protected void map(Object key, Object value, Context context)

        throws IOException, InterruptedException {

//假如我这边只是想导出数据到HDFS

 

  LinkedMapWritable doc = (LinkedMapWritable) value;   

  Text docVal = new Text();

   docVal.set(doc.toString());

  context.write(NullWritable.get(), docVal);

}

}

4、小结

hadoop-ES读写最主要的就是ESInputFormat、ESOutputFormat的参数配置(Configuration)。

另外 其它数据源操作(Mysql等)也是类似,找到对应的InputFormat,OutputFormat配置上环境参数。

posted on 2014-08-23 09:36  Ryan_Y  阅读(10069)  评论(0编辑  收藏  举报