Rumah >pembangunan bahagian belakang >Golang >Bagaimanakah Saya Boleh Melaksanakan Tamat Masa untuk Panggilan RPC?

Bagaimanakah Saya Boleh Melaksanakan Tamat Masa untuk Panggilan RPC?

DDD
DDDasal
2024-10-29 18:11:18389semak imbas

 How Can I Implement Timeouts for RPC Calls?

Bolehkah permintaan panggilan RPC ditamatkan masa?

RPC, atau Panggilan Prosedur Jauh, ialah mekanisme untuk memanggil fungsi dalam proses yang berbeza, tetapi disebabkan kependaman rangkaian atau isu lain, panggilan kadangkala boleh tersekat.

Jika RPC tidak mempunyai mekanisme tamat masa terbina dalam, situasi sedemikian boleh dikendalikan dengan menggunakan saluran untuk melaksanakan corak tamat masa:

import "time"

c := make(chan error, 1)
go func() { c <- client.Call("Service", args, &result) } ()
select {
  case err := <-c:
    // use err and result
  case <-time.After(timeoutNanoseconds):
    // call timed out
}

Dalam contoh ini:

  • c ialah saluran yang boleh menampung maksimum satu ralat.
  • Groutine melaksanakan panggilan RPC dan menghantar ralat (atau keputusan) ke saluran.
  • Pernyataan pilih menyekat sehingga sama ada goroutine selesai melaksanakan dan menghantar ralat kepada saluran atau tamat masaNanosaat berlalu. Jika yang pertama berlaku, pelaksanaan diteruskan dengan pembolehubah ralat dan hasil, manakala dalam kes kedua operasi tamat.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Melaksanakan Tamat Masa untuk Panggilan RPC?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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