Heim >Backend-Entwicklung >Python-Tutorial >Einführung in die Netzwerkprogrammierung in Python

Einführung in die Netzwerkprogrammierung in Python

William Shakespeare
William ShakespeareOriginal
2025-03-05 10:36:10980Durchsuche

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.

Introduction to Network Programming in Python (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!

Stellungnahme:
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