首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在apache-flink中创建动态规则?

如何在apache-flink中创建动态规则?
EN

Stack Overflow用户
提问于 2020-07-29 19:30:33
回答 1查看 342关注 0票数 0

我将flink与Java结合使用,并成功定义了一个静态模式,如下所示:

代码语言:javascript
复制
Pattern<Event, ?> pattern = Pattern.<Event>
            begin("first")
            .where(
                    new SimpleCondition<Event>() {
                        @Override
                            public boolean filter(Event event) {
                            return event.getTemperature() > 50;
                         }
                    }).within(Time.seconds(10L));

在apache-flink中有没有一种动态创建模式的方法?我需要根据用户的输入定义模式。

谢谢

EN

回答 1

Stack Overflow用户

发布于 2020-07-29 21:15:31

您可能会对"Dynamic Updates of Application Logic“模式感兴趣。

对于您要connect到流的规则,请使用BroadcastStream。

使用本文中的示例,您甚至可以拥有动态聚合定义:

代码语言:javascript
复制
// Streams setup
DataStream<Transaction> transactions = [...]
DataStream<Rule> rulesUpdateStream = [...]

BroadcastStream<Rule> rulesStream = rulesUpdateStream.broadcast(RULES_STATE_DESCRIPTOR);

// Processing pipeline setup
 DataStream<Alert> alerts =
     transactions
         .connect(rulesStream)
         .process(new DynamicKeyFunction())
         .keyBy((keyed) -> keyed.getKey())
         .connect(rulesStream)
         .process(new DynamicAlertFunction())
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63152612

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档