当前位置: 首页 > news >正文

全景网站制作教程福州seo排名公司

全景网站制作教程,福州seo排名公司,设计公司装修,企业网站asp背景 在处理键值分区状态时,使用ttl设置过期时间是我们经常使用的,但是任何代码的修改都需要首先进行单元测试,本文就使用单元测试来验证一下状态ttl的设置是否正确 测试状态ttl超时的单元测试 首先看一下处理函数: // 处理函…

背景

在处理键值分区状态时,使用ttl设置过期时间是我们经常使用的,但是任何代码的修改都需要首先进行单元测试,本文就使用单元测试来验证一下状态ttl的设置是否正确

测试状态ttl超时的单元测试

首先看一下处理函数:

// 处理函数
public class MyStateProcessFunction extends KeyedProcessFunction<String, String, String> {// 键值分区状态ValueState<String> previousInput;@Overridepublic void open(Configuration parameters) throws Exception {ValueStateDescriptor stateDescriptor = new ValueStateDescriptor<String>("previousInput", Types.STRING);// 状态ttl超时时间设置StateTtlConfig ttlConfig =StateTtlConfig.newBuilder(Time.minutes(1)).setUpdateType(StateTtlConfig.UpdateType.OnCreateAndWrite).setStateVisibility(StateTtlConfig.StateVisibility.NeverReturnExpired)// check 10 keys for every state access.cleanupIncrementally(10, false).build();stateDescriptor.enableTimeToLive(ttlConfig);previousInput = getRuntimeContext().getState(stateDescriptor);}@Overridepublic void processElement(String in, Context context, Collector<String> collector) throws Exception {context.timerService().registerProcessingTimeTimer(100);String out = (Objects.nonNull(previousInput.value()) ? previousInput.value() : "") + in;collector.collect(out);if (!in.contains("NotUpdate")) {// 为了模仿有访问状态,但是不更新状态,正常情况下业务逻辑是访问其他key组的其它state,而一直没有访问的key的状态会在超时时间到之后被清理掉previousInput.update(in);}}@Overridepublic void onTimer(long timestamp, OnTimerContext ctx, Collector<String> out) throws Exception {if (Objects.nonNull(previousInput.value())) {out.collect(String.format("timer trigger %s", previousInput.value()));} else {out.collect(String.format("timer trigger state clear", previousInput.value()));}}}

单元测试代码:

/*** 测试状态处理函数,包含状态的ttl配置,以及ontimer方法**/
@Test
public void testKeyedStateProcessFunction() throws Exception {MyStateProcessFunction myStateProcessFunction = new MyStateProcessFunction();OneInputStreamOperatorTestHarness<String, String> testHarness =ProcessFunctionTestHarnesses.forKeyedProcessFunction(myStateProcessFunction, x -> "1", Types.STRING);testHarness.open();testHarness.processElement("hello", 10);// 注册了一个定时器,定时器100后过期Assert.assertEquals(1, testHarness.numProcessingTimeTimers());// 测试输出Assert.assertEquals(Lists.newArrayList("hello"), testHarness.extractOutputValues());ValueState<String> previousInput = myStateProcessFunction.getRuntimeContext().getState(new ValueStateDescriptor<>("previousInput", Types.STRING));// 查看下状态应该已经被设置Assert.assertEquals("hello", previousInput.value());testHarness.processElement("world", 10);// 再次测试输出Assert.assertEquals(Lists.newArrayList("hello", "helloworld"), testHarness.extractOutputValues());// 再次查看下状态应该已经被设置Assert.assertEquals("world", previousInput.value());// 设置时间为1分钟,让状态超时testHarness.setStateTtlProcessingTime(Time.minutes(1).toMilliseconds());// 触发下状态访问,这样flink就会清理,正常生产中不需要这一步,访问状态本来就一直在进行中,只是可能是其他key分组的状态testHarness.processElement("NotUpdate1", System.currentTimeMillis());// 查看下状态应该已经被清理Assert.assertNull(previousInput.value());// 设置让定时器过期,顺带确认下状态已经被清理testHarness.setProcessingTime(100);// 测试输出(包含两个输入+一个定时器的输出)Assert.assertEquals(Lists.newArrayList("hello", "helloworld", "NotUpdate1", "timer trigger state clear"),testHarness.extractOutputValues());testHarness.close();
}

测试代码中已经包含了详细的注解,我们实现自己的ttl单元测试时可以参考下

http://www.zhongyajixie.com/news/1519.html

相关文章:

  • 政府网站制作方案做了5天游戏推广被抓了
  • 佛山自己网站建设公司网站模板设计
  • 如何做网站超链接网站关键词快速排名工具
  • 渝叶购零售客户电商网站营销网络图
  • 个体户查名字是否被注册班级优化大师怎么用
  • 电子商务网站建设流程新东方教育培训机构
  • 如何快速做h5网站南宁百度推广代理公司
  • 邯郸注册公司搜索引擎优化的目的是
  • 著名室内设计师seo网络优化专员
  • 成都哪个公司做网站爱站长尾词
  • 旅游电子商务的网站建设新闻源软文推广平台
  • 网站显示百度众测是怎么做的网店搜索引擎优化的方法
  • 大宅装修抖音seo推荐算法
  • 论坛备案网站名称东莞市民最新疫情
  • 网站建设具体日程安排广告推广图片
  • 国外免费舆情网站有哪些软件关键词上首页的有效方法
  • 广州网站建设是什么seo快排
  • 厦门网站建设seo百度快照怎么优化排名
  • 做坑网站需要seo网络推广招聘
  • 园林公司做网站的好处枸橼酸西地那非片的功效与作用
  • 一个网址建多个网站网站查询服务器
  • 越秀定制型网站建设找培训机构的网站
  • 建筑设计地图网站广州网站优化运营
  • 贵阳专业做网站的公司有哪些新闻稿撰写
  • a家兽装定制网站重庆百度推广开户
  • 深圳大鹏住房和建设局网站推广营销
  • 网站建设的技术seo网站优化详解
  • 网站跳出率什么意思宁波seo网络推广定制多少钱
  • 网站构成的作用重庆网站建设公司
  • 动易网站建设网站建立的步骤