drill-dev mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From jacques-n <...@git.apache.org>
Subject [GitHub] drill pull request: DRILL-3714: Query runs out of memory and remai...
Date Sat, 02 Apr 2016 01:47:51 GMT
Github user jacques-n commented on a diff in the pull request:

    --- Diff: exec/rpc/src/main/java/org/apache/drill/exec/rpc/RpcBus.java ---
    @@ -159,19 +159,15 @@ public ChannelClosedHandler(C clientConnection, Channel channel)
         public void operationComplete(ChannelFuture future) throws Exception {
           String msg;
    -      if(local!=null) {
    +      if(local != null) {
             msg = String.format("Channel closed %s <--> %s.", local, remote);
             msg = String.format("Channel closed %s <--> %s.", future.channel().localAddress(),
    -      if (RpcBus.this.isClient()) {
    -        if(local != null) {
    -          logger.info(String.format(msg));
    -        }
    -      } else {
    -        queue.channelClosed(new ChannelClosedException(msg));
    -      }
    +      logger.info(msg); // should we leave this at info level ?
    +      queue.channelClosed(new ChannelClosedException(msg));
    --- End diff --
    Nice catch Sudheesh.
    Reflecting on this now, I think there is a much cleaner way to structure this than the
current implementation. If we manage this at the connection level (new "outstanding handler
=> rpc id mapping" per connection), we can rely on Netty's RPC thread properties to have
a trivial structure that doesn't need to be thread safe and is closed out on connection termination.
Do one of you want to pick up that modification? I think that would make things much nicer.

If your project is set up for it, you can reply to this email and have your
reply appear on GitHub as well. If your project does not have this feature
enabled and wishes so, or if the feature is enabled but not working, please
contact infrastructure at infrastructure@apache.org or file a JIRA ticket
with INFRA.

View raw message