[ 
https://issues.apache.org/jira/browse/FLINK-7880?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=16270843#comment-16270843
 ] 

ASF GitHub Bot commented on FLINK-7880:
---------------------------------------

Github user zentol commented on a diff in the pull request:

    https://github.com/apache/flink/pull/5062#discussion_r153801762
  
    --- Diff: 
flink-queryable-state/flink-queryable-state-client-java/src/main/java/org/apache/flink/queryablestate/network/Client.java
 ---
    @@ -422,20 +467,31 @@ void close() {
                 * @param cause The cause to close the channel with.
                 * @return Channel close future
                 */
    -           private boolean close(Throwable cause) {
    -                   if (failureCause.compareAndSet(null, cause)) {
    -                           channel.close();
    -                           stats.reportInactiveConnection();
    +           private CompletableFuture<Void> close(Throwable cause) {
    +                   final CompletableFuture<Void> shutdownFuture = new 
CompletableFuture<>();
     
    -                           for (long requestId : pendingRequests.keySet()) 
{
    -                                   TimestampedCompletableFuture pending = 
pendingRequests.remove(requestId);
    -                                   if (pending != null && 
pending.completeExceptionally(cause)) {
    -                                           stats.reportFailedRequest();
    +                   if (connectionShutdownFuture.compareAndSet(null, 
shutdownFuture) &&
    --- End diff --
    
    this can result in odd race conditions, where one thread has set the 
shutdownFuture, but another one the failureCause. I would suggest to create a 
container for the future and exception and update them atomically.


> flink-queryable-state-java fails with core-dump
> -----------------------------------------------
>
>                 Key: FLINK-7880
>                 URL: https://issues.apache.org/jira/browse/FLINK-7880
>             Project: Flink
>          Issue Type: Bug
>          Components: Queryable State, Tests
>    Affects Versions: 1.4.0
>            Reporter: Till Rohrmann
>            Assignee: Kostas Kloudas
>            Priority: Critical
>              Labels: test-stability
>
> The {{flink-queryable-state-java}} module fails on Travis with a core dump.
> https://travis-ci.org/tillrohrmann/flink/jobs/289949829



--
This message was sent by Atlassian JIRA
(v6.4.14#64029)

Reply via email to