Dengan populariti seni bina perkhidmatan mikro, mekanisme pemutus litar telah menjadi bahagian yang amat diperlukan. Mekanisme pemutus litar boleh mengelakkan kesan beberapa kegagalan rangkaian atau perkhidmatan pada keseluruhan sistem dan memastikan kebolehpercayaan dan kestabilan sistem. Artikel ini akan memperkenalkan cara menggunakan Golang untuk melaksanakan pemutus litar.
Dalam sistem teragih, komunikasi antara perkhidmatan mungkin menghadapi masalah seperti turun naik rangkaian, kegagalan perkakasan dan tamat masa. Jika anomali penghantaran yang disebabkan oleh kerosakan tidak ditemui dan dikendalikan dalam masa, ia akan menyebabkan sebahagian atau keseluruhan sistem runtuh, menyebabkan akibat yang serius. Kemunculan mekanisme pemutus litar menyelesaikan masalah ini.
Litar ialah mekanisme untuk mengatasi kegagalan. Apabila perkhidmatan gagal, mekanisme pemutus litar akan segera memutuskan sambungan panggilan perkhidmatan dan menetapkan tetingkap masa. Dalam tetingkap masa ini, sebarang permintaan untuk perkhidmatan akan dipintas terus dan mesej ralat akan dikembalikan, mengelakkan kesan kegagalan runtuhan salji pada perkhidmatan yang dipanggil dan membenarkan sistem untuk terus beroperasi sehingga perkhidmatan kembali normal.
Golang ialah bahasa yang cekap, ringkas dan mudah dipelajari, sesuai untuk pembangunan sistem teragih. Persekitaran bersepadu bahasa Go sudah mengandungi banyak perpustakaan pemutus litar, yang sangat mudah digunakan.
Berikut akan memperkenalkan cara menggunakan Golang untuk melaksanakan pemutus litar.
Di Golang, mekanisme pemutus litar biasanya dilaksanakan menggunakan pemutus litar. Untuk menggunakan mekanisme pemutus litar, perpustakaan pemutus litar perlu dipasang terlebih dahulu. Lebih banyak perpustakaan praktikal termasuk Hystrix Netflix dan perpustakaan pemutus litar go-kit.
Di sini kami mengambil perpustakaan pemutus litar go-kit sebagai contoh untuk dijelaskan. Mula-mula anda perlu memasangnya ke dalam persekitaran tempatan anda. Jalankan kod berikut dalam terminal:
go get github.com/go-kit/kit/v2/circuitbreaker
Selepas memasang perpustakaan pemutus litar, anda boleh mula menggunakan pemutus litar. Berikut menerangkan cara menggunakan perpustakaan pemutus litar go-kit untuk melaksanakan pemutus litar.
Proses mentakrifkan fius adalah sangat mudah, hanya gunakan kod berikut:
breaker := circuitbreaker.NewCircuitBreaker(circuitbreaker.Config{ Timeout: 2 * time.Second, // 超时时间 MaxRequests: 1, // 最大请求数 ReadyToTrip: func(counts circuitbreaker.Counts) bool { return counts.ConsecutiveFailures > 3 // 连续3次失败后打开断路器 }, })
Antaranya, Timeout
menentukan tamat masa permintaan; 🎜>Mengekang bilangan maksimum permintaan dalam tempoh masa; Fungsi MaxRequests
digunakan untuk menyemak sama ada pemutus litar perlu dibuka. Dalam kod di atas, apabila permintaan gagal lebih daripada 3 kali, fungsi ReadyToTrip
akan kembali benar, iaitu, buka fius. ReadyToTrip
func main() { breaker := circuitbreaker.NewCircuitBreaker(circuitbreaker.Config{ Timeout: 2 * time.Second, MaxRequests: 1, ReadyToTrip: func(counts circuitbreaker.Counts) bool { return counts.ConsecutiveFailures > 3 }, }) if err := breaker.Call(func() error { // 调用远端服务 return remoteCall() }); err != nil { // 熔断后的处理 fmt.Println("断路器已开启:", err) } }
. Jika ralat berlaku dalam panggilan, mekanisme pemutus litar akan dicetuskan, dan toleransi kesalahan boleh dilaksanakan dalam kod. breaker.Call()
Atas ialah kandungan terperinci Golang melaksanakan pemutus litar. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!