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

Einführung in die Netzwerkprogrammierung in Python

William Shakespeare
Freigeben: 2025-03-05 10:36:10
Original
973 Leute haben es durchsucht

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)
Nach dem Login kopieren

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()
Nach dem Login kopieren

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()
Nach dem Login kopieren

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()
Nach dem Login kopieren

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!

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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage