ApacheBeam:IllegalStateException-Valueonlyavailableatruntimeafterupgradingtobeam2.41.0
创始人
2024-09-05 11:00:49
0

在使用Beam的时候,当你升级到2.41.0版本时,你可能会遇到以下异常:

java.lang.IllegalStateException: Value only available at runtime

这个异常是由于Beam升级后引入了一个新的Rule来检查运行时数据是否与Pipeline代码中的数据匹配,导致运行时值无法在编译期间获得,从而导致这个异常。

要解决这个问题,你可以使用以下两种方法之一:

方法一:禁用检查规则

你可以通过在运行Pipeline的时候添加以下标志来禁用检查规则:

-Dorg.apache.beam.sdk.pipeline.PipelineRunnerRegistrar$DefaultRunner--enforceImmutability=false

这将使Beam不再执行检查,从而允许你在编译期间获得值。

方法二:使用InstantiationTimeValueProvider

你可以使用InstantiationTimeValueProvider来处理在编译期间无法获取的值。示例如下:

import org.apache.beam.sdk.options.ValueProvider; import org.apache.beam.sdk.options.ValueProvider.NestedValueProvider; import org.apache.beam.sdk.options.ValueProvider.StaticValueProvider; import org.apache.beam.sdk.transforms.DoFn; import org.apache.beam.sdk.transforms.ParDo; import org.apache.beam.sdk.values.KV;

public class MyDoFn extends DoFn, String> { private ValueProvider myValue;

public MyDoFn(ValueProvider myValue) { this.myValue = myValue; }

@ProcessElement public void processElement(ProcessContext c) { String value = myValue.get(); String key = c.element().getKey(); String output = key + ":" + value; c.output(output); } }

public class MyPipeline { public static void main(String[] args) { String myRuntimeValue = "myRuntimeValue"; MyDoFn myDoFn = new MyDoFn(NestedValueProvider.of( StaticValueProvider.of(myRuntimeValue), (SerializableFunction) input -> input));

Pipeline p = Pipeline.create(); p.apply

相关内容

热门资讯

解迷透视!wepoker游戏下... 解迷透视!wepoker游戏下载,微信小程序游戏破解微乐游戏,练习教程(有挂规律)-哔哩哔哩暗藏猫腻...
详细透视!德普之星辅助工具如何... 详细透视!德普之星辅助工具如何打开,微乐小程序黑科技免费知乎,课程教程(有挂技术)-哔哩哔哩1、许多...
总结透视!wepoker辅助器... 总结透视!wepoker辅助器,微信微乐小程序有窍门吗,秘籍教程(有挂秘籍)-哔哩哔哩1、wepok...
辅助透视!wpk透视是真的假的... 辅助透视!wpk透视是真的假的,微乐自建房脚本最新版本更新内容,指引教程(有挂功能)-哔哩哔哩1、w...
解谜透视!德州局透视脚本下载安... 解谜透视!德州局透视脚本下载安装最新版本,微乐小程序黑科技app入口,模块教程(有挂秘笈)-哔哩哔哩...
解密透视!hhpoker作弊实... 解密透视!hhpoker作弊实战视频,微乐老友广东辅助器,手筋教程(详细教程)-哔哩哔哩1、让任何用...
普及透视!poker辅助器免费... 普及透视!poker辅助器免费安装,微乐自建房免费脚本哪个最好用,秘籍教程(有挂头条)-哔哩哔哩1、...
揭露透视!aapoker公共底... 揭露透视!aapoker公共底牌,微乐春天小程序辅助,操作教程(证实有挂)-哔哩哔哩1、每一步都需要...
详细透视!aapoker怎么拿... 详细透视!aapoker怎么拿好牌,收集微乐小程序游戏破解器,讲义教程(有挂细节)-哔哩哔哩1、aa...
揭幕透视!wepoker脚本,... 揭幕透视!wepoker脚本,微信小程序游戏充值破解,模板教程(有挂秘籍)-哔哩哔哩1、wepoke...