[ https://issues.apache.org/jira/browse/FLINK-3339?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=15134193#comment-15134193 ]
ASF GitHub Bot commented on FLINK-3339: --------------------------------------- GitHub user aljoscha opened a pull request: https://github.com/apache/flink/pull/1594 [FLINK-3339] Make ValueState.update(null) act as ValueState.clear() This was causing problems with TypeSerializers that choke on null values, especially in the Scala KeyedStream.*WithState() family of functions. You can merge this pull request into a Git repository by running: $ git pull https://github.com/aljoscha/flink state-fix-null Alternatively you can review and apply these changes as the patch at: https://github.com/apache/flink/pull/1594.patch To close this pull request, make a commit to your master/trunk branch with (at least) the following in the commit message: This closes #1594 ---- commit d3bae5e171cd6a572966022380e30eb6df08108b Author: Aljoscha Krettek <aljoscha.kret...@gmail.com> Date: 2016-02-05T13:46:14Z [FLINK-3339] Make ValueState.update(null) act as ValueState.clear() This was causing problems with TypeSerializers that choke on null values, especially in the Scala KeyedStream.*WithState() family of functions. ---- > Checkpointing NPE when using filterWithState > -------------------------------------------- > > Key: FLINK-3339 > URL: https://issues.apache.org/jira/browse/FLINK-3339 > Project: Flink > Issue Type: Bug > Reporter: Shikhar Bhushan > Assignee: Aljoscha Krettek > > (1.0-SNAPSHOT) > I am using the Scala API keyedStream.filterWithState(..), where the state is > an Option[Long] > I am seeing the following error which goes away if I remove the filter. > {noformat} > 02/04/2016 14:10:19 Job execution switched to status FAILING. > java.lang.RuntimeException: Error triggering a checkpoint as the result of > receiving checkpoint barrier > at > org.apache.flink.streaming.runtime.tasks.StreamTask$2.onEvent(StreamTask.java:651) > at > org.apache.flink.streaming.runtime.tasks.StreamTask$2.onEvent(StreamTask.java:644) > at > org.apache.flink.streaming.runtime.io.BarrierBuffer.processBarrier(BarrierBuffer.java:201) > at > org.apache.flink.streaming.runtime.io.BarrierBuffer.getNextNonBlocked(BarrierBuffer.java:127) > at > org.apache.flink.streaming.runtime.io.StreamInputProcessor.processInput(StreamInputProcessor.java:173) > at > org.apache.flink.streaming.runtime.tasks.OneInputStreamTask.run(OneInputStreamTask.java:63) > at > org.apache.flink.streaming.runtime.tasks.StreamTask.invoke(StreamTask.java:218) > at org.apache.flink.runtime.taskmanager.Task.run(Task.java:562) > at java.lang.Thread.run(Thread.java:745) > Caused by: java.lang.NullPointerException > at > org.apache.flink.api.common.typeutils.base.LongSerializer.serialize(LongSerializer.java:63) > at > org.apache.flink.api.common.typeutils.base.LongSerializer.serialize(LongSerializer.java:27) > at > org.apache.flink.runtime.state.memory.AbstractMemState.snapshot(AbstractMemState.java:74) > at > org.apache.flink.runtime.state.AbstractStateBackend.snapshotPartitionedState(AbstractStateBackend.java:245) > at > org.apache.flink.streaming.api.operators.AbstractStreamOperator.snapshotOperatorState(AbstractStreamOperator.java:174) > at > org.apache.flink.streaming.api.operators.AbstractUdfStreamOperator.snapshotOperatorState(AbstractUdfStreamOperator.java:119) > at > org.apache.flink.streaming.runtime.tasks.StreamTask.triggerCheckpoint(StreamTask.java:470) > at > org.apache.flink.streaming.runtime.tasks.StreamTask$2.onEvent(StreamTask.java:648) > ... 8 more > {noformat} -- This message was sent by Atlassian JIRA (v6.3.4#6332)