- Apache Flink 文档
- 概念
- 数据流编程模型
- 分布式运行时环境
- 教程
- API 教程
- DataStream API 教程
- Setup 教程
- 本地安装教程
- 在 Windows 上运行 Flink
- 例子
- 批处理示例
- 应用开发
- 项目构建设置
- Java 项目模板
- Scala 的项目模板
- 配置依赖关系,连接器,库
- 基础 API 概念
- Scala API 扩展
- Java Lambda 表达式
- Flink DataStream API 编程指南
- 活动时间
- 事件时间/处理时间/摄取时间
- 活动时间和水印
- 状态与容错
- 算子
- DataStream 转换
- 物理分区
- 任务链和资源组
- 流连接器
- 旁路输出
- Python 编程指南(流)Beta
- 测试
- 实验特点
- Flink DataSet API 编程指南
- 数据集转换
- 容错
- 在数据集中压缩数据元
- 迭代
- Python 编程指南 Beta
- 连接器
- Hadoop 兼容性测试版
- 本地执行
- 群集执行
- Table API 和 SQL
- 概念和通用 API
- 流处理概念
- 连接到外部系统
- Table API
- SQL
- 内置函数
- 用户定义的源和接收器
- 用户定义的函数
- SQL 客户端测试版
- 数据类型和序列化
- 为 Flink 程序注册自定义序列化程序
- 管理执行
- 执行配置
- 程序打包和分布式执行
- 并行执行
- 执行计划
- 重启策略
- 类库
- FlinkCEP - Flink 的复杂事件处理
- 风暴兼容性 Beta
- 项目配置
- 执行 Storm 拓扑
- 在 Flink 流程序中嵌入 Storm 算子
- Flink Extensions
- Storm 兼容性示例
- Gelly:Flink Graph API
- 图 API
- FlinkML - Flink 的机器学习
- 最佳实践
- API 迁移指南
- 部署和运营
- 集群和部署
- 独立群集
- YARN 设置
- Mesos 设置
- Kubernetes 设置
- Docker 设置
- 亚马逊网络服务(AWS)
- Google Compute Engine 设置
- 先决条件
- 在 Google Compute Engine 上部署 Flink
- MapR 设置
- Hadoop 集成
- JobManager 高可用性(HA)
- 状态和容错
- 检查点
- 保存点
- 状态后台
- 调整检查点和大状态
- 配置
- 生产准备清单
- 命令行界面
- Scala REPL
- Kerberos 身份验证设置和配置
- SSL 设置
- 文件系统
- 升级应用程序和 Flink 版本
- 调试和监控
- 度量
- 如何使用日志记录
- 历史服务器
- 监控检查点
- 监测背压
- 监控 REST API
- 调试 Windows 和事件时间
- 调试类加载
- 应用程序分析
- 使用 Java Flight Recorder 进行性能分析
- 使用 JITWatch 进行分析
- Flink Development
- 将 Flink 导入 IDE
- 从 Source 建立 Flink
- 内幕
- 组件堆栈
- 数据流容错
- 工作和调度
- 任务生命周期
- 文件系统
- 实现
- 坚持保证
- 更新文件内容
- 覆盖文件
- 线程安全
在 Flink 流程序中嵌入 Storm 算子
作为替代方案,Spouts 和 Bolts 可以嵌入到常规流处理节目中。Storm 兼容层为每个提供了一个打包类,即 SpoutWrapper
和 BoltWrapper
( org.apache.flink.storm.wrappers
)。
每默认情况下,打包转换风暴输出元组 Flink 的 元组 类型(即, Tuple0
以 Tuple25
根据风暴元组的字段数)。对于单场输出元组,也可以转换为字段的数据类型(例如, String
代替 Tuple1<String>
)。
由于 Flink 无法推断 Storm 算子的输出字段类型,因此需要手动指定输出类型。为了获得正确的 TypeInformation
对象, TypeExtractor
可以使用 Flink 。
嵌入 Spouts
要将 Spout 用作 Flink 源,请使用 StreamExecutionEnvironment.addSource(SourceFunction, TypeInformation)
。Spout 对象被传递给它的构造函数 SpoutWrapper<OUT>
,作为第一个参数 addSource(...)
。泛型类型声明 OUT
指定源输出流的类型。
StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();
// stream has `raw` type (single field output streams only)
DataStream<String> rawInput = env.addSource(
new SpoutWrapper<String>(new FileSpout(localFilePath), new String[] { Utils.DEFAULT_STREAM_ID }), // emit default output stream as raw type
TypeExtractor.getForClass(String.class)); // output type
// process data stream
[...]
如果 Spout 发出有限数量的元组, SpoutWrapper
可以通过 numberOfInvocations
在其构造函数中设置参数来配置为自动终止。这允许 Flink 程序在处理完所有数据后自动关闭。默认情况下,程序将一直运行,直到手动 取消 。
嵌入螺栓
要使用 Bolt 作为 Flink 算子,请使用 DataStream.transform(String, TypeInformation, OneInputStreamOperator)
。Bolt 对象被传递给它的构造函数 BoltWrapper<IN,OUT>
,作为最后一个参数 transform(...)
。泛型类型声明 IN
并分别 OUT
指定 算子的输入和输出流的类型。
StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();
DataStream<String> text = env.readTextFile(localFilePath);
DataStream<Tuple2<String, Integer>> counts = text.transform(
"tokenizer", // operator name
TypeExtractor.getForObject(new Tuple2<String, Integer>("", 0)), // output type
new BoltWrapper<String, Tuple2<String, Integer>>(new BoltTokenizer())); // Bolt operator
// do further processing
[...]
嵌入式螺栓的命名属性访问
螺栓可以通过名称访问输入元组字段(另外通过索引访问)。要在嵌入式螺栓中使用此函数,您需要具有 a
对于 POJO 输入类型,Flink 通过反射访问字段。对于这种情况,Flink 期望相应的公共成员变量或公共 getter 方法。例如,如果 Bolt 通过名称 sentence
(例如 String s = input.getStringByField("sentence");
)访问字段,则输入 POJO 类必须具有成员变量 public String sentence;
或方法 public String getSentence() { ... };
(注意驼峰式命名)。
对于 Tuple
输入类型,需要使用 Storm 的 Fields
类指定输入模式。对于这种情况,构造函数 BoltWrapper
需要另外一个参数: new BoltWrapper<Tuple1<String>, ...>(..., new Fields("sentence"))
。输入类型是 Tuple1<String>
和 Fields("sentence")
指定 input.getStringByField("sentence")
相当于 input.getString(0)
。
有关 示例 ,请参阅 BoltTokenizerWordCountPojo 和 BoltTokenizerWordCountWithNames 。
配置喷口和螺栓
在 Storm 中,Spouts 和 Bolts 可以配置一个全局分布的 Map
对象,该对象被赋予 submitTopology(...)
方法 LocalCluster
或 StormSubmitter
。这 Map
是由拓扑旁边的用户提供的,并作为参数转发给呼叫 Spout.open(...)
和 Bolt.prepare(...)
。如果在 Flink 中使用 FlinkTopologyBuilder
等执行整个拓扑,则不需要特别注意 - 它与常规 Storm 一样。
对于嵌入式使用,必须使用 Flink 的配置机制。可以在 StreamExecutionEnvironment
via 中设置全局配置 .getConfig().setGlobalJobParameters(...)
。Flink 的常规 Configuration
课程可用于配置 Spouts 和 Bolts。但是, Configuration
不像 Storm 那样支持任意 Keys 数据类型(只 String
允许 Keys)。因此,Flink 还提供 StormConfig
了可以像 raw 一样使用的类, Map
以提供与 Storm 的完全兼容性。
StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();
StormConfig config = new StormConfig();
// set config values
[...]
// set global Storm configuration
env.getConfig().setGlobalJobParameters(config);
// assemble program with embedded Spouts and/or Bolts
[...]
多输出流
Flink 还可以处理 Spout 和 Bolts 的多个输出流的声明。如果在 Flink 中使用 FlinkTopologyBuilder
等执行整个拓扑,则不需要特别注意 - 它与常规 Storm 一样。
对于嵌入式使用,输出流将是数据类型 SplitStreamType<T>
,必须使用 DataStream.split(...)
和拆分 SplitStream.select(...)
。Flink 提供预定义输出选择 StormStreamSelector<T>
为 .split(...)
已经。此外, SplitStreamTuple<T>
可以使用除去打包类型 SplitStreamMapper<T>
。
[...]
// get DataStream from Spout or Bolt which declares two output streams s1 and s2 with output type SomeType
DataStream<SplitStreamType<SomeType>> multiStream = ...
SplitStream<SplitStreamType<SomeType>> splitStream = multiStream.split(new StormStreamSelector<SomeType>());
// remove SplitStreamType using SplitStreamMapper to get data stream of type SomeType
DataStream<SomeType> s1 = splitStream.select("s1").map(new SplitStreamMapper<SomeType>()).returns(SomeType.class);
DataStream<SomeType> s2 = splitStream.select("s2").map(new SplitStreamMapper<SomeType>()).returns(SomeType.class);
// do further processing on s1 and s2
[...]
有关完整示例,请参阅 SpoutSplitExample.java 。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论