Maison >développement back-end >Tutoriel Python >Introduction à la programmation réseau dans Python

Introduction à la programmation réseau dans Python

William Shakespeare
William Shakespeareoriginal
2025-03-05 10:36:10982parcourir

Ce tutoriel présente des sockets Python et démontre la création de serveurs et de clients HTTP à l'aide du module socket. Il explore également Tornado, une bibliothèque de réseautage Python idéal pour le retrait à long terme, les webockets et les applications nécessitant des connexions utilisateur persistantes.

Comprendre les sockets

Un socket agit comme un canal de communication entre deux applications, que ce soit sur la même machine ou sur un réseau. Essentiellement, c'est un lien de connexion entre un serveur et un client; Le serveur fournit des informations demandées par le client. Par exemple, votre navigateur utilise une prise pour se connecter à un serveur Web lorsque vous visitez une page Web.

le module socket

La création de socket utilise la fonction socket.socket():

import socket
s = socket.socket(socket_family, socket_type, protocol=0)

Arguments:

  • socket_family : La famille d'adresses (par exemple, socket.AF_INET pour ipv4, socket.AF_INET6 pour ipv6).
  • socket_type : type de socket (par exemple, socket.SOCK_STREAM pour TCP, socket.SOCK_DGRAM pour UDP).
  • protocol : généralement par défaut 0.

Une fois que vous avez un objet Socket, vous pouvez créer un serveur ou un client en utilisant ses méthodes.

Création d'un client simple

Méthodes du client clé:

  • s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
  • s.connect(): établit une connexion TCP.

Exemple:

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()

Construire un serveur simple

Méthodes de serveur de clés:

  • s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
  • s.bind(): attribue une adresse (nom d'hôte, port) sur la prise.
  • s.listen(): commence à écouter les connexions TCP.
  • s.accept(): accepte une connexion client TCP.

Exemple:

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()

Exécutez le client et le serveur dans des terminaux séparés pour la communication. Utilisez netstat -ntlp (ou une commande similaire pour votre système d'exploitation) pour vérifier l'utilisation du port.

Le framework de tornade

Tornado est un framework Web Python et une bibliothèque de réseautage asynchrone. Son E / S non bloquante gère de nombreuses connexions simultanées, ce qui le rend adapté à un interclinaison à longue, à Websockets et à des applications nécessitant des connexions persistantes.

Un exemple de Tornado simple Exemple:

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 s'intègre également à asyncio, permettant l'utilisation des deux bibliothèques dans la même boucle d'événements.

Synchrones vs programmes asynchrones

La programmation synchrone exécute les tâches séquentiellement, tandis que la programmation asynchrone permet l'exécution de la tâche simultanée sans attendre que d'autres se terminent. La programmation asynchrone est avantageuse lorsqu'elle traite des opérations liées aux E / S comme les appels d'API, la prévention des retards et l'amélioration de la réactivité des applications. Les capacités asynchrones de la tornade sont particulièrement utiles pour gérer plusieurs demandes d'API simultanément.

Conclusion

Ce tutoriel a fourni une base pour la programmation de socket dans Python et a démontré une création de serveur / client simple. Une exploration plus approfondie du module socket et de la tornade améliorera vos capacités de réseautage. N'oubliez pas de consulter la documentation officielle Python pour des informations plus détaillées.

Introduction to Network Programming in Python (Image de la sortie du serveur de tornade - Remplacez par URL d'image réelle si disponible)

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn