tornado.netutil — Miscellaneous network utilities¶

    bindsockets(_port, address=None, family=0, backlog=128, flags=None, reuse_port=False)[源代码]

    Creates listening sockets bound to the given port and address.

    Returns a list of socket objects (multiple sockets are returned ifthe given address maps to multiple IP addresses, which is most commonfor mixed IPv4 and IPv6 use).

    Address may be either an IP address or hostname. If it’s a hostname,the server will listen on all IP addresses associated with thename. Address may be an empty string or None to listen on allavailable interfaces. Family may be set to either socket.AF_INETor to restrict to IPv4 or IPv6 addresses, otherwiseboth will be used if available.

    The backlog argument has the same meaning as forsocket.listen().

    flags is a bitmask of AI* flags to , likesocket.AI_PASSIVE | socket.AI_NUMERICHOST.

    reuse_port option sets SO_REUSEPORT option for every socketin the list. If your platform doesn’t support this option ValueError willbe raised.
    tornado.netutil.bind_unix_socket(_file, mode=384, backlog=128)[源代码]

    Creates a listening unix socket.

    If a socket with the given name already exists, it will be deleted.If any other file with that name exists, an exception will beraised.

    Returns a socket object (not a list of socket objects likebind_sockets)
    tornado.netutil.addaccept_handler(_sock, callback, io_loop=None)

    Adds an event handler to accept new connections on sock.

    When a connection is accepted, callback(connection, address) willbe run (connection is a socket object, and address is theaddress of the other end of the connection). Note that this signatureis different from the callback(fd, events) signature used forIOLoop handlers.


    在 4.1 版更改: The ioloop argument is deprecated.

    tornado.netutil.(_ip)

    Returns true if the given string is a well-formed IP address.

    Supports IPv4 and IPv6.
    class tornado.netutil.Resolver

    Configurable asynchronous DNS resolver interface.

    By default, a blocking implementation is used (which simply calls). An alternative implementation can bechosen with the Resolver.configureclass method:







    The implementations of this interface included with Tornado are

    -
    - tornado.netutil.ThreadedResolver
    -
    - tornado.platform.twisted.TwistedResolver
    -
    resolve(host, port, family=0, callback=None)[源代码]

    Resolves an address.

    The host argument is a string which may be a hostname or aliteral IP address.

    Returns a Future whose result is a list of (family,address) pairs, where address is a tuple suitable to pass to (i.e. a (host,
    port)
    pair for IPv4; additional fields may be present forIPv6). If a callback is passed, it will be run with theresult as an argument when it is complete.

    |引发:
    |——-
    |IOError – if the address cannot be resolved.



    在 4.4 版更改: Standardized all implementations to raise .

    close()[源代码]

    Closes the Resolver, freeing any resources used.


    3.1 新版功能.

    class tornado.netutil.ExecutorResolver

    Resolver implementation using a .

    Use this instead of ThreadedResolver when you require additionalcontrol over the executor being used.

    The executor will be shut down when the resolver is closed unlesscloseresolver=False; use this if you want to reuse the sameexecutor elsewhere.


    在 4.1 版更改: The io_loop argument is deprecated.

    _class tornado.netutil.BlockingResolver

    Default implementation, using socket.getaddrinfo.

    The will be blocked during the resolution, although thecallback will not be run until the next iteration.
    class tornado.netutil.ThreadedResolver

    Multithreaded non-blocking implementation.

    Requires the concurrent.futures package to be installed(available in the standard library since Python 3.2,installable with pip install futures in older versions).

    The thread pool size can be configured with:



    1. Resolver.configure('tornado.netutil.ThreadedResolver',
      numthreads=10)





    在 3.1 版更改: All ThreadedResolvers share a single thread pool, whosesize is set by the first one to be created.

    _class tornado.netutil.OverrideResolver

    Wraps a resolver with a mapping of overrides.

    This can be used to make local DNS changes (e.g. for testing)without modifying system-wide settings.

    The mapping can contain either host strings or host-port pairs.
    tornado.netutil.ssloptions_to_context(_ssl_options)

    Try to convert an ssloptions dictionary to an object.

    The ssl_options dictionary contains keywords to be passed tossl.wrap_socket. In Python 2.7.9+, objects canbe used instead. This function converts the dict form to itsSSLContext equivalent, and may be used when a component whichaccepts both forms needs to upgrade to the versionto use features like SNI or NPN.
    tornado.netutil.ssl_wrap_socket(_socket, ssl_options, server_hostname=None, **kwargs)[源代码]

    Returns an ssl.SSLSocket wrapping the given socket.

    ssl_options may be either an ssl.SSLContext object or adictionary (as accepted by ). Additionalkeyword arguments are passed to wrap_socket (either the method or the module function asappropriate).