Message278691
This indicated to me that the socket object has indeed been closed _before_ you call getpeername():
-------------
print(sock)>>>
<socket.socket [closed] fd=-1, family=AFNET, type=SOCKSTREAM, proto=0>
sock.getpeername()>>>
OS.Error[WinError10038]an operation was attempted on something that is not a socket
=======
In this case, I think ā[closed] fd=-1ā means that both the Python-level socket object, and all objects returned by socket.makefile(), have been closed, so the OS-level socket has probably been closed. In any case, getpeername() is probably trying the invalid file descriptor -1. If there are no copies of the OS-level socket open (e.g. in other processes), then the TCP connection is probably also shut down, but I suspect the problem is the socket object, not the TCP connection.
Without code or something demonstrating the bug, Iām pretty sure it is a bug in your program, not in Python. |
|
Date |
User |
Action |
Args |
2016-10-15 03:46:10 | martin.panter | set | recipients:
+ martin.panter, GeorgeY |
2016-10-15 03:46:10 | martin.panter | set | messageid: <1476503170.31.0.780175579109.issue28447@psf.upfronthosting.co.za> |
2016-10-15 03:46:10 | martin.panter | link | issue28447 messages |
2016-10-15 03:46:10 | martin.panter | create | |
|