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


Java BasicOutputCollector.emit方法代碼示例

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


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

示例1: execute

import backtype.storm.topology.BasicOutputCollector; //導入方法依賴的package包/類
@Override
public void execute(Tuple tuple, BasicOutputCollector collector) {
	SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd");//設置日期格式
	String nowData = df.format(new Date()); // new Date()為獲取當前係統時間,檢測是否為最新數據

	String data = tuple.getString(0);
	//訂單號		用戶id	     原金額	                      優惠價	          標示字段		下單時間
	//id		memberid  	totalprice					preprice		sendpay		createdate
	if(data!=null && data.length()>0) {
		String[] values = data.split("\t");
		if(values.length==6) {
			String id = values[0];
			String memberid = values[1];
			String totalprice = values[2];
			String preprice = values[3];
			String sendpay = values[4];
			String createdate = values[5];
			
			if(StringUtils.isNotEmpty(id)&&StringUtils.isNotEmpty(memberid)&&StringUtils.isNotEmpty(totalprice)) {
				if(DateUtils.isValidDate(createdate, nowData)) {
					collector.emit(new Values(id,memberid,totalprice,preprice,sendpay,createdate));
				}
			}
		}
	}
}
 
開發者ID:realxujiang,項目名稱:storm-kafka-examples,代碼行數:27,代碼來源:CheckOrderBolt.java

示例2: execute

import backtype.storm.topology.BasicOutputCollector; //導入方法依賴的package包/類
public void execute(Tuple input, BasicOutputCollector collector) {


        try {
            String url = input.getString(0);
            if(url.length() > 10) {
                collector.emit(new Values(url));
                System.out.println(url);
            }else{
                System.err.println("======>loop back====>"+url);
            }
        }catch (Exception ex){
            logger.error("Generate Url error:"+ex);
            ex.printStackTrace();
        }
    }
 
開發者ID:cutoutsy,項目名稱:miner,代碼行數:17,代碼來源:GenerateUrlBolt.java

示例3: execute

import backtype.storm.topology.BasicOutputCollector; //導入方法依賴的package包/類
public void execute(Tuple input, BasicOutputCollector collector) {
    LOGGER.debug("Calculating positive score");

    Long id     = input.getLong(input.fieldIndex("tweet_id"));
    String text = input.getString(input.fieldIndex("tweet_text"));

    Set<String> posWords = PositiveWords.getWords();
    String[] words = text.split(" ");

    int numWords = words.length;
    int numPosWords = 0;

    for (String word : words) {
        if (posWords.contains(word))
            numPosWords++;
    }

    collector.emit(new Values(id, (float) numPosWords / numWords, text));
}
 
開發者ID:mayconbordin,項目名稱:erad2016-streamprocessing,代碼行數:20,代碼來源:PositiveSentimentBolt.java

示例4: execute

import backtype.storm.topology.BasicOutputCollector; //導入方法依賴的package包/類
public void execute(Tuple input, BasicOutputCollector collector) {
    LOGGER.debug("filttering incoming tweets");
    String json = input.getString(0);

    try {
        JsonNode root = mapper.readValue(json, JsonNode.class);

        long id;
        String text;

        if (root.get("lang") != null && "en".equals(root.get("lang").textValue())) {
            if (root.get("id") != null && root.get("text") != null) {
                id   = root.get("id").longValue();
                text = root.get("text").textValue();
                collector.emit(new Values(id, text));
            } else {
                LOGGER.debug("tweet id and/ or text was null");
            }
        } else {
            LOGGER.debug("Ignoring non-english tweet");
        }
    } catch (IOException ex) {
        LOGGER.error("IO error while filtering tweets", ex);
        LOGGER.trace(null, ex);
    }
}
 
開發者ID:mayconbordin,項目名稱:erad2016-streamprocessing,代碼行數:27,代碼來源:TwitterFilterBolt.java

示例5: execute

import backtype.storm.topology.BasicOutputCollector; //導入方法依賴的package包/類
public void execute(Tuple input, BasicOutputCollector collector) {
    LOGGER.debug("Calculating negitive score");

    Long id     = input.getLong(input.fieldIndex("tweet_id"));
    String text = input.getString(input.fieldIndex("tweet_text"));

    Set<String> negWords = NegativeWords.getWords();
    String[] words = text.split(" ");

    int numWords = words.length;
    int numNegWords = 0;
    for (String word : words) {
        if (negWords.contains(word))
            numNegWords++;
    }

    collector.emit(new Values(id, (float) numNegWords / numWords, text));
}
 
開發者ID:mayconbordin,項目名稱:erad2016-streamprocessing,代碼行數:19,代碼來源:NegativeSentimentBolt.java

示例6: execute

import backtype.storm.topology.BasicOutputCollector; //導入方法依賴的package包/類
@Override
public void execute(Tuple tuple, BasicOutputCollector collector) {
  //Get the sentence content from the tuple
  String sentence = tuple.getString(0);
  //An iterator to get each word
  BreakIterator boundary=BreakIterator.getWordInstance();
  //Give the iterator the sentence
  boundary.setText(sentence);
  //Find the beginning first word
  int start=boundary.first();
  //Iterate over each word and emit it to the output stream
  for (int end=boundary.next(); end != BreakIterator.DONE; start=end, end=boundary.next()) {
    //get the word
    String word=sentence.substring(start,end);
    //If a word is whitespace characters, replace it with empty
    word=word.replaceAll("\\s+","");
    //if it's an actual word, emit it
    if (!word.equals("")) {
      collector.emit(new Values(word));
    }
  }
}
 
開發者ID:mbad0la,項目名稱:Get-ENVS,代碼行數:23,代碼來源:SplitSentence.java

示例7: execute

import backtype.storm.topology.BasicOutputCollector; //導入方法依賴的package包/類
@Override
public void execute(Tuple tuple, BasicOutputCollector collector) {
    //Get the word contents from the tuple
    String word = tuple.getString(0);
    //Have we counted any already?
    Integer count = counts.get(word);
    if (count == null)
        count = 0;
    //Increment the count and store it
    count++;
    counts.put(word, count);
    //Emit the word and the current count
    //collector.emit(new Values(IGNITE_FIELD, count));
    TreeMap<String, Integer> words = new TreeMap<>();
    words.put(word,count);

    collector.emit(new Values(words));
    //Log information
    logger.info("Emitting a count of " + count + " for word " + word);
}
 
開發者ID:srecon,項目名稱:ignite-book-code-samples,代碼行數:21,代碼來源:WordCount.java

示例8: execute

import backtype.storm.topology.BasicOutputCollector; //導入方法依賴的package包/類
@Override
public void execute(Tuple tuple, BasicOutputCollector collector) {
    //Get the sentence content from the tuple
    String sentence = tuple.getString(0);
    //An iterator to get each word
    BreakIterator boundary=BreakIterator.getWordInstance();
    //Give the iterator the sentence
    boundary.setText(sentence);
    //Find the beginning first word
    int start=boundary.first();
    //Iterate over each word and emit it to the output stream
    for (int end = boundary.next(); end != BreakIterator.DONE; start=end, end=boundary.next()) {
        //get the word
        String word=sentence.substring(start,end);
        //If a word is whitespace characters, replace it with empty
        word=word.replaceAll("\\s+","");
        //if it's an actual word, emit it
        if (!word.equals("")) {
            collector.emit(new Values(word));
        }
    }
}
 
開發者ID:srecon,項目名稱:ignite-book-code-samples,代碼行數:23,代碼來源:SplitSentence.java

示例9: execute

import backtype.storm.topology.BasicOutputCollector; //導入方法依賴的package包/類
@Override
public void execute(Tuple tuple, BasicOutputCollector basicOutputCollector) {
    String line = (String)tuple.getValue(0);
    if(!line.isEmpty()){
        String[] elements = line.split(",");
        // we are interested in speed and the car registration number
        int speed = Integer.valueOf((elements[1]).trim());
        String car = elements[0];
        if(speed > SPEED_THRESHOLD){
            TreeMap<String, Integer> carValue = new TreeMap<String, Integer>();
            carValue.put(car, speed);
            basicOutputCollector.emit(new Values(carValue));
            LOGGER.info("Speed violation found:"+ car + " speed:" + speed);
        }
    }
}
 
開發者ID:srecon,項目名稱:ignite-book-code-samples,代碼行數:17,代碼來源:SpeedLimitBolt.java

示例10: execute

import backtype.storm.topology.BasicOutputCollector; //導入方法依賴的package包/類
@Override
public void execute(Tuple tuple, BasicOutputCollector collector) {
	TransactionAttempt attempt = (TransactionAttempt) tuple.getValue(0);
	int curr = tuple.getInteger(2);
	Integer prev = tuple.getInteger(3);

	int currBucket = curr / BUCKET_SIZE;
	Integer prevBucket = null;
	if (prev != null) {
		prevBucket = prev / BUCKET_SIZE;
	}

	if (prevBucket == null) {
		collector.emit(new Values(attempt, currBucket, 1));
	} else if (currBucket != prevBucket) {
		collector.emit(new Values(attempt, currBucket, 1));
		collector.emit(new Values(attempt, prevBucket, -1));
	}
}
 
開發者ID:songtk,項目名稱:learn_jstorm,代碼行數:20,代碼來源:TransactionalWordsTest.java

示例11: execute

import backtype.storm.topology.BasicOutputCollector; //導入方法依賴的package包/類
@Override
public void execute(Tuple tuple, BasicOutputCollector outputCollector) {
    try {
        Stock stock = (Stock) tuple.getValueByField(FieldNames.STOCK_FIELD);
        Values values = new Values(
                                  stock.getDate(),
                                  stock.getOpen(),
                                  stock.getHigh(),
                                  stock.getLow(),
                                  stock.getClose(),
                                  stock.getVolume(),
                                  stock.getAdjClose(),
                                  stock.getName());
        outputCollector.emit(values);
    } catch (Exception ex) {
        LOG.error(ex.toString(), ex);
        throw new FailedException(ex.toString());
    }
}
 
開發者ID:hkropp,項目名稱:storm-hive-streaming-example,代碼行數:20,代碼來源:FieldEmitBolt.java

示例12: execute

import backtype.storm.topology.BasicOutputCollector; //導入方法依賴的package包/類
@Override
public void execute(Tuple tuple, BasicOutputCollector collector) {
    tpsCounter.count();
    
    Long tupleId = tuple.getLong(0);
    Object obj = tuple.getValue(1);
    
    if (obj instanceof TradeCustomer) {
    
   	    TradeCustomer tradeCustomer = (TradeCustomer)obj;
   	    
   	    Pair trade = tradeCustomer.getTrade();
   	    Pair customer = tradeCustomer.getCustomer();
           
           collector.emit(SequenceTopologyDef.TRADE_STREAM_ID, 
                   new Values(tupleId, trade));
           
           collector.emit(SequenceTopologyDef.CUSTOMER_STREAM_ID, 
                   new Values(tupleId, customer));
    }else if (obj != null){
        LOG.info("Unknow type " + obj.getClass().getName());
    }else {
        LOG.info("Nullpointer " );
    }
	
}
 
開發者ID:zhangjunfang,項目名稱:jstorm-0.9.6.3-,代碼行數:27,代碼來源:SplitRecord.java

示例13: execute

import backtype.storm.topology.BasicOutputCollector; //導入方法依賴的package包/類
@Override
public void execute(Tuple input, BasicOutputCollector collector) {
	String valueByField = input.getString(0);
	System.out.println("field value "+ valueByField);
	String[] split = valueByField.split(",");
	PacketDetailDTO tdrPacketDetailDTO = new PacketDetailDTO();
	tdrPacketDetailDTO.setPhoneNumber(Long.parseLong(split[0]));
	tdrPacketDetailDTO.setBin(Integer.parseInt(split[1]));
	tdrPacketDetailDTO.setBout(Integer.parseInt(split[2]));
	tdrPacketDetailDTO.setTimestamp(Long.parseLong(split[3]));

	collector.emit("tdrstream", new Values(tdrPacketDetailDTO));
}
 
開發者ID:PacktPublishing,項目名稱:Practical-Real-time-Processing-and-Analytics,代碼行數:14,代碼來源:ParserBolt.java

示例14: execute

import backtype.storm.topology.BasicOutputCollector; //導入方法依賴的package包/類
public void execute(Tuple input, BasicOutputCollector collector) {
    total = total.add(new BigInteger(input.getValues().get(1).toString()));
    collector.emit(tuple(total.toString()));
    //prints the total with low probability.
    if(RANDOM.nextInt(1000) > 995) {
        LOG.info("Running total = " + total);
    }
}
 
開發者ID:mengzhiyi,項目名稱:storm-hbase-1.0.x,代碼行數:9,代碼來源:TotalWordCounter.java

示例15: execute

import backtype.storm.topology.BasicOutputCollector; //導入方法依賴的package包/類
@Override
public void execute(Tuple tuple, BasicOutputCollector collector) {
	List<Object> data = tuple.getValues();

	String id = (String) data.get(0);
	String memberid = (String) data.get(1);
	String totalprice = (String) data.get(2);
	String preprice = (String) data.get(3);
	String sendpay = (String) data.get(4);
	String createdate = (String) data.get(5);
	collector.emit(new Values(id,memberid,totalprice,preprice,sendpay,createdate));
	logger.info("+++++++++++++++++++++++++++++++++Valid+++++++++++++++++++++++++++++++++");
	logger.info("msg = "+data+" [email protected]@[email protected]@[email protected] = "+(counter++));
	logger.info("+++++++++++++++++++++++++++++++++Valid+++++++++++++++++++++++++++++++++");
}
 
開發者ID:realxujiang,項目名稱:storm-kafka-examples,代碼行數:16,代碼來源:CounterBolt.java


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