Go : délai de ResponseController non respecté
l'éditeur php Strawberry est là pour vous présenter "Go : Non-respect du délai de ResponseController". Dans le développement de logiciels, ResponseController est un contrôleur courant utilisé pour gérer les demandes de réponse. Cependant, les développeurs peuvent parfois négliger de respecter le délai fixé par ResponseController lors de l'écriture du code, ce qui peut entraîner une série de problèmes. Cet article explorera ce problème en détail et fournira des solutions pour garantir la fiabilité et la stabilité de votre code.
Contenu de la question
J'ai un code dans lequel j'essaie d'annuler l'écriture au client si l'écriture prend trop de temps. Je pense que je peux utiliser http.responsecontroller pour y parvenir car il dispose d'une méthode setwritedeadline.
Malheureusement, dans le code ci-dessous, rw.write
ne renvoie pas d'erreur une fois le délai écoulé.
Existe-t-il un autre moyen d'annuler l'écriture ?
package main import ( "log" "net/http" "time" ) func main() { http.handlefunc("/", func(rw http.responsewriter, r *http.request) { log.println(r.method, r.url.path) rc := http.newresponsecontroller(rw) dl := time.now().add(3 * time.second) if err := rc.setwritedeadline(dl); err != nil { log.println(err) return } log.println("write deadline:", dl) var total int for _, b := range []byte("what!\n") { time.sleep(time.second) n, err := rw.write([]byte{b}) if err != nil { log.println(err) return } total += n log.println("bytes written", n) } log.println(r.method, r.url.path, "write total", total) }) http.listenandserve(":8080", nil) }
$ go run main.go 2023/04/26 12:24:40 get / 2023/04/26 12:24:40 write deadline: 2023-04-26 12:24:43.303884739 -0700 pdt m=+11.5891 16304 2023/04/26 12:24:41 bytes written 1 2023/04/26 12:24:42 bytes written 1 2023/04/26 12:24:43 bytes written 1 2023/04/26 12:24:44 bytes written 1 2023/04/26 12:24:45 bytes written 1 2023/04/26 12:24:46 bytes written 1 2023/04/26 12:24:46 get / write total 6
$ curl http://localhost:8080/ curl: (52) Empty reply from server
Workaround
setwritedeadline documentation dit :
setwritedeadline Fixez la date limite pour rédiger les réponses. L'écriture du corps de la réponse après la date limite ne bloquera pas, mais peut réussir si les données sont mises en mémoire tampon.
L'écriture vers l'auteur de la réponse dans la question réussit car la petite quantité de données écrites par l'application est mise en mémoire tampon.
L'erreur "Réponse vide du serveur" de curl indique que le délai est respecté lorsque le serveur vide la réponse à la connexion réseau sous-jacente lorsqu'elle revient du gestionnaire.
Utilisez setwritedeadline pour éviter la lenteur du client.
Utilisez un contexte avec une date limite pour limiter le temps nécessaire au serveur pour générer une réponse :
65bd46fc4 févrierCe 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

AI Hentai Generator
Générez AI Hentai gratuitement.

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)

OpenSSL, en tant que bibliothèque open source largement utilisée dans les communications sécurisées, fournit des algorithmes de chiffrement, des clés et des fonctions de gestion des certificats. Cependant, il existe des vulnérabilités de sécurité connues dans sa version historique, dont certaines sont extrêmement nocives. Cet article se concentrera sur les vulnérabilités et les mesures de réponse communes pour OpenSSL dans Debian Systems. DebianopenSSL CONNUTS Vulnérabilités: OpenSSL a connu plusieurs vulnérabilités graves, telles que: la vulnérabilité des saignements cardiaques (CVE-2014-0160): cette vulnérabilité affecte OpenSSL 1.0.1 à 1.0.1F et 1.0.2 à 1.0.2 Versions bêta. Un attaquant peut utiliser cette vulnérabilité à des informations sensibles en lecture non autorisées sur le serveur, y compris les clés de chiffrement, etc.

L'article explique comment utiliser l'outil PPROF pour analyser les performances GO, notamment l'activation du profilage, la collecte de données et l'identification des goulots d'étranglement communs comme le processeur et les problèmes de mémoire. COMMANDE: 159

L'article traite des tests d'unité d'écriture dans GO, couvrant les meilleures pratiques, des techniques de moquerie et des outils pour une gestion efficace des tests.

La bibliothèque utilisée pour le fonctionnement du numéro de point flottante dans le langage go présente comment s'assurer que la précision est ...

Problème de threading de file d'attente dans Go Crawler Colly explore le problème de l'utilisation de la bibliothèque Crawler Crawler dans le langage Go, les développeurs rencontrent souvent des problèmes avec les threads et les files d'attente de demande. � ...

Chemin d'apprentissage du backend: le parcours d'exploration du front-end à l'arrière-end en tant que débutant back-end qui se transforme du développement frontal, vous avez déjà la base de Nodejs, ...

L'article traite de la commande GO FMT dans GO Programming, qui formate le code pour adhérer aux directives de style officiel. Il met en évidence l'importance de GO FMT pour maintenir la cohérence du code, la lisibilité et la réduction des débats de style. Meilleures pratiques pour

Cet article présente une variété de méthodes et d'outils pour surveiller les bases de données PostgreSQL sous le système Debian, vous aidant à saisir pleinement la surveillance des performances de la base de données. 1. Utilisez PostgreSQL pour reprendre la surveillance Afficher PostgreSQL lui-même offre plusieurs vues pour surveiller les activités de la base de données: PG_STAT_ACTIVITY: affiche les activités de la base de données en temps réel, y compris les connexions, les requêtes, les transactions et autres informations. PG_STAT_REPLIcation: surveille l'état de réplication, en particulier adapté aux grappes de réplication de flux. PG_STAT_DATABASE: Fournit des statistiques de base de données, telles que la taille de la base de données, les temps de validation / recul des transactions et d'autres indicateurs clés. 2. Utilisez l'outil d'analyse de journaux pgbadg
