Flume NG

Mongodb sink

import java.io.IOException;
import java.net.UnknownHostException;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.Map;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.cloudera.flume.conf.Context;
import com.cloudera.flume.conf.SinkFactory.SinkBuilder;
import com.cloudera.flume.core.Event;
import com.cloudera.flume.core.EventSink;
import com.cloudera.util.Pair;
import com.google.common.base.Preconditions;
import com.mongodb.BasicDBObject;
import com.mongodb.DB;
import com.mongodb.DBCollection;
import com.mongodb.Mongo;
import com.mongodb.MongoException;

public class MongoDBSink extends EventSink.Base {
  static final Logger LOG = LoggerFactory.getLogger(MongoDBSink.class);
  
  private String serverName;
  private int serverPort;
  private String dbName;
  private String collName;
  private Mongo mongo;
  private DB db;
  private DBCollection collection;
  
  public MongoDBSink(String server, String port, String dbName, String collName) {
    this.serverName = server;
    this.serverPort = Integer.parseInt(port);
    this.dbName = dbName;
    this.collName = collName;
  }

  @Override
  public synchronized void append(Event e) throws IOException {
    BasicDBObject entry = new BasicDBObject();
    entry.put("timestamp", new Date(e.getTimestamp()));
    entry.put("hostname", e.getHost());
    entry.put("priority", e.getPriority().name());
    entry.put("message", new String(e.getBody()));
    Map<String, byte[]> metadata = e.getAttrs();
    if (!metadata.isEmpty()) {
      BasicDBObject metadataEntry = new BasicDBObject();
      for (String key: metadata.keySet()) {
        metadataEntry.put(key, new String(metadata.get(key)));
      }
      entry.put("metadata", metadataEntry);
    }
    collection.insert(entry);
  }

  @Override
  public void close() throws IOException {
    mongo.close();
  }

  @Override
  public void open() throws IOException {
    try {
      mongo = new Mongo(serverName, serverPort);
      db = mongo.getDB(dbName);
      collection = db.getCollection(collName);
    } catch (UnknownHostException e) {
      LOG.error("Could not find specified server.", e);
    } catch (MongoException e) {
      LOG.error("Error connecting to server.", e);
    }
  }
  
  public static SinkBuilder builder() {
    return new SinkBuilder() {
      // construct a new parameterized sink
      @Override
      public EventSink build(Context context, String... argv) {
        Preconditions.checkArgument(argv.length == 4,
            "usage: mongoDBSink(\"server\",\"port\",\"db\",\"collection\")");

        return new MongoDBSink(argv[0], argv[1], argv[2], argv[3]);
      }
    };
  }

  /**
   * 将sink注入SourceFactory
   * 别名mongoDBSink
   */
  public static List<Pair<String, SinkBuilder>> getSinkBuilders() {
    List<Pair<String, SinkBuilder>> builders =
      new ArrayList<Pair<String, SinkBuilder>>();
    builders.add(new Pair<String, SinkBuilder>("mongoDBSink", builder()));
    return builders;
  }
}

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值