diff options
author | Sandro Tosi <sandro.tosi@gmail.com> | 2011-09-02 18:06:31 (GMT) |
---|---|---|
committer | Sandro Tosi <sandro.tosi@gmail.com> | 2011-09-02 18:06:31 (GMT) |
commit | 335f204977dda691617fc3e2164930a0077a42e2 (patch) | |
tree | fb25032e61a8e5a4be89f63b5c3cd18e35d49fa5 /Doc | |
parent | d86ac4cd4e77fc3646b72f2eeb2aa5df83361f01 (diff) | |
download | cpython-335f204977dda691617fc3e2164930a0077a42e2.zip cpython-335f204977dda691617fc3e2164930a0077a42e2.tar.gz cpython-335f204977dda691617fc3e2164930a0077a42e2.tar.bz2 |
#12781: Mention SO_REUSEADDR flag near socket examples
Diffstat (limited to 'Doc')
-rw-r--r-- | Doc/library/socket.rst | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/Doc/library/socket.rst b/Doc/library/socket.rst index d462bb7..64b4183 100644 --- a/Doc/library/socket.rst +++ b/Doc/library/socket.rst @@ -1014,6 +1014,25 @@ the interface:: s.ioctl(socket.SIO_RCVALL, socket.RCVALL_OFF) +Running an example several times with too small delay between executions, could +lead to this error:: + + socket.error: [Errno 98] Address already in use + +This is because the previous execution has left the socket in a ``TIME_WAIT`` +state, and can't be immediately reused. + +There is a :mod:`socket` flag to set, in order to prevent this, +:data:`socket.SO_REUSEADDR`:: + + s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) + s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1) + s.bind((HOST, PORT)) + +the :data:`SO_REUSEADDR` flag tells the kernel to reuse a local socket in +``TIME_WAIT`` state, without waiting for its natural timeout to expire. + + .. seealso:: For an introduction to socket programming (in C), see the following papers: |