本文整理匯總了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);
}
}
}
示例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);
}
}
示例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));
}
}
示例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);
}
}
示例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);
}
}
示例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);
}
}
示例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);
}
}
}
示例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());
}
});
}
示例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);
}
}
示例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);
}
示例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));
}
示例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);
}
}
}
示例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);
}
}
示例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);
}