Maison développement back-end Golang La requête http Golang prend du temps

La requête http Golang prend du temps

May 10, 2023 am 09:25 AM

Golang est un langage de programmation très adapté à la programmation web. Golang fournit des bibliothèques standards très utiles, telles que net/http. Cette bibliothèque fournit la fonction de créer et d'envoyer des requêtes HTTP et de recevoir des réponses. Dans les projets réels, nous devons parfois calculer la consommation de temps des requêtes HTTP, afin de pouvoir mieux évaluer et optimiser les performances. Cet article expliquera comment calculer la consommation de temps des requêtes HTTP dans Golang. net/http,这个库提供了创建和发送HTTP请求和接收响应的功能。在实际项目中,我们有时候需要对HTTP请求的耗时进行计算,这样可以更好的进行性能评估和优化。本文将介绍如何在Golang中计算HTTP请求的耗时。

HTTP请求耗时的计算

在计算HTTP请求请求耗时之前,我们需要了解HTTP请求的生命周期。HTTP请求的生命周期主要分为以下四个阶段。

  1. DNS解析:将域名解析为IP地址
  2. TCP连接:通过IP地址建立TCP连接
  3. 服务器处理请求:服务器处理HTTP请求,进行处理查找资源等操作
  4. 响应内容传送:服务器将响应文本传送给客户端

在Golang中,我们可以通过time标准库的Now()函数来记录某个时间点的时间,然后通过时间差来计算HTTP请求的耗时。下面我们将依次介绍以上四个阶段的HTTP请求耗时的计算方法。

  1. DNS解析耗时

在Golang中,我们可以通过net.LookupIP()函数来进行DNS解析。这个函数接收一个主机名作为参数,并返回其对应的IP地址列表。我们可以分别记录DNS解析前和DNS解析后的时间点,然后计算时间差即可得到DNS解析时间的耗时。下面是一个DNS解析耗时的示例代码:

start := time.Now()
ips, err := net.LookupIP("www.example.com")
end := time.Now()
if err != nil {
    fmt.Println("Failed to resolve DNS:", err)
    return
}
dnsTime := end.Sub(start)
fmt.Println("DNS resolution time:", dnsTime)
Copier après la connexion
  1. TCP连接耗时

在Golang中,我们可以通过net.Dial()函数来建立TCP连接。这个函数接收两个参数,第一个参数是协议("tcp"或"tcp4"或"tcp6"),第二个参数是目标主机名或IP地址加端口号(例如:"example.com:80")。我们可以分别记录TCP连接建立前和建立后的时间点,然后计算时间差即可得到TCP连接时间的耗时。下面是一个TCP连接耗时的示例代码:

start := time.Now()
conn, err := net.Dial("tcp", "www.example.com:80")
end := time.Now()
if err != nil {
    fmt.Println("Failed to connect to server:", err)
    return
}
connTime := end.Sub(start)
fmt.Println("TCP connection time:", connTime)
Copier après la connexion
  1. 服务器处理请求耗时

在Golang中,通过http.Client类型的Do()函数可以发送HTTP请求并返回响应。我们可以在发送请求前记录时间点,然后在接收到响应后记录时间点,计算时间差即可得到服务器处理请求时间的耗时。下面是一个服务器处理请求耗时的示例代码:

start := time.Now()
resp, err := http.Get("http://www.example.com")
end := time.Now()
if err != nil {
    fmt.Println("Failed to get response:", err)
    return
}
body, _ := ioutil.ReadAll(resp.Body)
defer resp.Body.Close()
serverTime := end.Sub(start)
fmt.Println("Server response time:", serverTime)
Copier après la connexion
  1. 响应内容传送耗时

在Golang中,通过http.Client类型的Do()

Calcul chronophage de la requête HTTP

Avant de calculer la requête HTTP qui prend du temps, nous devons comprendre le cycle de vie de la requête HTTP. Le cycle de vie d'une requête HTTP est principalement divisé en quatre étapes suivantes.

  1. Résolution DNS : résoudre le nom de domaine en adresse IP
  2. Connexion TCP : établir une connexion TCP via l'adresse IP
  3. Requête de traitement du serveur : le serveur traite la requête HTTP et la traite Recherche de ressources et autres opérations
  4. Transmission du contenu de la réponse : le serveur transmet le texte de la réponse au client

Dans Golang, on peut passer le time La fonction Now() enregistre l'heure à un certain moment dans le temps, puis calcule la consommation de temps de la requête HTTP à travers le décalage horaire. Ci-dessous, nous présenterons tour à tour la méthode de calcul du temps de requête HTTP dans les quatre étapes ci-dessus.

  1. La résolution DNS prend du temps

Dans Golang, nous pouvons effectuer la résolution DNS via la fonction net.LookupIP(). Cette fonction reçoit un nom d'hôte en paramètre et renvoie une liste de ses adresses IP correspondantes. Nous pouvons enregistrer les points temporels avant et après la résolution DNS, puis calculer le décalage horaire pour obtenir le temps de résolution DNS. Voici un exemple de code qui prend du temps pour résoudre DNS : 🎜
start := time.Now()
resp, err := http.Get("http://www.example.com")
end := time.Now()
if err != nil {
    fmt.Println("Failed to get response:", err)
    return
}
body, _ := ioutil.ReadAll(resp.Body)
defer resp.Body.Close()
transferTime := end.Sub(start)
fmt.Println("Server response time:", transferTime)
Copier après la connexion
  1. La connexion TCP prend du temps
🎜Dans Golang, nous pouvons passer net. Fonction Dial () pour établir une connexion TCP. Cette fonction reçoit deux paramètres, le premier paramètre est le protocole ("tcp" ou "tcp4" ou "tcp6") et le deuxième paramètre est le nom d'hôte cible ou l'adresse IP plus le numéro de port (par exemple : "example.com : 80" "). Nous pouvons enregistrer les moments avant et après l'établissement de la connexion TCP, puis calculer le décalage horaire pour obtenir l'heure de connexion TCP. Voici un exemple de code qui prend du temps pour une connexion TCP : 🎜
start := time.Now()
ips, err := net.LookupIP("www.example.com")
if err != nil {
    fmt.Println("Failed to resolve DNS:", err)
    return
}

conn, err := net.Dial("tcp", ips[0].String()+":80")
if err != nil {
    fmt.Println("Failed to connect to server:", err)
    return
}
connTime := time.Now().Sub(start)

req, err := http.NewRequest("GET", "http://www.example.com", nil)
if err != nil {
    fmt.Println("Failed to create HTTP request:", err)
    return
}

start = time.Now()
resp, err := http.DefaultClient.Do(req)
if err != nil {
    fmt.Println("Failed to get response:", err)
    return
}
body, _ := ioutil.ReadAll(resp.Body)
defer resp.Body.Close()
serverTime := time.Now().Sub(start)

transferTime := time.Now().Sub(start)
totalTime := connTime + serverTime + transferTime
fmt.Println("HTTP request total time:", totalTime)
Copier après la connexion
  1. Il faut du temps au serveur pour traiter la requête
🎜Dans Golang, via http.ClientDo() de type /code> peut envoyer une requête HTTP et renvoyer une réponse. Nous pouvons enregistrer le moment avant d'envoyer la demande, puis enregistrer le moment après avoir reçu la réponse. En calculant le décalage horaire, nous pouvons obtenir le temps nécessaire au serveur pour traiter la demande. Voici un exemple de code qui met du temps au serveur pour traiter la requête : 🎜rrreee
  1. Il faut du temps pour fournir le contenu de la réponse
🎜Dans Golang, via http.Client La fonction <code>Do() de type peut envoyer une requête HTTP et renvoyer une réponse. Nous pouvons enregistrer le moment après avoir obtenu la réponse, puis enregistrer le moment après la fin de la transmission du contenu de la réponse. En calculant la différence de temps, nous pouvons obtenir le temps écoulé pour la transmission du contenu de la réponse. Voici un exemple de code qui prend du temps pour transmettre le contenu de la réponse : 🎜rrreee🎜Le temps total passé dans les quatre étapes ci-dessus est le temps total passé sur la requête HTTP. Nous pouvons rassembler les extraits de code ci-dessus pour calculer le temps total passé sur les requêtes HTTP. Voici un exemple de code pour calculer le temps total passé sur les requêtes HTTP : 🎜rrreee🎜Résumé🎜🎜Ce qui précède explique comment calculer le temps passé sur les requêtes HTTP dans Golang. En calculant séparément le temps de résolution DNS, le temps de connexion TCP, le temps de traitement des requêtes du serveur et le délai de livraison du contenu de réponse, nous pouvons mieux évaluer et optimiser les performances des requêtes réseau. 🎜

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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Vous avez un jeu croisé?
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Quelles sont les vulnérabilités de Debian OpenSSL Quelles sont les vulnérabilités de Debian OpenSSL Apr 02, 2025 am 07:30 AM

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.

Comment utilisez-vous l'outil PPROF pour analyser les performances GO? Comment utilisez-vous l'outil PPROF pour analyser les performances GO? Mar 21, 2025 pm 06:37 PM

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

Comment rédigez-vous des tests unitaires en Go? Comment rédigez-vous des tests unitaires en Go? Mar 21, 2025 pm 06:34 PM

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.

Quelles bibliothèques sont utilisées pour les opérations du numéro de point flottantes en Go? Quelles bibliothèques sont utilisées pour les opérations du numéro de point flottantes en Go? Apr 02, 2025 pm 02:06 PM

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 ...

Quel est le problème avec le fil de file d'attente dans GO's Crawler Colly? Quel est le problème avec le fil de file d'attente dans GO's Crawler Colly? Apr 02, 2025 pm 02:09 PM

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. � ...

Quelle est la commande Go FMT et pourquoi est-elle importante? Quelle est la commande Go FMT et pourquoi est-elle importante? Mar 20, 2025 pm 04:21 PM

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

Méthode de surveillance postgresql sous Debian Méthode de surveillance postgresql sous Debian Apr 02, 2025 am 07:27 AM

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

Transformant du développement frontal au développement back-end, est-il plus prometteur d'apprendre Java ou Golang? Transformant du développement frontal au développement back-end, est-il plus prometteur d'apprendre Java ou Golang? Apr 02, 2025 am 09:12 AM

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, ...

See all articles