storm代码练习-bolt

本文介绍了一个基于Apache Storm的实时数据处理Bolt实现案例。该Bolt通过解析输入元组中的日志字段,提取并打印出sesion_id信息,同时记录处理的行数。此外,还演示了如何使用collector进行消息确认及错误处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

后续会不断更新
package lesson;

import java.util.Map;

import org.apache.storm.task.OutputCollector;
import org.apache.storm.task.TopologyContext;
import org.apache.storm.topology.IRichBolt;
import org.apache.storm.topology.OutputFieldsDeclarer;
import org.apache.storm.tuple.Fields;
import org.apache.storm.tuple.Tuple;

public class MyBolt implements IRichBolt {
	OutputCollector collector = null;
	@Override
	public void cleanup() {
		// TODO 自动生成的方法存根

	}
	int num = 0;
	String valueString = null;
	@Override
	public void execute(Tuple input) {
		// TODO 自动生成的方法存根
//		input.getValueByField("log");
//		接受第一列为0,第二列为1,以此类推,当然也可以用名称来接收
//		input.getValue(0);
		try {
			valueString = input.getStringByField("log");
			if(valueString != null) 
			{
				num ++;
				System.out.println("lines :"+num+" sesion_id:"+valueString.split("\t")[1]);
			}
			collector.ack(input);
			Thread.sleep(3000);

		} catch (Exception e) {
			// TODO 自动生成的 catch 块
			collector.fail(input);
			//失败了之后,spout端就会重新发射
			e.printStackTrace();
		}
	} 

	@Override
	public void prepare(Map arg0, TopologyContext arg1, OutputCollector collector) {
		// TODO 自动生成的方法存根
		this.collector = collector;

	}

	@Override
	public void declareOutputFields(OutputFieldsDeclarer declarer) {
		// TODO 自动生成的方法存根
		declarer.declare(new Fields(""));
		

	}

	@Override
	public Map<String, Object> getComponentConfiguration() {
		// TODO 自动生成的方法存根
		return null;
	}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值