summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSandro Tosi <sandro.tosi@gmail.com>2011-09-02 18:06:31 (GMT)
committerSandro Tosi <sandro.tosi@gmail.com>2011-09-02 18:06:31 (GMT)
commit335f204977dda691617fc3e2164930a0077a42e2 (patch)
treefb25032e61a8e5a4be89f63b5c3cd18e35d49fa5
parentd86ac4cd4e77fc3646b72f2eeb2aa5df83361f01 (diff)
downloadcpython-335f204977dda691617fc3e2164930a0077a42e2.zip
cpython-335f204977dda691617fc3e2164930a0077a42e2.tar.gz
cpython-335f204977dda691617fc3e2164930a0077a42e2.tar.bz2
#12781: Mention SO_REUSEADDR flag near socket examples
-rw-r--r--Doc/library/socket.rst19
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: