當前位置: 首頁>>代碼示例>>Java>>正文


Java Tuple.getValueByField方法代碼示例

本文整理匯總了Java中org.apache.storm.tuple.Tuple.getValueByField方法的典型用法代碼示例。如果您正苦於以下問題:Java Tuple.getValueByField方法的具體用法?Java Tuple.getValueByField怎麽用?Java Tuple.getValueByField使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.apache.storm.tuple.Tuple的用法示例。


在下文中一共展示了Tuple.getValueByField方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: reloadBolt

import org.apache.storm.tuple.Tuple; //導入方法依賴的package包/類
@Override
public void reloadBolt(Tuple tuple) {
    String msg = null;
    try {
        PropertiesHolder.reload();
        ThreadLocalCache.reload();
        Command.initialize();
        msg = "dispatcher bolt reload successful!";
        logger.info("Dispatcher bolt was reloaded at:{}", System.currentTimeMillis());
    } catch (Exception e) {
        msg = e.getMessage();
        throw new RuntimeException(e);
    } finally {
        if (tuple != null) {
            EmitData data = (EmitData) tuple.getValueByField(Constants.EmitFields.DATA);
            ControlMessage message = data.get(EmitData.MESSAGE);
            CtlMessageResult result = new CtlMessageResult("dispatcher-bolt", msg);
            result.setOriginalMessage(message);
            CtlMessageResultSender sender = new CtlMessageResultSender(message.getType(), zkConnect);
            sender.send("dispatcher-bolt-" + context.getThisTaskId(), result, false, true);
        }
    }
}
 
開發者ID:BriData,項目名稱:DBus,代碼行數:24,代碼來源:DispatcherBolt.java

示例2: execute

import org.apache.storm.tuple.Tuple; //導入方法依賴的package包/類
@Override
public void execute(Tuple input) {
    if (TupleUtils.isTick(input)) {
        collector.ack(input);
        return;
    }

    try {
        Command cmd = (Command) input.getValueByField(EmitFields.COMMAND);
        BoltCommandHandler handler = handlerManager.getHandler(cmd);
        handler.handle(input);
        this.collector.ack(input);
    } catch (Exception e) {
        logger.error("Process data error", e);
        this.collector.reportError(e);
        this.collector.fail(input);
    }

}
 
開發者ID:BriData,項目名稱:DBus,代碼行數:20,代碼來源:WrapperBolt.java

示例3: handle

import org.apache.storm.tuple.Tuple; //導入方法依賴的package包/類
@Override
public void handle(Tuple tuple) {
    EmitData data = (EmitData) tuple.getValueByField(Constants.EmitFields.DATA);
    List<PairWrapper<String, Object>> wrapperList = data.get(EmitData.MESSAGE);
    DataTable table = data.get(EmitData.DATA_TABLE);
    MetaVersion ver = data.get(EmitData.VERSION);
    for (PairWrapper<String, Object> wrapper : wrapperList) {
        Object packet = wrapper.getPairValue("PACKET");
        JSONObject json = JSON.parseObject(packet.toString());
        String dbSchema = wrapper.getPairValue("SCHEMA_NAME").toString();
        String tableName = wrapper.getPairValue("TABLE_NAME").toString();

        String pos = wrapper.getProperties(Constants.MessageBodyKey.POS).toString();

        // oracle 數據格式:2017-03-24 14:28:00.995660,mysql格式:2017-03-24 14:28:00.995
        // 暫時不要統一
        //String opts = wrapper.getProperties(Constants.MessageBodyKey.OP_TS).toString().substring(0, 23);
        String opts = wrapper.getProperties(Constants.MessageBodyKey.OP_TS).toString();
        long time = json.getLong("time");
        long txTime = json.getLong("txTime");

        String targetTopic = listener.getTargetTopic(dbSchema, tableName);
        // 發送Heartbeat
        listener.sendHeartbeat(message(table, ver, pos, opts), targetTopic, buildKey(time + "|" + txTime, table, ver));
    }
}
 
開發者ID:BriData,項目名稱:DBus,代碼行數:27,代碼來源:HeartbeatDefaultHandler.java

示例4: handle

import org.apache.storm.tuple.Tuple; //導入方法依賴的package包/類
@Override
public void handle(Tuple tuple) {
	try{
		EmitData emitData = (EmitData) tuple.getValueByField(Constants.EmitFields.DATA);
		List<MessageEntry> datas = emitData.get(EmitData.MESSAGE);
		long offset = emitData.get(EmitData.OFFSET);

        logger.debug("[BEGIN] receive data,offset:{}", offset);
        
        for(MessageEntry msgEntry : datas){
        	long pos = Long.parseLong(msgEntry.getEntryHeader().getPos());
        	syncMeta(msgEntry, pos, offset, tuple);
        }
	} catch (Exception e){
		logger.error("Error when processing data", e);
        throw new RuntimeException(e);
	}
}
 
開發者ID:BriData,項目名稱:DBus,代碼行數:19,代碼來源:MaMetaSyncEventHandler.java

示例5: execute

import org.apache.storm.tuple.Tuple; //導入方法依賴的package包/類
@Override
public void execute(Tuple input) {
    StatsComponentType componentId = StatsComponentType.valueOf(input.getSourceComponent());
    InfoMessage message = (InfoMessage) input.getValueByField(MESSAGE_FIELD);

    if (!Destination.WFM_STATS.equals(message.getDestination())) {
        collector.ack(input);
        return;
    }

    LOGGER.debug("Flow stats message: {}={}, component={}, stream={}",
            CORRELATION_ID, message.getCorrelationId(), componentId, StatsStreamType.valueOf(input.getSourceStreamId()));
    FlowStatsData data = (FlowStatsData) message.getData();
    long timestamp = message.getTimestamp();
    String switchId = data.getSwitchId().replaceAll(":", "");

    try {
        for (FlowStatsReply reply : data.getStats()) {
            for (FlowStatsEntry entry : reply.getEntries()) {
                emit(entry, timestamp, switchId);
            }
        }
    } finally {
        collector.ack(input);
    }
}
 
開發者ID:telstra,項目名稱:open-kilda,代碼行數:27,代碼來源:FlowMetricGenBolt.java

示例6: execute

import org.apache.storm.tuple.Tuple; //導入方法依賴的package包/類
@Override
public void execute(Tuple input) {
    if (TupleUtils.isTick(input)) {
        collector.ack(input);
        return;
    }
    try {
        Command cmd = (Command) input.getValueByField(EmitFields.COMMAND);
        BoltCommandHandler handler = handlerManager.getHandler(cmd);
        handler.handle(input);
        this.collector.ack(input);
    } catch (Exception e) {
        this.collector.fail(input);
        this.collector.reportError(e);
        logger.error("Process Error!", e);
    }

}
 
開發者ID:BriData,項目名稱:DBus,代碼行數:19,代碼來源:DispatcherBolt.java

示例7: reloadBolt

import org.apache.storm.tuple.Tuple; //導入方法依賴的package包/類
@Override
public void reloadBolt(Tuple tuple) {
    String msg = null;
    try {
        PropertiesHolder.reload();
        Command.initialize();
        ThreadLocalCache.reload();
        msg = "appender bolt reload successful!";
        logger.info("Appender bolt was reloaded at:{}", System.currentTimeMillis());
    } catch (Exception e) {
        msg = e.getMessage();
        throw new RuntimeException(e);
    } finally {
        if (tuple != null) {
            EmitData data = (EmitData) tuple.getValueByField(Constants.EmitFields.DATA);
            ControlMessage message = data.get(EmitData.MESSAGE);
            CtlMessageResult result = new CtlMessageResult("appender-bolt", msg);
            result.setOriginalMessage(message);
            CtlMessageResultSender sender = new CtlMessageResultSender(message.getType(), zkConnect);
            sender.send("appender-bolt-" + context.getThisTaskId(), result, false, true);
        }
    }
}
 
開發者ID:BriData,項目名稱:DBus,代碼行數:24,代碼來源:DbusAppenderBolt.java

示例8: execute

import org.apache.storm.tuple.Tuple; //導入方法依賴的package包/類
public void execute(Tuple input, BasicOutputCollector arg1) {
	PacketDetailDTO packetDetailDTO = (PacketDetailDTO) input.getValueByField("usagestream");
	session.execute("INSERT INTO packet_usage (phone_number, bin, bout, total_bytes) VALUES ("
			+ packetDetailDTO.getPhoneNumber()
			+ ", "
			+ packetDetailDTO.getBin()
			+ ", "
			+ packetDetailDTO.getBout()
			+ ", " + packetDetailDTO.getTotalBytes() + ")");
}
 
開發者ID:PacktPublishing,項目名稱:Practical-Real-time-Processing-and-Analytics,代碼行數:11,代碼來源:UsageCassandraBolt.java

示例9: writeData

import org.apache.storm.tuple.Tuple; //導入方法依賴的package包/類
@Override
public void writeData(String dbSchema, String table, DbusMessage dbusMessage, Tuple input) {
    EmitData data = (EmitData) input.getValueByField(Constants.EmitFields.DATA);
    List<String> topics = topicProvider.provideTopics(dbSchema, table);
    if (topics == null || topics.isEmpty()) {
        logger.error("Can't find a topic to write the message!");
        this.collector.ack(input);
        return;
    }

    String message = dbusMessage.toString();
    ProducerRecord<String, String> record = new ProducerRecord<>(topics.get(0), buildKey(dbusMessage), message);
    reporter.report(message.getBytes().length, dbusMessage.getPayload().size());
    Object offsetObj = data.get(EmitData.OFFSET);
    String offset = offsetObj != null ? offsetObj.toString() : "0";
    producer.send(record, (metadata, exception) -> {
        if (exception != null) {
            synchronized (this.collector) {
                this.collector.fail(input);
            }
            logger.error("Write data to kafka error, original data:[schema:{}, table:{}, offset:{}]!", dbSchema, table, offset, exception);
        } else {
            synchronized (this.collector) {
                this.collector.ack(input);
            }
            logger.info("kafka-message,original-offset:{}, key:{}", offset, record.key());
        }
    });
}
 
開發者ID:BriData,項目名稱:DBus,代碼行數:30,代碼來源:DbusKafkaWriterBolt.java

示例10: handle

import org.apache.storm.tuple.Tuple; //導入方法依賴的package包/類
@Override
public void handle(Tuple tuple) {
    EmitData data = (EmitData) tuple.getValueByField(Constants.EmitFields.DATA);
    String groupId = tuple.getStringByField(Constants.EmitFields.GROUP_FIELD);
    this.emitHeartbeat(listener.getOutputCollector(), tuple, groupId, data, Command.HEART_BEAT);
    if(logger.isDebugEnabled()) {
        Object offset = data.get(EmitData.OFFSET);
        logger.debug("[heartbeat] {} {} offset:{}", listener.getClass().getSimpleName(), groupId, offset == null ? -1 : offset);
    }
}
 
開發者ID:BriData,項目名稱:DBus,代碼行數:11,代碼來源:CommonHeartbeatHandler.java

示例11: execute

import org.apache.storm.tuple.Tuple; //導入方法依賴的package包/類
@Override
   public void execute(Tuple tuple) {

       String url = tuple.getStringByField("url");
       Metadata metadata = (Metadata) tuple.getValueByField("metadata");

System.out.println("DummyIndexer %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% set to FETCHED url: " + url);

       _collector.emit(
               com.digitalpebble.stormcrawler.Constants.StatusStreamName,
               tuple, new Values(url, metadata, Status.FETCHED));
       _collector.ack(tuple);
   }
 
開發者ID:eorliac,項目名稱:patent-crawler,代碼行數:14,代碼來源:DummyIndexer.java

示例12: handle

import org.apache.storm.tuple.Tuple; //導入方法依賴的package包/類
@Override
public void handle(Tuple tuple) {
    EmitData emitData = (EmitData) tuple.getValueByField(Constants.EmitFields.DATA);

    Command cmd = (Command)tuple.getValueByField(Constants.EmitFields.COMMAND);
    String dbschema = emitData.get(EmitData.DB_SCHEMA);
    String table = emitData.get(EmitData.DATA_TABLE);
    this.emit(listener.getOutputCollector(), tuple, groupField(dbschema, table), emitData, cmd);
    logger.info("Full pull request[{}]", groupField(dbschema, table));
}
 
開發者ID:BriData,項目名稱:DBus,代碼行數:11,代碼來源:DispatcherInitialLoadHandler.java

示例13: reloadBolt

import org.apache.storm.tuple.Tuple; //導入方法依賴的package包/類
@Override
public void reloadBolt(Tuple tuple) {
    String msg = null;
    try {
        PropertiesHolder.reload();
        ThreadLocalCache.reload();
        if (producer != null) {
            producer.close();
        }

        producer = createProducer();
        msg = "kafka write bolt reload successful!";
        logger.info("Kafka writer bolt was reloaded at:{}", System.currentTimeMillis());
    } catch (Exception e) {
        msg = e.getMessage();
        throw new RuntimeException(e);
    } finally {
        if (tuple != null) {
            EmitData data = (EmitData) tuple.getValueByField(Constants.EmitFields.DATA);
            ControlMessage message = data.get(EmitData.MESSAGE);
            CtlMessageResult result = new CtlMessageResult("kafka-write-bolt", msg);
            result.setOriginalMessage(message);
            CtlMessageResultSender sender = new CtlMessageResultSender(message.getType(), zkconnect);
            sender.send("kafka-write-bolt-" + context.getThisTaskId(), result, false, true);
        }
    }
}
 
開發者ID:BriData,項目名稱:DBus,代碼行數:28,代碼來源:DbusKafkaWriterBolt.java

示例14: execute

import org.apache.storm.tuple.Tuple; //導入方法依賴的package包/類
public void execute(Tuple input) {
    if (TupleUtils.isTick(input)) {
        collector.ack(input);
        return;
    }
    try {
        Command cmd = (Command) input.getValueByField(Constants.EmitFields.COMMAND);
        BoltCommandHandler handler = handlerManager.getHandler(cmd);
        handler.handle(input);
        this.collector.ack(input);
    } catch (Exception e) {
        this.collector.ack(input);
        logger.error("Heartbeat error, ignore this error", e);
    }
}
 
開發者ID:BriData,項目名稱:DBus,代碼行數:16,代碼來源:DbusHeartBeatBolt.java

示例15: handle

import org.apache.storm.tuple.Tuple; //導入方法依賴的package包/類
@Override
public void handle(Tuple tuple) {
    EmitData emitData = (EmitData) tuple.getValueByField(Constants.EmitFields.DATA);
    Command cmd = (Command)tuple.getValueByField(Constants.EmitFields.COMMAND);

    listener.reloadBolt(tuple);
    this.emitToAll(listener.getOutputCollector(), tuple, emitData, cmd);
}
 
開發者ID:BriData,項目名稱:DBus,代碼行數:9,代碼來源:CommonReloadHandler.java


注:本文中的org.apache.storm.tuple.Tuple.getValueByField方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。