Home | History | Annotate | Download | only in library
      1 :mod:`socketserver` --- A framework for network servers
      2 =======================================================
      3 
      4 .. module:: socketserver
      5    :synopsis: A framework for network servers.
      6 
      7 **Source code:** :source:`Lib/socketserver.py`
      8 
      9 --------------
     10 
     11 The :mod:`socketserver` module simplifies the task of writing network servers.
     12 
     13 There are four basic concrete server classes:
     14 
     15 
     16 .. class:: TCPServer(server_address, RequestHandlerClass, bind_and_activate=True)
     17 
     18    This uses the Internet TCP protocol, which provides for
     19    continuous streams of data between the client and server.
     20    If *bind_and_activate* is true, the constructor automatically attempts to
     21    invoke :meth:`~BaseServer.server_bind` and
     22    :meth:`~BaseServer.server_activate`.  The other parameters are passed to
     23    the :class:`BaseServer` base class.
     24 
     25 
     26 .. class:: UDPServer(server_address, RequestHandlerClass, bind_and_activate=True)
     27 
     28    This uses datagrams, which are discrete packets of information that may
     29    arrive out of order or be lost while in transit.  The parameters are
     30    the same as for :class:`TCPServer`.
     31 
     32 
     33 .. class:: UnixStreamServer(server_address, RequestHandlerClass, bind_and_activate=True)
     34            UnixDatagramServer(server_address, RequestHandlerClass, bind_and_activate=True)
     35 
     36    These more infrequently used classes are similar to the TCP and
     37    UDP classes, but use Unix domain sockets; they're not available on
     38    non-Unix platforms.  The parameters are the same as for
     39    :class:`TCPServer`.
     40 
     41 
     42 These four classes process requests :dfn:`synchronously`; each request must be
     43 completed before the next request can be started.  This isn't suitable if each
     44 request takes a long time to complete, because it requires a lot of computation,
     45 or because it returns a lot of data which the client is slow to process.  The
     46 solution is to create a separate process or thread to handle each request; the
     47 :class:`ForkingMixIn` and :class:`ThreadingMixIn` mix-in classes can be used to
     48 support asynchronous behaviour.
     49 
     50 Creating a server requires several steps.  First, you must create a request
     51 handler class by subclassing the :class:`BaseRequestHandler` class and
     52 overriding its :meth:`~BaseRequestHandler.handle` method;
     53 this method will process incoming
     54 requests.  Second, you must instantiate one of the server classes, passing it
     55 the server's address and the request handler class. It is recommended to use
     56 the server in a :keyword:`with` statement. Then call the
     57 :meth:`~BaseServer.handle_request` or
     58 :meth:`~BaseServer.serve_forever` method of the server object to
     59 process one or many requests.  Finally, call :meth:`~BaseServer.server_close`
     60 to close the socket (unless you used a :keyword:`!with` statement).
     61 
     62 When inheriting from :class:`ThreadingMixIn` for threaded connection behavior,
     63 you should explicitly declare how you want your threads to behave on an abrupt
     64 shutdown.  The :class:`ThreadingMixIn` class defines an attribute
     65 *daemon_threads*, which indicates whether or not the server should wait for
     66 thread termination.  You should set the flag explicitly if you would like
     67 threads to behave autonomously; the default is :const:`False`, meaning that
     68 Python will not exit until all threads created by :class:`ThreadingMixIn` have
     69 exited.
     70 
     71 Server classes have the same external methods and attributes, no matter what
     72 network protocol they use.
     73 
     74 
     75 Server Creation Notes
     76 ---------------------
     77 
     78 There are five classes in an inheritance diagram, four of which represent
     79 synchronous servers of four types::
     80 
     81    +------------+
     82    | BaseServer |
     83    +------------+
     84          |
     85          v
     86    +-----------+        +------------------+
     87    | TCPServer |------->| UnixStreamServer |
     88    +-----------+        +------------------+
     89          |
     90          v
     91    +-----------+        +--------------------+
     92    | UDPServer |------->| UnixDatagramServer |
     93    +-----------+        +--------------------+
     94 
     95 Note that :class:`UnixDatagramServer` derives from :class:`UDPServer`, not from
     96 :class:`UnixStreamServer` --- the only difference between an IP and a Unix
     97 stream server is the address family, which is simply repeated in both Unix
     98 server classes.
     99 
    100 
    101 .. class:: ForkingMixIn
    102            ThreadingMixIn
    103 
    104    Forking and threading versions of each type of server can be created
    105    using these mix-in classes.  For instance, :class:`ThreadingUDPServer`
    106    is created as follows::
    107 
    108       class ThreadingUDPServer(ThreadingMixIn, UDPServer):
    109           pass
    110 
    111    The mix-in class comes first, since it overrides a method defined in
    112    :class:`UDPServer`.  Setting the various attributes also changes the
    113    behavior of the underlying server mechanism.
    114 
    115    :class:`ForkingMixIn` and the Forking classes mentioned below are
    116    only available on POSIX platforms that support :func:`~os.fork`.
    117 
    118    :meth:`socketserver.ForkingMixIn.server_close` waits until all child
    119    processes complete, except if
    120    :attr:`socketserver.ForkingMixIn.block_on_close` attribute is false.
    121 
    122    :meth:`socketserver.ThreadingMixIn.server_close` waits until all non-daemon
    123    threads complete, except if
    124    :attr:`socketserver.ThreadingMixIn.block_on_close` attribute is false. Use
    125    daemonic threads by setting
    126    :data:`ThreadingMixIn.daemon_threads` to ``True`` to not wait until threads
    127    complete.
    128 
    129    .. versionchanged:: 3.7
    130 
    131       :meth:`socketserver.ForkingMixIn.server_close` and
    132       :meth:`socketserver.ThreadingMixIn.server_close` now waits until all
    133       child processes and non-daemonic threads complete.
    134       Add a new :attr:`socketserver.ForkingMixIn.block_on_close` class
    135       attribute to opt-in for the pre-3.7 behaviour.
    136 
    137 
    138 .. class:: ForkingTCPServer
    139            ForkingUDPServer
    140            ThreadingTCPServer
    141            ThreadingUDPServer
    142 
    143    These classes are pre-defined using the mix-in classes.
    144 
    145 
    146 To implement a service, you must derive a class from :class:`BaseRequestHandler`
    147 and redefine its :meth:`~BaseRequestHandler.handle` method.
    148 You can then run various versions of
    149 the service by combining one of the server classes with your request handler
    150 class.  The request handler class must be different for datagram or stream
    151 services.  This can be hidden by using the handler subclasses
    152 :class:`StreamRequestHandler` or :class:`DatagramRequestHandler`.
    153 
    154 Of course, you still have to use your head!  For instance, it makes no sense to
    155 use a forking server if the service contains state in memory that can be
    156 modified by different requests, since the modifications in the child process
    157 would never reach the initial state kept in the parent process and passed to
    158 each child.  In this case, you can use a threading server, but you will probably
    159 have to use locks to protect the integrity of the shared data.
    160 
    161 On the other hand, if you are building an HTTP server where all data is stored
    162 externally (for instance, in the file system), a synchronous class will
    163 essentially render the service "deaf" while one request is being handled --
    164 which may be for a very long time if a client is slow to receive all the data it
    165 has requested.  Here a threading or forking server is appropriate.
    166 
    167 In some cases, it may be appropriate to process part of a request synchronously,
    168 but to finish processing in a forked child depending on the request data.  This
    169 can be implemented by using a synchronous server and doing an explicit fork in
    170 the request handler class :meth:`~BaseRequestHandler.handle` method.
    171 
    172 Another approach to handling multiple simultaneous requests in an environment
    173 that supports neither threads nor :func:`~os.fork` (or where these are too
    174 expensive or inappropriate for the service) is to maintain an explicit table of
    175 partially finished requests and to use :mod:`selectors` to decide which
    176 request to work on next (or whether to handle a new incoming request).  This is
    177 particularly important for stream services where each client can potentially be
    178 connected for a long time (if threads or subprocesses cannot be used).  See
    179 :mod:`asyncore` for another way to manage this.
    180 
    181 .. XXX should data and methods be intermingled, or separate?
    182    how should the distinction between class and instance variables be drawn?
    183 
    184 
    185 Server Objects
    186 --------------
    187 
    188 .. class:: BaseServer(server_address, RequestHandlerClass)
    189 
    190    This is the superclass of all Server objects in the module.  It defines the
    191    interface, given below, but does not implement most of the methods, which is
    192    done in subclasses.  The two parameters are stored in the respective
    193    :attr:`server_address` and :attr:`RequestHandlerClass` attributes.
    194 
    195 
    196    .. method:: fileno()
    197 
    198       Return an integer file descriptor for the socket on which the server is
    199       listening.  This function is most commonly passed to :mod:`selectors`, to
    200       allow monitoring multiple servers in the same process.
    201 
    202 
    203    .. method:: handle_request()
    204 
    205       Process a single request.  This function calls the following methods in
    206       order: :meth:`get_request`, :meth:`verify_request`, and
    207       :meth:`process_request`.  If the user-provided
    208       :meth:`~BaseRequestHandler.handle` method of the
    209       handler class raises an exception, the server's :meth:`handle_error` method
    210       will be called.  If no request is received within :attr:`timeout`
    211       seconds, :meth:`handle_timeout` will be called and :meth:`handle_request`
    212       will return.
    213 
    214 
    215    .. method:: serve_forever(poll_interval=0.5)
    216 
    217       Handle requests until an explicit :meth:`shutdown` request.  Poll for
    218       shutdown every *poll_interval* seconds.
    219       Ignores the :attr:`timeout` attribute.  It
    220       also calls :meth:`service_actions`, which may be used by a subclass or mixin
    221       to provide actions specific to a given service.  For example, the
    222       :class:`ForkingMixIn` class uses :meth:`service_actions` to clean up zombie
    223       child processes.
    224 
    225       .. versionchanged:: 3.3
    226          Added ``service_actions`` call to the ``serve_forever`` method.
    227 
    228 
    229    .. method:: service_actions()
    230 
    231       This is called in the :meth:`serve_forever` loop. This method can be
    232       overridden by subclasses or mixin classes to perform actions specific to
    233       a given service, such as cleanup actions.
    234 
    235       .. versionadded:: 3.3
    236 
    237    .. method:: shutdown()
    238 
    239       Tell the :meth:`serve_forever` loop to stop and wait until it does.
    240 
    241 
    242    .. method:: server_close()
    243 
    244       Clean up the server. May be overridden.
    245 
    246 
    247    .. attribute:: address_family
    248 
    249       The family of protocols to which the server's socket belongs.
    250       Common examples are :const:`socket.AF_INET` and :const:`socket.AF_UNIX`.
    251 
    252 
    253    .. attribute:: RequestHandlerClass
    254 
    255       The user-provided request handler class; an instance of this class is created
    256       for each request.
    257 
    258 
    259    .. attribute:: server_address
    260 
    261       The address on which the server is listening.  The format of addresses varies
    262       depending on the protocol family;
    263       see the documentation for the :mod:`socket` module
    264       for details.  For Internet protocols, this is a tuple containing a string giving
    265       the address, and an integer port number: ``('127.0.0.1', 80)``, for example.
    266 
    267 
    268    .. attribute:: socket
    269 
    270       The socket object on which the server will listen for incoming requests.
    271 
    272 
    273    The server classes support the following class variables:
    274 
    275    .. XXX should class variables be covered before instance variables, or vice versa?
    276 
    277    .. attribute:: allow_reuse_address
    278 
    279       Whether the server will allow the reuse of an address.  This defaults to
    280       :const:`False`, and can be set in subclasses to change the policy.
    281 
    282 
    283    .. attribute:: request_queue_size
    284 
    285       The size of the request queue.  If it takes a long time to process a single
    286       request, any requests that arrive while the server is busy are placed into a
    287       queue, up to :attr:`request_queue_size` requests.  Once the queue is full,
    288       further requests from clients will get a "Connection denied" error.  The default
    289       value is usually 5, but this can be overridden by subclasses.
    290 
    291 
    292    .. attribute:: socket_type
    293 
    294       The type of socket used by the server; :const:`socket.SOCK_STREAM` and
    295       :const:`socket.SOCK_DGRAM` are two common values.
    296 
    297 
    298    .. attribute:: timeout
    299 
    300       Timeout duration, measured in seconds, or :const:`None` if no timeout is
    301       desired.  If :meth:`handle_request` receives no incoming requests within the
    302       timeout period, the :meth:`handle_timeout` method is called.
    303 
    304 
    305    There are various server methods that can be overridden by subclasses of base
    306    server classes like :class:`TCPServer`; these methods aren't useful to external
    307    users of the server object.
    308 
    309    .. XXX should the default implementations of these be documented, or should
    310       it be assumed that the user will look at socketserver.py?
    311 
    312    .. method:: finish_request(request, client_address)
    313 
    314       Actually processes the request by instantiating :attr:`RequestHandlerClass` and
    315       calling its :meth:`~BaseRequestHandler.handle` method.
    316 
    317 
    318    .. method:: get_request()
    319 
    320       Must accept a request from the socket, and return a 2-tuple containing the *new*
    321       socket object to be used to communicate with the client, and the client's
    322       address.
    323 
    324 
    325    .. method:: handle_error(request, client_address)
    326 
    327       This function is called if the :meth:`~BaseRequestHandler.handle`
    328       method of a :attr:`RequestHandlerClass` instance raises
    329       an exception.  The default action is to print the traceback to
    330       standard error and continue handling further requests.
    331 
    332       .. versionchanged:: 3.6
    333          Now only called for exceptions derived from the :exc:`Exception`
    334          class.
    335 
    336 
    337    .. method:: handle_timeout()
    338 
    339       This function is called when the :attr:`timeout` attribute has been set to a
    340       value other than :const:`None` and the timeout period has passed with no
    341       requests being received.  The default action for forking servers is
    342       to collect the status of any child processes that have exited, while
    343       in threading servers this method does nothing.
    344 
    345 
    346    .. method:: process_request(request, client_address)
    347 
    348       Calls :meth:`finish_request` to create an instance of the
    349       :attr:`RequestHandlerClass`.  If desired, this function can create a new process
    350       or thread to handle the request; the :class:`ForkingMixIn` and
    351       :class:`ThreadingMixIn` classes do this.
    352 
    353 
    354    .. Is there any point in documenting the following two functions?
    355       What would the purpose of overriding them be: initializing server
    356       instance variables, adding new network families?
    357 
    358    .. method:: server_activate()
    359 
    360       Called by the server's constructor to activate the server.  The default behavior
    361       for a TCP server just invokes :meth:`~socket.socket.listen`
    362       on the server's socket.  May be overridden.
    363 
    364 
    365    .. method:: server_bind()
    366 
    367       Called by the server's constructor to bind the socket to the desired address.
    368       May be overridden.
    369 
    370 
    371    .. method:: verify_request(request, client_address)
    372 
    373       Must return a Boolean value; if the value is :const:`True`, the request will
    374       be processed, and if it's :const:`False`, the request will be denied.  This
    375       function can be overridden to implement access controls for a server. The
    376       default implementation always returns :const:`True`.
    377 
    378 
    379    .. versionchanged:: 3.6
    380       Support for the :term:`context manager` protocol was added.  Exiting the
    381       context manager is equivalent to calling :meth:`server_close`.
    382 
    383 
    384 Request Handler Objects
    385 -----------------------
    386 
    387 .. class:: BaseRequestHandler
    388 
    389    This is the superclass of all request handler objects.  It defines
    390    the interface, given below.  A concrete request handler subclass must
    391    define a new :meth:`handle` method, and can override any of
    392    the other methods.  A new instance of the subclass is created for each
    393    request.
    394 
    395 
    396    .. method:: setup()
    397 
    398       Called before the :meth:`handle` method to perform any initialization actions
    399       required.  The default implementation does nothing.
    400 
    401 
    402    .. method:: handle()
    403 
    404       This function must do all the work required to service a request.  The
    405       default implementation does nothing.  Several instance attributes are
    406       available to it; the request is available as :attr:`self.request`; the client
    407       address as :attr:`self.client_address`; and the server instance as
    408       :attr:`self.server`, in case it needs access to per-server information.
    409 
    410       The type of :attr:`self.request` is different for datagram or stream
    411       services.  For stream services, :attr:`self.request` is a socket object; for
    412       datagram services, :attr:`self.request` is a pair of string and socket.
    413 
    414 
    415    .. method:: finish()
    416 
    417       Called after the :meth:`handle` method to perform any clean-up actions
    418       required.  The default implementation does nothing.  If :meth:`setup`
    419       raises an exception, this function will not be called.
    420 
    421 
    422 .. class:: StreamRequestHandler
    423            DatagramRequestHandler
    424 
    425    These :class:`BaseRequestHandler` subclasses override the
    426    :meth:`~BaseRequestHandler.setup` and :meth:`~BaseRequestHandler.finish`
    427    methods, and provide :attr:`self.rfile` and :attr:`self.wfile` attributes.
    428    The :attr:`self.rfile` and :attr:`self.wfile` attributes can be
    429    read or written, respectively, to get the request data or return data
    430    to the client.
    431 
    432    The :attr:`rfile` attributes of both classes support the
    433    :class:`io.BufferedIOBase` readable interface, and
    434    :attr:`DatagramRequestHandler.wfile` supports the
    435    :class:`io.BufferedIOBase` writable interface.
    436 
    437    .. versionchanged:: 3.6
    438       :attr:`StreamRequestHandler.wfile` also supports the
    439       :class:`io.BufferedIOBase` writable interface.
    440 
    441 
    442 Examples
    443 --------
    444 
    445 :class:`socketserver.TCPServer` Example
    446 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    447 
    448 This is the server side::
    449 
    450    import socketserver
    451 
    452    class MyTCPHandler(socketserver.BaseRequestHandler):
    453        """
    454        The request handler class for our server.
    455 
    456        It is instantiated once per connection to the server, and must
    457        override the handle() method to implement communication to the
    458        client.
    459        """
    460 
    461        def handle(self):
    462            # self.request is the TCP socket connected to the client
    463            self.data = self.request.recv(1024).strip()
    464            print("{} wrote:".format(self.client_address[0]))
    465            print(self.data)
    466            # just send back the same data, but upper-cased
    467            self.request.sendall(self.data.upper())
    468 
    469    if __name__ == "__main__":
    470        HOST, PORT = "localhost", 9999
    471 
    472        # Create the server, binding to localhost on port 9999
    473        with socketserver.TCPServer((HOST, PORT), MyTCPHandler) as server:
    474            # Activate the server; this will keep running until you
    475            # interrupt the program with Ctrl-C
    476            server.serve_forever()
    477 
    478 An alternative request handler class that makes use of streams (file-like
    479 objects that simplify communication by providing the standard file interface)::
    480 
    481    class MyTCPHandler(socketserver.StreamRequestHandler):
    482 
    483        def handle(self):
    484            # self.rfile is a file-like object created by the handler;
    485            # we can now use e.g. readline() instead of raw recv() calls
    486            self.data = self.rfile.readline().strip()
    487            print("{} wrote:".format(self.client_address[0]))
    488            print(self.data)
    489            # Likewise, self.wfile is a file-like object used to write back
    490            # to the client
    491            self.wfile.write(self.data.upper())
    492 
    493 The difference is that the ``readline()`` call in the second handler will call
    494 ``recv()`` multiple times until it encounters a newline character, while the
    495 single ``recv()`` call in the first handler will just return what has been sent
    496 from the client in one ``sendall()`` call.
    497 
    498 
    499 This is the client side::
    500 
    501    import socket
    502    import sys
    503 
    504    HOST, PORT = "localhost", 9999
    505    data = " ".join(sys.argv[1:])
    506 
    507    # Create a socket (SOCK_STREAM means a TCP socket)
    508    with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as sock:
    509        # Connect to server and send data
    510        sock.connect((HOST, PORT))
    511        sock.sendall(bytes(data + "\n", "utf-8"))
    512 
    513        # Receive data from the server and shut down
    514        received = str(sock.recv(1024), "utf-8")
    515 
    516    print("Sent:     {}".format(data))
    517    print("Received: {}".format(received))
    518 
    519 
    520 The output of the example should look something like this:
    521 
    522 Server:
    523 
    524 .. code-block:: shell-session
    525 
    526    $ python TCPServer.py
    527    127.0.0.1 wrote:
    528    b'hello world with TCP'
    529    127.0.0.1 wrote:
    530    b'python is nice'
    531 
    532 Client:
    533 
    534 .. code-block:: shell-session
    535 
    536    $ python TCPClient.py hello world with TCP
    537    Sent:     hello world with TCP
    538    Received: HELLO WORLD WITH TCP
    539    $ python TCPClient.py python is nice
    540    Sent:     python is nice
    541    Received: PYTHON IS NICE
    542 
    543 
    544 :class:`socketserver.UDPServer` Example
    545 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    546 
    547 This is the server side::
    548 
    549    import socketserver
    550 
    551    class MyUDPHandler(socketserver.BaseRequestHandler):
    552        """
    553        This class works similar to the TCP handler class, except that
    554        self.request consists of a pair of data and client socket, and since
    555        there is no connection the client address must be given explicitly
    556        when sending data back via sendto().
    557        """
    558 
    559        def handle(self):
    560            data = self.request[0].strip()
    561            socket = self.request[1]
    562            print("{} wrote:".format(self.client_address[0]))
    563            print(data)
    564            socket.sendto(data.upper(), self.client_address)
    565 
    566    if __name__ == "__main__":
    567        HOST, PORT = "localhost", 9999
    568        with socketserver.UDPServer((HOST, PORT), MyUDPHandler) as server:
    569            server.serve_forever()
    570 
    571 This is the client side::
    572 
    573    import socket
    574    import sys
    575 
    576    HOST, PORT = "localhost", 9999
    577    data = " ".join(sys.argv[1:])
    578 
    579    # SOCK_DGRAM is the socket type to use for UDP sockets
    580    sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
    581 
    582    # As you can see, there is no connect() call; UDP has no connections.
    583    # Instead, data is directly sent to the recipient via sendto().
    584    sock.sendto(bytes(data + "\n", "utf-8"), (HOST, PORT))
    585    received = str(sock.recv(1024), "utf-8")
    586 
    587    print("Sent:     {}".format(data))
    588    print("Received: {}".format(received))
    589 
    590 The output of the example should look exactly like for the TCP server example.
    591 
    592 
    593 Asynchronous Mixins
    594 ~~~~~~~~~~~~~~~~~~~
    595 
    596 To build asynchronous handlers, use the :class:`ThreadingMixIn` and
    597 :class:`ForkingMixIn` classes.
    598 
    599 An example for the :class:`ThreadingMixIn` class::
    600 
    601    import socket
    602    import threading
    603    import socketserver
    604 
    605    class ThreadedTCPRequestHandler(socketserver.BaseRequestHandler):
    606 
    607        def handle(self):
    608            data = str(self.request.recv(1024), 'ascii')
    609            cur_thread = threading.current_thread()
    610            response = bytes("{}: {}".format(cur_thread.name, data), 'ascii')
    611            self.request.sendall(response)
    612 
    613    class ThreadedTCPServer(socketserver.ThreadingMixIn, socketserver.TCPServer):
    614        pass
    615 
    616    def client(ip, port, message):
    617        with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as sock:
    618            sock.connect((ip, port))
    619            sock.sendall(bytes(message, 'ascii'))
    620            response = str(sock.recv(1024), 'ascii')
    621            print("Received: {}".format(response))
    622 
    623    if __name__ == "__main__":
    624        # Port 0 means to select an arbitrary unused port
    625        HOST, PORT = "localhost", 0
    626 
    627        server = ThreadedTCPServer((HOST, PORT), ThreadedTCPRequestHandler)
    628        with server:
    629            ip, port = server.server_address
    630 
    631            # Start a thread with the server -- that thread will then start one
    632            # more thread for each request
    633            server_thread = threading.Thread(target=server.serve_forever)
    634            # Exit the server thread when the main thread terminates
    635            server_thread.daemon = True
    636            server_thread.start()
    637            print("Server loop running in thread:", server_thread.name)
    638 
    639            client(ip, port, "Hello World 1")
    640            client(ip, port, "Hello World 2")
    641            client(ip, port, "Hello World 3")
    642 
    643            server.shutdown()
    644 
    645 
    646 The output of the example should look something like this:
    647 
    648 .. code-block:: shell-session
    649 
    650    $ python ThreadedTCPServer.py
    651    Server loop running in thread: Thread-1
    652    Received: Thread-2: Hello World 1
    653    Received: Thread-3: Hello World 2
    654    Received: Thread-4: Hello World 3
    655 
    656 
    657 The :class:`ForkingMixIn` class is used in the same way, except that the server
    658 will spawn a new process for each request.
    659 Available only on POSIX platforms that support :func:`~os.fork`.
    660 
    661