Heim Backend-Entwicklung Python-Tutorial Programmierung mit der Coroutine von Tornado

Programmierung mit der Coroutine von Tornado

Oct 17, 2016 pm 02:13 PM

Nach der Veröffentlichung von tornado3 wurde das Konzept der Coroutine in der asynchronen Programmierung gestärkt, es ersetzte die ursprüngliche gen.engine und wurde zur aktuellen gen.coroutine. Dieser Dekorator wurde ursprünglich entwickelt, um die asynchrone Programmierung in Tornado zu vereinfachen. Vermeiden Sie das Schreiben von Rückruffunktionen, um die Entwicklung besser mit dem normalen logischen Denken in Einklang zu bringen. Ein einfaches Beispiel lautet wie folgt:


class MaindHandler(web.RequestHandler):

@asynchronous

@gen.coroutine

def post(self):

client = AsyncHTTPClient()

resp = yield client.fetch(https://api.github.com/users")

if resp.code == 200:

resp = escape.json_decode(resp.body)

self.write(json.dumps(resp, indent=4, Separatoren=( ' ,', ':')))

else:

resp = {"message": "error when fetch etwas"}

self.write(json. dumps (bzw. indent=4, Separatoren={',', ':')))

self.finish()

Nach der yield-Anweisung registriert ioloop das Ereignis und wartet Bis die Ausführung nach der Rückkehr von resp. fortgesetzt wird, wird hier json.dumps anstelle von escape.json_encode verwendet, da beim Erstellen einer REST-API häufig über den Browser auf JSON zugegriffen wird .dumps zum Formatieren der Daten ist für Benutzer dieses Stils benutzerfreundlicher, wenn sie eine Pull-Anfrage senden Der Autor antwortete, dass Escape nicht die Absicht habe, alle JSON-Funktionen selbst bereitzustellen


Gen >

In einem früheren Blog habe ich erwähnt, dass Sie zur Nutzung der asynchronen Funktion von Tornado eine asynchrone Bibliothek verwenden müssen, da sonst ein einzelner Prozess blockiert wird und der asynchrone Effekt überhaupt nicht erzielt wird. Die am häufigsten verwendete asynchrone Bibliothek in Tornado ist der eigene AsyncHTTPClient und die darauf basierende OpenID-Anmeldeüberprüfungsschnittstelle. Weitere asynchrone Bibliotheken finden Sie hier. Einschließlich des häufig verwendeten MongoDB-Treibers.


Nach Version 3.0 rückt das gen.coroutine-Modul stärker in den Vordergrund. Der Coroutine-Dekorator kann asynchrone Programmierung, die auf Rückrufen basiert, wie synchrone Programmierung aussehen lassen. Darunter ist die Send-Funktion des Generators in Python. In Generatoren wird das Schlüsselwort yield oft mit return in einer normalen Funktion verglichen. Es kann als Iterator verwendet werden, sodass next() verwendet werden kann, um das Ergebnis von yield zurückzugeben. Es gibt jedoch eine andere Möglichkeit, den Generator zu verwenden, nämlich die Sendemethode. Innerhalb des Generators kann das Ergebnis von yield einer Variablen zugewiesen werden und dieser Wert wird über den externen Generator-Client gesendet. Geben Sie ein Beispiel:


def test_yield():

pirnt "test yeild"


sagt = (yield)

print sagt

if __name__ == "__main__":

client = test_yield()


client.next()

client.send("hello world")

Die Ausgabeergebnisse lauten wie folgt:

test yeild

Hallo Welt


Eine bereits laufende Funktion wird angehalten, bis der Client, der sie aufruft, die Sendemethode verwendet und die ursprüngliche Funktion weiterhin ausgeführt wird. Die gen.coroutine-Methode besteht hier darin, die erforderlichen Vorgänge asynchron auszuführen und dann auf die Rückgabe des Ergebnisses zu warten, bevor sie an die ursprüngliche Funktion gesendet wird, die weiterhin ausgeführt wird. Auf diese Weise wird der synchron geschriebene Code erreicht Auswirkung der asynchronen Ausführung.

Tornado-asynchrone Programmierung


Verwenden Sie Coroutine, um asynchrone Programmierung mit Funktionstrennung zu implementieren. Die Details lauten wie folgt:


@gen.coroutine

def post(self):


client = AsyncHTTPClient()

resp = yield client.fetch("https://api.github.com/users")

if resp == 200:

body = escape.json_decode(resy .body)

else:

body = {"message": "client fetch error"}

logger.error("client fetch error %d, %s" % (resp .code, resp.message))

self.write(escape.json_encode(body))

self.finish()

kann danach so werden Wechsel zu einer Funktion ;

@gen.coroutime

def post(self):


resp = yield GetUser()

self.write(resp)

@gen.coroutine

def GetUser():


client = AsyncHTTPClient( )

resp = yield client.fetch("https://api.github.com/users")

if resp.code == 200:

resp = escape.json_decode( resp.body)

else:

resp = {"message": "fetch client error"}

logger.error("client fetch error % d, %s " % (resp.code, resp.message))

raise gen.Return(resp)

Wenn Asynchron in einer Funktion gekapselt ist, stellt das Gen-Modul anstelle des Schlüsselworts „return“ für die Rückgabe wie bei einem normalen Programm eine Methode „gen.Return“ bereit. Dies wird durch die Raise-Methode erreicht. Dies hängt auch damit zusammen, dass die Umsetzung über einen Generator erfolgt.


Verwenden Sie Coroutine, um geplante Aufgaben auszuführen


In Tornado gibt es eine solche Methode:


tornado.ioloop.IOLoop.instance().add_timeout()

Diese Methode ist eine nicht blockierende Version von time.sleep, die zwei Parameter akzeptiert: eine Zeitlänge und eine Funktion. Gibt die Zeitspanne an, nach der die Funktion aufgerufen wird. Hier basiert es auf ioloop und ist daher nicht blockierend. Diese Methode wird häufig bei der Programmierung langer Clientverbindungen und Rückruffunktionen verwendet. Es ist jedoch nutzlos, es zum Ausführen einiger geplanter Aufgaben zu verwenden. Normalerweise ist es nicht erforderlich, es beim Ausführen geplanter Aufgaben zu verwenden. Aber als ich Heroku benutzte, stellte ich fest, dass ich, wenn ich keine Kreditkarte registrierte, nur das Hosten einer einfachen Webanwendung nutzen konnte. Geplante Aufgaben zur Ausführung können nicht hinzugefügt werden. Also habe ich mir eine solche Methode ausgedacht. Hier verwende ich es hauptsächlich, um in regelmäßigen Abständen Daten über die Github-API-Schnittstelle abzurufen. Die Verwendungsmethode ist wie folgt:


Decorator


def sync_loop_call(delta=60 * ​​​​1000):

"""

Warte auf func down und verarbeite dann add_timeout

"""

def wrap_loop(func):

@ wraps( Func)

@geen.coroutine

DEF WRAP_FUNC (*ARGS, ** KWARGS):

Options.logger.info ("Funktion %R Start AT % D" %

                                                                                                                                                                                                                                                               . (func.__name__, e))

Optionen . Logger.info ("Funktion %R Ende AT %D" %

(Func .__ Name__, int (Time.time ())))

tornado.ioloop.instance ( ).add_timeout(

datetime.timedelta(milliseconds=delta),

wrap_func)

return wrap_func

return wrap_loop

Task Function

@sync_loop_call(delta=10 * 1000)

def worker():

"""

Etwas tun


" ""

Aufgabe hinzufügen

if __name__ == "__main__":

worker ()

app. listen(options.port)

tornado.ioloop.IOLoop.instance().start()


Danach wird beim Start der Webanwendung die geplante Aufgabe entsprechend ausgeführt, und weil Da sie ereignisbasiert ist und asynchron ausgeführt wird, hat sie keinen Einfluss auf den normalen Betrieb des Webdienstes. Natürlich kann die Aufgabe nicht blockierend oder rechenintensiv sein. Ich erfasse hier hauptsächlich Daten und verwende die asynchrone Erfassungsmethode, die mit Tornado geliefert wird.

Im Dekorator sync_loop_call habe ich den Dekorator @gen.coroutine zur Funktion wrap_func hinzugefügt, der sicherstellt, dass add_timeout erst ausgeführt wird, nachdem die Funktion yeild ausgeführt wurde . Ohne @gen.coroutine-Dekorator. Dann wird add_timeout ausgeführt, ohne auf die Rückkehr von yeild zu warten.

Vollständige Beispiele finden Sie auf meinem Github. Dieses Projekt basiert auf Heroku. Wird verwendet, um Github-Benutzeraktivitätsrankings und regionale Benutzerverteilung anzuzeigen. Sie können Github-Data zur Ansicht besuchen. Da Heroku in China blockiert ist, müssen Sie über die Mauer klettern, um darauf zuzugreifen.


Zusammenfassung


Tornado ist ein nicht blockierender Webserver und ein Webframework, aber wenn Sie es verwenden, können Sie dies tun Nur asynchrone Bibliotheken können ihre asynchronen Funktionen wirklich nutzen. Da die App selbst jedoch nicht sehr anspruchsvoll ist, gibt es natürlich kein Problem, wenn die Blockierung nicht besonders schwerwiegend ist. Wenn Sie außerdem das Coroutine-Modul für die asynchrone Programmierung verwenden und eine Funktion in eine Funktion einkapselt, wird dieser Fehler auch dann nicht ausgelöst, wenn während der Ausführung der Funktion ein Fehler auftritt, wenn er nicht abgefangen wird, was das Debuggen sehr erschwert.


Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Wie löste ich das Problem der Berechtigungen beim Betrachten der Python -Version in Linux Terminal? Wie löste ich das Problem der Berechtigungen beim Betrachten der Python -Version in Linux Terminal? Apr 01, 2025 pm 05:09 PM

Lösung für Erlaubnisprobleme beim Betrachten der Python -Version in Linux Terminal Wenn Sie versuchen, die Python -Version in Linux Terminal anzuzeigen, geben Sie Python ein ...

Wie kann ich die gesamte Spalte eines Datenrahmens effizient in einen anderen Datenrahmen mit verschiedenen Strukturen in Python kopieren? Wie kann ich die gesamte Spalte eines Datenrahmens effizient in einen anderen Datenrahmen mit verschiedenen Strukturen in Python kopieren? Apr 01, 2025 pm 11:15 PM

Bei der Verwendung von Pythons Pandas -Bibliothek ist das Kopieren von ganzen Spalten zwischen zwei Datenrahmen mit unterschiedlichen Strukturen ein häufiges Problem. Angenommen, wir haben zwei Daten ...

Wie lehre ich innerhalb von 10 Stunden die Grundlagen für Computer-Anfänger-Programmierbasis in Projekt- und problemorientierten Methoden? Wie lehre ich innerhalb von 10 Stunden die Grundlagen für Computer-Anfänger-Programmierbasis in Projekt- und problemorientierten Methoden? Apr 02, 2025 am 07:18 AM

Wie lehre ich innerhalb von 10 Stunden die Grundlagen für Computer -Anfänger für Programmierungen? Wenn Sie nur 10 Stunden Zeit haben, um Computer -Anfänger zu unterrichten, was Sie mit Programmierkenntnissen unterrichten möchten, was würden Sie dann beibringen ...

Wie erstelle ich dynamisch ein Objekt über eine Zeichenfolge und rufe seine Methoden in Python auf? Wie erstelle ich dynamisch ein Objekt über eine Zeichenfolge und rufe seine Methoden in Python auf? Apr 01, 2025 pm 11:18 PM

Wie erstellt in Python ein Objekt dynamisch über eine Zeichenfolge und ruft seine Methoden auf? Dies ist eine häufige Programmieranforderung, insbesondere wenn sie konfiguriert oder ausgeführt werden muss ...

Wie hört Uvicorn kontinuierlich auf HTTP -Anfragen ohne Serving_forver () an? Wie hört Uvicorn kontinuierlich auf HTTP -Anfragen ohne Serving_forver () an? Apr 01, 2025 pm 10:51 PM

Wie hört Uvicorn kontinuierlich auf HTTP -Anfragen an? Uvicorn ist ein leichter Webserver, der auf ASGI basiert. Eine seiner Kernfunktionen ist es, auf HTTP -Anfragen zu hören und weiterzumachen ...

Was sind einige beliebte Python -Bibliotheken und ihre Verwendung? Was sind einige beliebte Python -Bibliotheken und ihre Verwendung? Mar 21, 2025 pm 06:46 PM

In dem Artikel werden beliebte Python-Bibliotheken wie Numpy, Pandas, Matplotlib, Scikit-Learn, TensorFlow, Django, Flask und Anfragen erörtert, die ihre Verwendung in wissenschaftlichen Computing, Datenanalyse, Visualisierung, maschinellem Lernen, Webentwicklung und h beschreiben

Wie kann man vom Browser vermeiden, wenn man überall Fiddler für das Lesen des Menschen in der Mitte verwendet? Wie kann man vom Browser vermeiden, wenn man überall Fiddler für das Lesen des Menschen in der Mitte verwendet? Apr 02, 2025 am 07:15 AM

Wie kann man nicht erkannt werden, wenn Sie Fiddlereverywhere für Man-in-the-Middle-Lesungen verwenden, wenn Sie FiddLereverywhere verwenden ...

See all articles