James E. King, III created THRIFT-3069:
------------------------------------------

             Summary: C++ TServerSocket leaks socket on fcntl get or set flags 
error
                 Key: THRIFT-3069
                 URL: https://issues.apache.org/jira/browse/THRIFT-3069
             Project: Thrift
          Issue Type: Bug
          Components: C++ - Library
    Affects Versions: 0.9.2
            Reporter: James E. King, III
            Priority: Minor


Walking through the C++ TServerSocket code, there are opportunities for the 
newly accepted client socket to leak:
{noformat}  THRIFT_SOCKET clientSocket = ::accept(serverSocket_,
                              (struct sockaddr *) &clientAddress,
                              (socklen_t *) &size);

  if (clientSocket == -1) {
    int errno_copy = THRIFT_GET_SOCKET_ERROR;
    GlobalOutput.perror("TServerSocket::acceptImpl() ::accept() ", errno_copy);
    throw TTransportException(TTransportException::UNKNOWN, "accept()", 
errno_copy);
  }

  // Make sure client socket is blocking
  int flags = THRIFT_FCNTL(clientSocket, THRIFT_F_GETFL, 0);
  if (flags == -1) {
    int errno_copy = THRIFT_GET_SOCKET_ERROR;
    GlobalOutput.perror("TServerSocket::acceptImpl() THRIFT_FCNTL() 
THRIFT_F_GETFL ", errno_copy);
    throw TTransportException(TTransportException::UNKNOWN, 
"THRIFT_FCNTL(THRIFT_F_GETFL)", errno_copy);
  }

  if (-1 == THRIFT_FCNTL(clientSocket, THRIFT_F_SETFL, flags & 
~THRIFT_O_NONBLOCK)) {
    int errno_copy = THRIFT_GET_SOCKET_ERROR;
    GlobalOutput.perror("TServerSocket::acceptImpl() THRIFT_FCNTL() 
THRIFT_F_SETFL ~THRIFT_O_NONBLOCK ", errno_copy);
    throw TTransportException(TTransportException::UNKNOWN, 
"THRIFT_FCNTL(THRIFT_F_SETFL)", errno_copy);
  }
{noformat}

Specifically in both of the latter error handling cases, {{clientSocket}} is 
not cleaned up.  Given this is highly unlikely to occur, I set the priority of 
this issue to Minor.



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

Reply via email to