欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Go設置http請求超時的方法實現(xiàn)

 更新時間:2024年08月11日 10:11:05   作者:Grassto  
這篇文章主要介紹了Go設置http請求超時的方法實現(xiàn),最近接手了一個老項目進行維護,發(fā)現(xiàn)其中有個關于 http 請求的方法設置的 timeout 沒有生效,很奇怪,一開始查看代碼并沒有發(fā)現(xiàn)什么可疑點,后查看了源碼,打斷點調(diào)試才發(fā)現(xiàn)問題所在,這里簡單記錄復盤一下

背景

最近接手了一個老項目進行維護,發(fā)現(xiàn)其中有個關于 http 請求的方法設置的 timeout 沒有生效,很奇怪!

一開始查看代碼并沒有發(fā)現(xiàn)什么可疑點,后查看了源碼,打斷點調(diào)試才發(fā)現(xiàn)問題所在,這里簡單記錄復盤一下。

說明:本篇的源碼的 go 版本是 1.20.2 。

問題

示例代碼

package main

import (
	"context"
	"fmt"
	"net/http"
	"time"
)

func main() {
	req, err := http.NewRequest(http.MethodGet, "https://www.baidu.com", nil)
	if err != nil {
		panic(err)
	}

	ctx, cancel := context.WithTimeout(context.Background(), time.Millisecond)
	defer cancel()
	req.WithContext(ctx)

	resp, err := http.DefaultClient.Do(req)
	if err != nil {
		panic(err)
	}

	//resp.Write(os.Stdout)
	fmt.Println("end: ", resp.StatusCode)
}

程序正常跑完并輸出了,但是預期的是 http.DefaultClient.Do(req) 這里會直接報錯,難道請求 1ms 就結束了??Why???

大家可以自己看下這段代碼哪里有問題。

先說解決,其實就是 req.WithContext(ctx) 生成的是一個新的 http.Request 對象,上述的問題代碼中并沒有將其賦值給當前的 http.Request。大意了,沒有閃。

req = req.WithContext(ctx)

WithContext 方法的源碼如下(net/http/request.go 356)

func (r *Request) WithContext(ctx context.Context) *Request {
	if ctx == nil {
		panic("nil context")
	}
	r2 := new(Request)
	*r2 = *r
	r2.ctx = ctx
	return r2
}

請求超時設置

翻了下源碼,看了下超時設置的方式,http 設置超時主要有兩種方式:

  • http.Client
	c := http.Client{
		Timeout: time.Minute,
	}
	c.Do(req)
  • http.Request 設置 context 超時
	ctx, cancel := context.WithTimeout(context.Background(), time.Minute)
	defer cancel()
	req = req.WithContext(ctx)

在 Client 上指定 Timeout 會作用于通過該 Client 發(fā)起的所有請求,而 Request 設置 Context,僅針對這一次請求。使用的時候需要注意自己的場景。

設置 Tcp 連接階段的超時可以這樣:

client := http.Client{
	Transport: &http.Transport{
		Dial: (&net.Dialer{
			Timeout:   2  * time.Second, //  tcp 連接時設置的連接超時
			Deadline:  time.Now().Add(3  * time.Second),  // 超時強制關閉
		}).Dial,
		TLSHandshakeTimeout: 2 * time.Second, //https 握手超時
	},
	Timeout: 5 * time.Second,
}

可以設置 Transport 中的 Dial

總結

平常自己使用 http 發(fā)送請求設置超時,都是直接給 http.Client 對象設置 Timeout 屬性,很少使用這種對單個 Request 設置超時的。

其實還是個熟練度問題,平常源碼讀的比較少。有空讀讀源碼不僅可以在使用代碼的時候更得心應手,也能夠?qū)W習借鑒源碼的代碼設計實現(xiàn)。對自己平常經(jīng)常需要使用的庫,還是建議都過一遍源碼,很不錯的一個打發(fā)空閑時間的方式。

以上就是Go設置http請求超時的方法實現(xiàn)的詳細內(nèi)容,更多關于Go設置http請求超時的資料請關注腳本之家其它相關文章!

相關文章

  • 詳解Golang如何優(yōu)雅的終止一個服務

    詳解Golang如何優(yōu)雅的終止一個服務

    后端服務通常會需要創(chuàng)建子協(xié)程來進行相應的作業(yè),但進程接受到終止信號或正常結束時,并沒有判斷或等待子協(xié)程執(zhí)行結束,下面這篇文章主要給大家介紹了關于Golang如何優(yōu)雅的終止一個服務的相關資料,需要的朋友可以參考下
    2022-03-03
  • 使用Gin框架返回JSON、XML和HTML數(shù)據(jù)

    使用Gin框架返回JSON、XML和HTML數(shù)據(jù)

    Gin是一個高性能的Go語言Web框架,它不僅提供了簡潔的API,還支持快速的路由和中間件處理,在Web開發(fā)中,返回JSON、XML和HTML數(shù)據(jù)是非常常見的需求,本文將介紹如何使用Gin框架來返回這三種類型的數(shù)據(jù),需要的朋友可以參考下
    2024-08-08
  • Golang庫插件注冊加載機制的問題

    Golang庫插件注冊加載機制的問題

    這篇文章主要介紹了Golang庫插件注冊加載機制,這里說的插件并不是指的golang原生的可以在buildmode中加載指定so文件的那種加載機制,需要的朋友可以參考下
    2022-03-03
  • 詳解Go語言如何解析帶注釋的json

    詳解Go語言如何解析帶注釋的json

    標準的json格式是不帶注釋,但是有時候為了方便理解json中各字段的含義,需要支持帶注釋的json,這篇文章主要介紹了Go語言解析帶注釋json的相關方法,希望對大家有所幫助
    2024-03-03
  • Golang實現(xiàn)web文件共享服務的示例代碼

    Golang實現(xiàn)web文件共享服務的示例代碼

    這篇文章主要介紹了Golang實現(xiàn)web文件共享服務的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-10-10
  • Golang中map縮容的實現(xiàn)

    Golang中map縮容的實現(xiàn)

    本文主要介紹了Go語言中map的擴縮容機制,包括grow和hashGrow方法的處理,具有一定的參考價值,感興趣的可以了解一下
    2025-03-03
  • Golang服務中context超時處理的方法詳解

    Golang服務中context超時處理的方法詳解

    在Go語言中,Context是一個非常重要的概念,它存在于一個完整的業(yè)務生命周期內(nèi),Context類型是一個接口類型,在實際應用中,我們可以使用Context包來傳遞請求的元數(shù)據(jù),本文將給大家介紹Golang服務中context超時處理的方法和超時原因,需要的朋友可以參考下
    2023-05-05
  • Go語言中高效地處理集合的方法小結

    Go語言中高效地處理集合的方法小結

    在?Go?語言中,處理集合(如切片、映射等)時,可以通過多種方式提高效率,本文為大家整理了一些常見的方法,有需要的小伙伴可以了解一下
    2025-02-02
  • go xorm存庫處理null值問題

    go xorm存庫處理null值問題

    這篇文章主要介紹了go xorm存庫處理null值問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • Golang中如何對MySQL進行操作詳解

    Golang中如何對MySQL進行操作詳解

    這篇文章主要給大家介紹了關于在Golang中如何對MySQL進行操作的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者使用Golang具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-03-03

最新評論