Dieses Tutorial führt Python -Steckdosen vor und demonstriert, dass HTTP -Server und Clients mithilfe des socket
-Moduls erstellt werden. Außerdem werden Tornado, eine Python-Netzwerkbibliothek, ideal für Langstrecken, Websockets und Anwendungen, die anhaltende Benutzerverbindungen benötigt werden, ideal.
Sockets verstehen
Ein Socket fungiert als Kommunikationskanal zwischen zwei Anwendungen, sei es auf derselben Maschine oder über ein Netzwerk. Im Wesentlichen handelt es sich um eine Verbindungsverbindung zwischen einem Server und einem Client. Der Server enthält Informationen, die vom Client angefordert werden. Ihr Browser verwendet beispielsweise einen Socket, um eine Verbindung zu einem Webserver herzustellen, wenn Sie eine Webseite besuchen.
Das socket
-Modul
Socket -Erstellung verwendet die Funktion socket.socket()
:
import socket s = socket.socket(socket_family, socket_type, protocol=0)
Argumente:
socket_family
: Adressfamilie (z. B. socket.AF_INET
für ipv4, socket.AF_INET6
für ipv6). socket_type
: Socket -Typ (z. B. socket.SOCK_STREAM
für tcp, socket.SOCK_DGRAM
für udp). protocol
: Normalerweise standardmäßig 0. Sobald Sie ein Socket -Objekt haben, können Sie einen Server oder Client mit seinen Methoden erstellen.
Erstellen eines einfachen Clients
KLAND -METHODEN:
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.connect()
: stellt eine TCP -Verbindung her. Beispiel:
import socket stream_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) server = "localhost" port = 8080 server_address = (server, port) stream_socket.connect(server_address) message = 'message' stream_socket.sendall(message.encode()) data = stream_socket.recv(10) print(data) stream_socket.close()
Erstellen eines einfachen Servers
Key Server -Methoden:
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.bind()
: weist dem Socket eine Adresse (Hostname, Port) zu. s.listen()
: Beginnt an TCP -Verbindungen zu hören. s.accept()
: Akzeptiert eine TCP -Client -Verbindung. Beispiel:
import socket sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) host = 'localhost' port = 8080 sock.bind((host, port)) sock.listen(1) print('Waiting for a connection') connection, client = sock.accept() print(client, 'connected') data = connection.recv(16) print('Received "%s"' % data) if data: connection.sendall(data) else: print('No data from', client) connection.close()
Führen Sie den Client und Server in separaten Terminals für die Kommunikation aus. Verwenden Sie netstat -ntlp
(oder einen ähnlichen Befehl für Ihr Betriebssystem), um die Portnutzung zu überprüfen.
Das Tornado -Framework
Tornado ist ein Python -Web -Framework und eine asynchrone Networking -Bibliothek. Das nicht blockierende E/A übernimmt viele gleichzeitige Verbindungen und ist für langwierige Wäsche, Websockets und Anwendungen geeignet, die anhaltende Verbindungen erfordern.
Ein einfaches Tornado -WebSocket -Beispiel:
import tornado.ioloop import tornado.web class ApplicationHandler(tornado.web.RequestHandler): def get(self): self.write("""<title>Tornado Framework</title><h2>Welcome to the Tornado framework</h2>""") if __name__ == "__main__": application = tornado.web.Application([ (r"/", ApplicationHandler), ]) application.listen(5001) tornado.ioloop.IOLoop.instance().start()
Tornado integriert sich auch in asyncio
und ermöglicht die Verwendung beider Bibliotheken innerhalb derselben Ereignisschleife.
synchron und asynchrones Programmieren
synchrones Programmieren führt auf die Aufgaben nacheinander aus, während die asynchrone Programmierung eine gleichzeitige Ausführung der Aufgaben ermöglicht, ohne darauf zu warten, dass andere fertiggestellt werden. Die asynchrone Programmierung ist vorteilhaft, wenn Sie mit E/O-gebundenen Operationen wie API-Aufrufen zu tun, Verzögerungen zu verhindern und die Reaktionsfähigkeit der Anwendungen zu verbessern. Die asynchronen Funktionen von Tornado sind besonders nützlich, um mehrere API -Anfragen gleichzeitig zu behandeln.
Schlussfolgerung
Dieses Tutorial bildete eine Grundlage für die Socket -Programmierung in Python und zeigte eine einfache Server-/Client -Erstellung. Eine weitere Untersuchung des socket
-Moduls und Tornado erhöht Ihre Networking -Funktionen. Denken Sie daran, die offizielle Python -Dokumentation zu konsultieren, um detailliertere Informationen zu erhalten.
(Bild des Tornado -Webserver -Ausgangs - Ersetzen
Das obige ist der detaillierte Inhalt vonEinführung in die Netzwerkprogrammierung in Python. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!