Cherrot Luo created THRIFT-3737:
-----------------------------------

             Summary: Improve TSocket isOpen() implementation to give more 
accurate connection status.
                 Key: THRIFT-3737
                 URL: https://issues.apache.org/jira/browse/THRIFT-3737
             Project: Thrift
          Issue Type: Bug
          Components: Python - Library
            Reporter: Cherrot Luo


h2. Description
Typically isOpen() of TSocket.py in python lib would *ALWAYS* return true, even 
if the underlying TCP connection has been closed or reset by the peer, unless 
you manually invoke its close() method.

This is because the isOpen method takes a simple but kind of "irresponsible" 
way to judge connection status:
{code:title=TSocket.py}
def isOpen(self):
    return self.handle is not None
{code}

This may affect the upstream lib/tools' implementation to offer a *reliable* 
transport instance. 
For example, in [happybase|https://github.com/wbolster/happybase] (a 
developer-friendly Python library to interact with Apache HBase), it use 
isOpen() to judge whether it neccessary to reopen the connection in its 
[connection|https://github.com/wbolster/happybase/blob/9cbd718c10a3089f234f1eac1236b631e1f8e7cd/happybase/connection.py#L164]
 and connection pool.

h2. Fix
I would send a pull request to the github repo later. 
The implementation is according to Python's 
*[urllib3|https://github.com/shazow/urllib3/blob/0f98217c8125848dd3eded84d11b83c5caefaa97/urllib3/util/connection.py#L13]*
 module -- The most widely used Python HTTP library.



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

Reply via email to