Maison > développement back-end > Tutoriel Python > Bibliothèques WebSocket Olawerful Python pour la communication en temps réel: guide expert

Bibliothèques WebSocket Olawerful Python pour la communication en temps réel: guide expert

Barbara Streisand
Libérer: 2025-01-29 00:16:09
original
423 Les gens l'ont consulté

owerful Python WebSocket Libraries for Real-Time Communication: Expert Guide

En tant qu'auteur prolifique, je vous invite à explorer ma vaste collection de livres sur Amazon. N'oubliez pas de me suivre sur Medium pour des mises à jour régulières et de montrer votre soutien. Votre encouragement est inestimable!

Les bibliothèques WebSocket robustes de Python ont transformé le développement d'applications Web en temps réel. S'appuyant sur des années d'expérience, je présente cinq bibliothèques puissantes pour élever vos projets WebSocket.

Tout d'abord, considérez la bibliothèque websockets. Sa force réside dans sa simplicité et sa fiabilité pour fabriquer des clients et des serveurs. C'est idéal pour les débutants qui s'aventurent dans la programmation WebSocket.

Un exemple de serveur de base websockets serveur:

<code class="language-python">import asyncio
import websockets

async def echo(websocket, path):
    async for message in websocket:
        await websocket.send(f"Echo: {message}")

async def main():
    server = await websockets.serve(echo, "localhost", 8765)
    await server.wait_closed()

asyncio.run(main())</code>
Copier après la connexion

Ce serveur reflète des messages entrants. asyncio gère efficacement les connexions simultanées.

Suivant, aiohttp offre une prise en charge Asynchrones Asynchrones complètes et WebSocket. Voici un serveur WebSocket utilisant aiohttp:

<code class="language-python">from aiohttp import web
import aiohttp

async def websocket_handler(request):
    ws = web.WebSocketResponse()
    await ws.prepare(request)

    async for msg in ws:
        if msg.type == aiohttp.WSMsgType.TEXT:
            await ws.send_str(f"Echo: {msg.data}")
        elif msg.type == aiohttp.WSMsgType.ERROR:
            print(f'ws connection closed with exception {ws.exception()}')

    return ws

app = web.Application()
app.add_routes([web.get('/ws', websocket_handler)])

if __name__ == '__main__':
    web.run_app(app)</code>
Copier après la connexion

aiohttp intègre de manière transparente la gestion de WebSocket dans son cadre Web, parfait pour les applications HTTP et WebSocket combinées.

Fastapi, réputé pour sa vitesse et sa convivialité, excelle également dans la prise en charge de WebSocket:

<code class="language-python">from fastapi import FastAPI, WebSocket
from fastapi.websockets import WebSocketDisconnect

app = FastAPI()

@app.websocket("/ws")
async def websocket_endpoint(websocket: WebSocket):
    await websocket.accept()
    try:
        while True:
            data = await websocket.receive_text()
            await websocket.send_text(f"Echo: {data}")
    except WebSocketDisconnect:
        print("Client disconnected")

if __name__ == "__main__":
    import uvicorn
    uvicorn.run(app, host="0.0.0.0", port=8000)</code>
Copier après la connexion

L'intégration ASGI Server de Fastapi (par exemple, Uvicorn) assure une communication WebSocket haute performance. Ses fonctionnalités, y compris la réduction de type et la documentation automatique, simplifient le développement.

Socket.io fournit une communication en temps réel, bidirectionnel et motivé par des événements, prenant en charge à la fois WebSocket et Fallbacks à long terme:

<code class="language-python">import socketio

sio = socketio.AsyncServer(async_mode='asgi')
app = socketio.ASGIApp(sio)

@sio.event
async def connect(sid, environ):
    print(f"Client connected: {sid}")

@sio.event
async def message(sid, data):
    await sio.emit('message', f"Echo: {data}", to=sid)

@sio.event
async def disconnect(sid):
    print(f"Client disconnected: {sid}")

if __name__ == '__main__':
    import uvicorn
    uvicorn.run(app, host='localhost', port=8000)</code>
Copier après la connexion

L'architecture basée sur les événements de Socket.io rationalise la logique d'application, offrant une prise en charge des salles et des espaces de noms.

Enfin, Autobahn prend en charge WebSocket et WAMP (Web Application Messageing Protocol), étendant WebSocket avec RPC et les fonctionnalités PubSub. Un simple serveur WebSocket Autobahn:

<code class="language-python">from autobahn.asyncio.websocket import WebSocketServerProtocol, WebSocketServerFactory

class MyServerProtocol(WebSocketServerProtocol):
    def onConnect(self, request):
        print(f"Client connecting: {request.peer}")

    def onOpen(self):
        print("WebSocket connection open.")

    async def onMessage(self, payload, isBinary):
        if isBinary:
            print(f"Binary message received: {len(payload)} bytes")
        else:
            print(f"Text message received: {payload.decode('utf8')}")
        await self.sendMessage(payload, isBinary)

    def onClose(self, wasClean, code, reason):
        print(f"WebSocket connection closed: {reason}")

if __name__ == '__main__':
    import asyncio
    factory = WebSocketServerFactory("ws://127.0.0.1:9000")
    factory.protocol = MyServerProtocol

    loop = asyncio.get_event_loop()
    coro = loop.create_server(factory, '0.0.0.0', 9000)
    server = loop.run_until_complete(coro)

    try:
        loop.run_forever()
    except KeyboardInterrupt:
        pass
    finally:
        server.close()
        loop.close()</code>
Copier après la connexion

La polyvalence d'Autobahn s'adresse à diverses applications, des serveurs de base aux systèmes distribués complexes utilisant WAMP.

Pour les applications à haut trafic, considérez l'évolutivité et la gestion des connexions, potentiellement à l'aide de redis pour le partage d'état. Implémentez l'authentification robuste (par exemple, basée sur les jetons) et la manipulation de reconnexion (backoff exponentielle). Optimiser la sérialisation des messages à l'aide de formats efficaces comme MessagePack pour les performances.

En résumé, ces cinq bibliothèques proposent des outils polyvalents pour une communication WebSocket efficace. Choisissez la bibliothèque la mieux adaptée aux besoins de votre application et implémentez les meilleures pratiques pour une expérience robuste et en temps réel.


101 livres

101 livres , une maison d'édition propulsée par l'AI co-fondée par Aarav Joshi, propose des livres abordables et de haute qualité. Explorez nos titres, y compris "Golang Clean Code", sur Amazon. Recherchez "Aarav Joshi" pour des remises spéciales!

nos créations

Découvrez nos divers projets: Investor Central (anglais, espagnol, allemand), Smart Living, Epochs & Echoes, Mystères déroutants, Hindutva, Elite Dev et JS écoles.


Nous sommes sur le milieu

Suivez-nous sur Medium: Tech Koala Insights, Epochs & Echoes World, Investor Central Medium, Medium Mysteries, Science et époques moderne et Hindutva moderne.

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!

source:php.cn
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal