


La connexion Python Asyncio Telnet est immédiatement déconnectée: comment résoudre le problème de blocage côté serveur?
Python Asyncio Telnet Connection Déconnexion: analyse et solution aux problèmes de blocage côté serveur
Lors de la création d'un serveur Web à l'aide de la bibliothèque Asyncio de Python, vous rencontrez souvent le problème de la déconnexion du client Telnet immédiatement après la connexion. Cet article analyse ce problème et fournit des solutions efficaces.
Description du problème:
Un simple serveur ASyncio TCP, après avoir connecté à l'aide du client Telnet, affiche immédiatement une erreur "Connexion clôturée par l'hôte étranger"., Indiquant que le serveur a activement fermé la connexion. La cause profonde du problème réside dans le blocage de la fonction de traitement côté serveur.
Code d'origine (a un problème):
importer asyncio à partir d'asyncio.base_events Import Server Async Def handle_client (lecteur, écrivain): Bien que vrai: data = attendre lecteur.readline () Si ce n'est pas des données: casser écrivain.write (données) écrivain.close () asynchrone def main (): server: server = attendre asyncio.get_running_loop (). Create_server ( handle_client, '127.0.0.1', 8888) Async avec serveur: attendre server.serve_forever () asyncio.run (main ())
reader.readline()
bloque jusqu'à ce qu'une nouvelle ligne ('\ n') soit lue. Le client Telnet n'enverra pas de données immédiatement après la réussite de la connexion, ce qui fait que reader.readline()
bloque indéfiniment, ce qui entraînera éventuellement la connexion à Time Out et sera fermée par le serveur.
Solution:
La fonction handle_client
améliorée envoie des messages de bienvenue immédiatement après l'établissement de la connexion et utilise reader.read(100)
au lieu de reader.readline()
pour éviter de bloquer et d'attendre Newlines. await writer.drain()
garantit que les données sont envoyées correctement.
Code amélioré:
Async Def handle_client (lecteur, écrivain): Welcome_Message = "Bienvenue sur le serveur! \ n" writer.write (welcome_message.encode ()) Await Writer.drain () Bien que vrai: data = attendre lecteur.read (100) Si ce n'est pas des données: casser écrivain.write (données) Await Writer.drain () écrivain.close ()
Grâce à ces modifications, le client Telnet peut se connecter avec succès au serveur et interagir normalement. reader.read(100)
lit jusqu'à 100 octets de données et peut continuer à s'exécuter même si le client n'envoie pas de lignes de nouvelles, en évitant le blocage. await writer.drain()
garantit que les données sont complètement envoyées au client et évitent la perte de données.
Grâce à l'analyse ci-dessus et à l'amélioration du code, nous pouvons résoudre efficacement le problème de la connexion Python Asyncio Telnet en cours de déconnexion immédiatement et de créer un serveur réseau plus stable et fiable.
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds











Dans MySQL, ajoutez des champs en utilisant alterTableTable_namEaddColumnNew_Columnvarchar (255) AfterExist_Column, supprimez les champs en utilisant alterTableTable_NamedRopColumnColumn_to_drop. Lorsque vous ajoutez des champs, vous devez spécifier un emplacement pour optimiser les performances de la requête et la structure des données; Avant de supprimer les champs, vous devez confirmer que l'opération est irréversible; La modification de la structure de la table à l'aide du DDL en ligne, des données de sauvegarde, de l'environnement de test et des périodes de faible charge est l'optimisation des performances et les meilleures pratiques.

Les outils de quantification intégrés de l'échange comprennent: 1. Binance: fournit un module quantitatif à terme Binance Futures, des frais de manutention faible et prend en charge les transactions assistées par l'IA. 2. OKX (OUYI): prend en charge la gestion multi-comptes et le routage des ordres intelligents, et fournit un contrôle des risques au niveau institutionnel. Les plates-formes de stratégie quantitative indépendantes comprennent: 3. 3Commas: générateur de stratégie de glisser-déposer, adapté à l'arbitrage de la couverture multiplateforme. 4. Quadancy: Bibliothèque de stratégie d'algorithme de niveau professionnel, soutenant les seuils de risque personnalisés. 5. Pionex: stratégie prédéfinie intégrée, frais de transaction bas. Les outils de domaine vertical incluent: 6. CryptoPper: plate-forme quantitative basée sur le cloud, prenant en charge 150 indicateurs techniques. 7. Bitsgap:

Comment réaliser l'effet de la pénétration des événements de défilement de la souris? Lorsque nous naviguons sur le Web, nous rencontrons souvent des conceptions d'interaction spéciales. Par exemple, sur le site officiel Deepseek, � ...

Méthodes efficaces pour les données d'insertion par lots dans MySQL Incluent: 1. Utilisation d'inserto ... Syntaxe des valeurs, 2. Utilisation de la commande chargedatainfile, 3. Utilisation du traitement des transactions, 4. Ajuster la taille du lot, 5. Désactiver l'indexation, 6. Utilisation de l'insertion ou de l'insert ... onduplicatekeyupdate, ces méthodes peuvent améliorer considérablement l'efficacité du fonctionnement de la base de données.

Les fonctions MySQL peuvent être utilisées pour le traitement et le calcul des données. 1. L'utilisation de base comprend le traitement des chaînes, le calcul de la date et les opérations mathématiques. 2. L'utilisation avancée consiste à combiner plusieurs fonctions pour implémenter des opérations complexes. 3. L'optimisation des performances nécessite d'éviter l'utilisation de fonctions dans la clause où et d'utiliser des tables groupby et temporaires.

Les 10 principales plates-formes de trading de devises virtuelles numériques sont: 1. Binance, 2. Okx, 3. Coinbase, 4. Kraken, 5. Huobi Global, 6. Bitfinex, 7. Kucoin, 8. Gemini, 9. Bitstamp, 10. Bittrex. Ces plateformes offrent toutes une haute sécurité et une variété d'options de trading, adaptées à différents besoins des utilisateurs.

Ce développement révolutionnaire permettra aux institutions financières de tirer parti de la norme ISO20022 globalement reconnue pour automatiser les processus bancaires à travers différents écosystèmes de blockchain. Le protocole d'assistance est une plate-forme de blockchain au niveau de l'entreprise conçue pour promouvoir une adoption généralisée grâce à des méthodes faciles à utiliser. Il a annoncé aujourd'hui qu'il avait réussi à intégrer la norme de messagerie ISO20022 et l'a incorporé directement dans les contrats intelligents de la blockchain. Cette évolution permettra aux institutions financières d'automatiser facilement les processus bancaires dans différents écosystèmes de blockchain en utilisant la norme ISO20022 reconnue globalement, qui remplace le système de messagerie rapide. Ces fonctionnalités seront bientôt essayées sur "Easetestnet". Easeprotocolarchitecteddou

Les méthodes de configuration des ensembles de caractères et des collations dans MySQL incluent: 1. Définition des jeux de caractères et des collations au niveau du serveur: setNames'utf8 '; SetCharAttersetUtf8; SetCollation_Connection = 'utf8_general_ci'; 2. Créez une base de données qui utilise des jeux de caractères et des collations spécifiques: CreatedAtAbasEExample_DBCharacteSetUtf8CollateUtf8_General_ci; 3. Spécifiez les ensembles de caractères et les collations lors de la création d'une table: CreateTableExample_Table (IDInt
