我用类似下面的代码做开窗聚合,统计每分钟事件出现次数。
t.selectKey { _, rawEvent -> "${rawEvent.appid}${rawEvent.eid}" }
.groupByKey()
.windowedBy(TimeWindows.of(Duration.ofMinutes(1)))
.aggregate(
{ CountWindow() },
{ _, v, agg ->
// 窗口期的事件总数+1
agg.total += 1
agg
},
Materialized.`as`<String, CountWindow, WindowStore<Bytes, ByteArray>>("test_window_retentation1")
.withValueSerde(GenericGsonSerde<CountWindow> { gson, bytes ->
gson.fromJson(String(bytes))
})
)
然后通过ReadOnlyWindowStore#fetch()查询给定时间段内事件出现的次数,一开始的时候结果是正常的,但是一段时间后当我重启应用,fetch就获取不到窗口数据了,看上去像是历史窗口被丢弃了。
请问这种开窗操作的窗口是不是有个保留时间呢,如果有的话是否可以设置?