Flink 1.14.2 CEP 没有输出

背景

最近几天把Flink项目的版本从1.12升级到了最新的1.14.2,然后发现项目里的CEP事件都没有输出了,即使将Stream打印到控制台,也是啥也没有。

问题原因

Flink在1.12版本之后,PatternStream默认使用Event Time。如果业务使用的事Processing Time,必须要明确配置。

解决办法

样例代码,下面的代码是不会有任何输出的。

package spendreport;

import org.apache.flink.cep.CEP;
import org.apache.flink.cep.PatternSelectFunction;
import org.apache.flink.cep.PatternStream;
import org.apache.flink.cep.nfa.aftermatch.AfterMatchSkipStrategy;
import org.apache.flink.cep.pattern.Pattern;
import org.apache.flink.cep.pattern.conditions.SimpleCondition;
import org.apache.flink.streaming.api.datastream.DataStream;
import org.apache.flink.streaming.api.environment.StreamExecutionEnvironment;
import org.apache.flink.walkthrough.common.entity.Transaction;
import org.apache.flink.walkthrough.common.source.TransactionSource;


/**
 * @author jixiang.ma@mail.nwpu.edu.cn
 * @date 2022/1/7 19:00
 * @copyright © 2021 ruanjian.nwpu all rights reserved.
 */
public class CEPtest {
    public static void main(String[] args) throws Exception {
        final StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment().setParallelism(1);

        DataStream<Transaction> dataStream = env.addSource(new TransactionSource());

        Pattern<Transaction, ?> pattern = Pattern.<Transaction>begin("begin", AfterMatchSkipStrategy.noSkip()).where(
                new SimpleCondition<Transaction>() {
                    @Override
                    public boolean filter(Transaction transaction) throws Exception {
                        return transaction.getAmount() > 300;
                    }
                }).timesOrMore(1);

        PatternStream<Transaction> patternStream = CEP.pattern(dataStream, pattern);
        DataStream<Transaction> d = patternStream.select(
                (PatternSelectFunction<Transaction, Transaction>) map -> map.get("begin").get(0))
                .name("bbbb");

        d.print();

        env.execute();
    }
}

 

而下面的代码就正常了

package spendreport;

import org.apache.flink.cep.CEP;
import org.apache.flink.cep.PatternSelectFunction;
import org.apache.flink.cep.PatternStream;
import org.apache.flink.cep.nfa.aftermatch.AfterMatchSkipStrategy;
import org.apache.flink.cep.pattern.Pattern;
import org.apache.flink.cep.pattern.conditions.SimpleCondition;
import org.apache.flink.streaming.api.datastream.DataStream;
import org.apache.flink.streaming.api.environment.StreamExecutionEnvironment;
import org.apache.flink.walkthrough.common.entity.Transaction;
import org.apache.flink.walkthrough.common.source.TransactionSource;


/**
 * @author jixiang.ma@mail.nwpu.edu.cn
 * @date 2022/1/7 19:00
 * @copyright © 2021 ruanjian.nwpu all rights reserved.
 */
public class CEPtest {
    public static void main(String[] args) throws Exception {
        final StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment().setParallelism(1);

        DataStream<Transaction> dataStream = env.addSource(new TransactionSource());

        Pattern<Transaction, ?> pattern = Pattern.<Transaction>begin("begin", AfterMatchSkipStrategy.noSkip()).where(
                new SimpleCondition<Transaction>() {
                    @Override
                    public boolean filter(Transaction transaction) throws Exception {
                        return transaction.getAmount() > 300;
                    }
                }).timesOrMore(1);

        PatternStream<Transaction> patternStream = CEP.pattern(dataStream, pattern).inProcessingTime();
        DataStream<Transaction> d = patternStream.select(
                (PatternSelectFunction<Transaction, Transaction>) map -> map.get("begin").get(0))
                .name("bbbb");

        d.print();

        env.execute();
    }
}

 只需要在在后面加上inProcessingTime()或者inEventTime()即可。

PatternStream<Transaction> patternStream = CEP.pattern(dataStream, pattern).inProcessingTime();

总结

当代码能跑起来的时候,能别动就别动!

备注:示例中的数据源是Flink内置数据源,需要加载Maven pom:

        <dependency>
			<groupId>org.apache.flink</groupId>
			<artifactId>flink-walkthrough-common_${scala.binary.version}</artifactId>
			<version>${flink.version}</version>
		</dependency>

  • 8
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值