Hi Arpith I'm afraid that you're totally talking about the wrong thing in previous thread. The root cause is not restoring state from checkpoint but not access the state legally. Have you ever add keyBy before process your function as doc's note [1] said: "If you want to access keyed state and timers you have to apply the ProcessFunction on a keyed stream"?
[1] https://ci.apache.org/projects/flink/flink-docs-release-1.11/dev/stream/operators/process_function.html#the-processfunction Best Yun Tang ________________________________ From: Arpith P <arpitht...@gmail.com> Sent: Tuesday, October 13, 2020 22:20 To: Yun Tang <myas...@live.com> Cc: user <user@flink.apache.org> Subject: Re: Is MapState tied to Operator Input & Output type? Hi Yun, Neither state descriptor type or name changed. I did assign an ID as well but it didn't help me. What I'm trying to do is I have two stream A & B which I want to connect/process in C; I eventually want values from stream A to be saved in C's MapState. What I've tried is I used ConnectedStream to connect both A(keyedstream) & B and processed in CoProcessFunction C, but looks like in CoprocessFunction doesn't have MapState as I'm getting functionInitializationContext.getKeyedStore as null. Is it possible to access MapState inside CoProcessFunction. Arpith On Tue, Oct 13, 2020 at 5:18 PM Yun Tang <myas...@live.com<mailto:myas...@live.com>> wrote: Hi The type of map state is not directly related with input & output type, this is only related with how you define the state descriptor. * Have you ever changed the state descriptor after changing the type of input/output type? * Have you assigned the id [1] to the operator which using the 'TestProcess'? The state might not be restored if you change your code without id assigned. [1] https://ci.apache.org/projects/flink/flink-docs-stable/ops/state/savepoints.html#assigning-operator-ids Best Yun Tang ________________________________ From: Arpith P <arpitht...@gmail.com<mailto:arpitht...@gmail.com>> Sent: Tuesday, October 13, 2020 19:26 To: user <user@flink.apache.org<mailto:user@flink.apache.org>> Subject: Is MapState tied to Operator Input & Output type? Hi, I’ve a ProcessFunction which initially was receiving input & output type of String (1) & inside processElement I was updating MapState. Now I have changed the Input & Output type to be Map, String (2), but if I restore from the last checkpoint folder MapState is coming in as empty. I’ve checked that checkpoint folder actually saves data (i.e. Files size > 1GB). Does map state tied with ProcessFunction input & output type, if not why doesn't mapstate get restored. (1) public class TestProcess extends ProcessFunction<String, String> implements CheckpointedFunction (2) public class TestProcess extends ProcessFunction<Map<String, String>, String> implements CheckpointedFunction