新聞中心
雅虎財經(jīng)是互聯(lián)網(wǎng)領(lǐng)先的商業(yè)新聞和金融數(shù)據(jù)網(wǎng)站。它是雅虎的一部分,并提供有關(guān)金融新聞,市場統(tǒng)計,國際市場數(shù)據(jù)和其他任何人都可以訪問的財務(wù)資源信息。

如果您是注冊的Yahoo!用戶,那么您可以自定義Yahoo! Finance以利用其特定產(chǎn)品。Yahoo! Finance API用于從Yahoo!查詢財務(wù)數(shù)據(jù)。
此API顯示實時延遲15分鐘的數(shù)據(jù),并每1分鐘更新其數(shù)據(jù)庫,以訪問當(dāng)前股票相關(guān)信息?,F(xiàn)在讓我們看一家公司的實時情景,看看當(dāng)公司的股票價值低于100時如何提高警報。
Spout創(chuàng)建
spout的目的是獲得公司的詳細(xì)信息,并發(fā)出價格spout。您可以使用以下程序代碼創(chuàng)建spout。
編碼:YahooFinanceSpout.java
import java.util.*;
import java.io.*;
import java.math.BigDecimal;
//import yahoofinace packages
import yahoofinance.YahooFinance;
import yahoofinance.Stock;
import backtype.storm.tuple.Fields;
import backtype.storm.tuple.Values;
import backtype.storm.topology.IRichSpout;
import backtype.storm.topology.OutputFieldsDeclarer;
import backtype.storm.spout.SpoutOutputCollector;
import backtype.storm.task.TopologyContext;
public class YahooFinanceSpout implements IRichSpout {
private SpoutOutputCollector collector;
private boolean completed = false;
private TopologyContext context;
@Override
public void open(Map conf, TopologyContext context, SpoutOutputCollector collector){
this.context = context;
this.collector = collector;
}
@Override
public void nextTuple() {
try {
Stock stock = YahooFinance.get("INTC");
BigDecimal price = stock.getQuote().getPrice();
this.collector.emit(new Values("INTC", price.doubleValue()));
stock = YahooFinance.get("GOOGL");
price = stock.getQuote().getPrice();
this.collector.emit(new Values("GOOGL", price.doubleValue()));
stock = YahooFinance.get("AAPL");
price = stock.getQuote().getPrice();
this.collector.emit(new Values("AAPL", price.doubleValue()));
} catch(Exception e) {}
}
@Override
public void declareOutputFields(OutputFieldsDeclarer declarer) {
declarer.declare(new Fields("company", "price"));
}
@Override
public void close() {}
public boolean isDistributed() {
return false;
}
@Override
public void activate() {}
@Override
public void deactivate() {}
@Override
public void ack(Object msgId) {}
@Override
public void fail(Object msgId) {}
@Override
public Map getComponentConfiguration() {
return null;
}
}
Bolt創(chuàng)建
這里的的目的是當(dāng)價格低于100時處理給定公司的價格。它使用Java Map對象在股價低于100時設(shè)置截止價格限制警報為真;否則為false。完整的程序代碼如下 -
編碼:PriceCutOffBolt.java
import java.util.HashMap;
import java.util.Map;
import backtype.storm.tuple.Fields;
import backtype.storm.tuple.Values;
import backtype.storm.task.OutputCollector;
import backtype.storm.task.TopologyContext;
import backtype.storm.topology.IRichBolt;
import backtype.storm.topology.OutputFieldsDeclarer;
import backtype.storm.tuple.Tuple;
public class PriceCutOffBolt implements IRichBolt {
Map cutOffMap;
Map resultMap;
private OutputCollector collector;
@Override
public void prepare(Map conf, TopologyContext context, OutputCollector collector) {
this.cutOffMap = new HashMap ();
this.cutOffMap.put("INTC", 100);
this.cutOffMap.put("AAPL", 100);
this.cutOffMap.put("GOOGL", 100);
this.resultMap = new HashMap();
this.collector = collector;
}
@Override
public void execute(Tuple tuple) {
String company = tuple.getString(0);
Double price = tuple.getDouble(1);
if(this.cutOffMap.containsKey(company)){
Integer cutOffPrice = this.cutOffMap.get(company);
if(price < cutOffPrice) {
this.resultMap.put(company, true);
} else {
this.resultMap.put(company, false);
}
}
collector.ack(tuple);
}
@Override
public void cleanup() {
for(Map.Entry entry:resultMap.entrySet()){
System.out.println(entry.getKey()+" : " + entry.getValue());
}
}
@Override
public void declareOutputFields(OutputFieldsDeclarer declarer) {
declarer.declare(new Fields("cut_off_price"));
}
@Override
public Map getComponentConfiguration() {
return null;
}
}
提交拓?fù)?/h2>
這是YahooFinanceSpout.java和PriceCutOffBolt.java連接在一起并生成拓?fù)涞闹饕獞?yīng)用程序。以下程序代碼顯示了如何提交拓?fù)洹?/p>
編碼:YahooFinanceStorm.java
import backtype.storm.tuple.Fields;
import backtype.storm.tuple.Values;
import backtype.storm.Config;
import backtype.storm.LocalCluster;
import backtype.storm.topology.TopologyBuilder;
public class YahooFinanceStorm {
public static void main(String[] args) throws Exception{
Config config = new Config();
config.setDebug(true);
TopologyBuilder builder = new TopologyBuilder();
builder.setSpout("yahoo-finance-spout", new YahooFinanceSpout());
builder.setBolt("price-cutoff-bolt", new PriceCutOffBolt())
.fieldsGrouping("yahoo-finance-spout", new Fields("company"));
LocalCluster cluster = new LocalCluster();
cluster.submitTopology("YahooFinanceStorm", config, builder.createTopology());
Thread.sleep(10000);
cluster.shutdown();
}
}
構(gòu)建和運(yùn)行應(yīng)用程序
完整的應(yīng)用程序有三個Java代碼。他們?nèi)缦?-
- YahooFinanceSpout.java
- PriceCutOffBolt.java
- YahooFinanceStorm.java
應(yīng)用程序可以使用以下命令構(gòu)建 -
javac -cp “/path/to/storm/apache-storm-0.9.5/lib/*”:”/path/to/yahoofinance/lib/*” *.java
應(yīng)用程序可以使用以下命令運(yùn)行 -
javac -cp “/path/to/storm/apache-storm-0.9.5/lib/*”:”/path/to/yahoofinance/lib/*”:. YahooFinanceStorm
輸出
輸出將類似于以下內(nèi)容 -
GOOGL : false AAPL : false INTC : true
本文題目:創(chuàng)新互聯(lián)ApacheStorm教程:ApacheStorm在雅虎財經(jīng)上的應(yīng)用
分享路徑:http://www.5511xx.com/article/coggcgc.html


咨詢
建站咨詢
