Rumah > pembangunan bahagian belakang > Golang > Bagaimana untuk melaksanakan strategi cuba semula untuk permintaan rangkaian menggunakan Go dan http.Transport?

Bagaimana untuk melaksanakan strategi cuba semula untuk permintaan rangkaian menggunakan Go dan http.Transport?

王林
Lepaskan: 2023-07-21 21:54:20
asal
826 orang telah melayarinya

Bagaimana untuk melaksanakan strategi cuba semula untuk permintaan rangkaian menggunakan Go dan http.Transport?

Apabila membuat permintaan rangkaian, kami sering menghadapi permintaan yang gagal disebabkan oleh ketidakstabilan rangkaian, keabnormalan pelayan dan sebab lain. Untuk meningkatkan kadar kejayaan permintaan, kami boleh menggunakan strategi cuba semula untuk menghantar semula permintaan sehingga permintaan itu berjaya atau bilangan maksimum percubaan semula dicapai. Artikel ini akan memperkenalkan cara menggunakan http.Transport dalam bahasa Go untuk melaksanakan strategi cuba semula untuk permintaan rangkaian.

Pertama, kita perlu mengimport pakej berikut:

import (
    "fmt"
    "net/http"
    "time"
)
Salin selepas log masuk

Seterusnya, kita perlu mencipta http.RoundTripper tersuai untuk melaksanakan logik cuba semula. Kita boleh mencipta RoundTripper tersuai berdasarkan http.Transport. Contohnya:

type RetryTransport struct {
    Transport http.RoundTripper
    Retries   int
}
Salin selepas log masuk

Dalam struktur RetryTransport, kami mentakrifkan dua medan: Transport dan Retry. Pengangkutan ialah jenis http.RoundTripper yang digunakan untuk menghantar permintaan dan menerima respons. Cuba semula mewakili bilangan maksimum percubaan semula.

Seterusnya, kita perlu melaksanakan kaedah RoundTrip dalam antara muka RoundTripper, yang digunakan untuk menghantar permintaan dan menerima respons. Dalam kaedah ini, kita boleh melaksanakan logik cuba semula. Contohnya:

func (r *RetryTransport) RoundTrip(req *http.Request) (*http.Response, error) {
    var resp *http.Response
    var err error

    for i := 0; i <= r.Retries; i++ {
        resp, err = r.Transport.RoundTrip(req)
        
        if err == nil && resp.StatusCode < 500 {
            break
        }
        
        time.Sleep(1 * time.Second)
    }

    return resp, err
}
Salin selepas log masuk

Dalam kaedah RoundTrip, kami menggunakan gelung untuk melaksanakan penghantaran dan penerimaan permintaan. Bilangan gelung ditentukan oleh bilangan maksimum percubaan semula. Selepas setiap permintaan dihantar, kami menyemak sama ada ralat berlaku dan kod status respons kurang daripada 500 (menunjukkan pengecualian bahagian pelayan). Jika syarat dipenuhi, permintaan berjaya dan gelung dilonjak keluar, jika tidak, permintaan dihantar semula selepas menunggu selama 1 saat.

Akhir sekali, kita perlu menggunakan RetryTransport tersuai untuk mencipta http.Client untuk menghantar permintaan. Contohnya:

func main() {
    retryTransport := &RetryTransport{
        Transport: http.DefaultTransport,
        Retries:   3,
    }

    client := &http.Client{
        Transport: retryTransport,
    }

    resp, err := client.Get("https://example.com")
    if err != nil {
        fmt.Println("请求出错:", err)
        return 
    }

    defer resp.Body.Close()

    // 处理响应
    // ...
}
Salin selepas log masuk

Dalam contoh di atas, kami mencipta RetryTransport dan menetapkannya sebagai Pengangkutan http.Client. Kami menetapkan bilangan maksimum percubaan semula kepada 3 kali. Kami kemudian menggunakan kaedah client.Get untuk menghantar permintaan dan memproses respons yang dikembalikan.

Dengan menggunakan RetryTransport tersuai, kami boleh melaksanakan strategi cuba semula untuk permintaan rangkaian. Apabila permintaan gagal, ia secara automatik akan mencuba semula bilangan kali yang ditentukan untuk meningkatkan kadar kejayaan permintaan rangkaian.

Untuk meringkaskan, artikel ini memperkenalkan cara menggunakan http.Transport dan RoundTripper tersuai dalam bahasa Go untuk melaksanakan strategi cuba semula untuk permintaan rangkaian. Dengan mentakrifkan bilangan percubaan semula dan masa menunggu, kami dapat mengatasi ketidakstabilan rangkaian dan pengecualian pelayan dengan lebih baik, dan meningkatkan kadar kejayaan permintaan.

Atas ialah kandungan terperinci Bagaimana untuk melaksanakan strategi cuba semula untuk permintaan rangkaian menggunakan Go dan http.Transport?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan