Как запускать скрученные веб-приложения в их собственных потоках, не используя twistd

У меня есть довольно богатое приложение на Python, и я не хочу его реструктурировать только для того, чтобы обнажить некоторые конечные точки http. Я просто хочу предоставить их через набор потоков, которые прослушивают эти порты через http.

Есть несколько уместных вопросов, но они довольно старые и не совсем то, что я ищу:

Что было бы «современным» подходом, и он предполагал бы просто запуск потоков - или даже лучших записей из threadpool - для включения twisted в существующее приложение?


person WestCoastProjects    schedule 31.03.2020    source источник


Ответы (1)


См. https://github.com/itamarst/crochet.

Вот пример из документации:

#!/usr/bin/python
"""
Do a DNS lookup using Twisted's APIs.
"""
from __future__ import print_function

# The Twisted code we'll be using:
from twisted.names import client

from crochet import setup, wait_for
setup()


# Crochet layer, wrapping Twisted's DNS library in a blocking call.
@wait_for(timeout=5.0)
def gethostbyname(name):
    """Lookup the IP of a given hostname.

    Unlike socket.gethostbyname() which can take an arbitrary amount of time
    to finish, this function will raise crochet.TimeoutError if more than 5
    seconds elapse without an answer being received.
    """
    d = client.lookupAddress(name)
    d.addCallback(lambda result: result[0][0].payload.dottedQuad())
    return d


if __name__ == '__main__':
    # Application code using the public API - notice it works in a normal
    # blocking manner, with no event loop visible:
    import sys
    name = sys.argv[1]
    ip = gethostbyname(name)
    print(name, "->", ip)
person Jean-Paul Calderone    schedule 31.03.2020