Menguruskan Tamat Masa dalam Panggilan RPC
Panggilan Prosedur Jauh (RPC) ialah mekanisme yang membenarkan atur cara menggunakan prosedur atau fungsi pada mesin jauh. Walau bagaimanapun, adalah penting untuk sistem RPC mempunyai mekanisme yang boleh dipercayai untuk mengendalikan senario di mana panggilan jauh mengambil masa yang lama atau gagal tanpa diduga.
Mekanisme Tamat Masa dalam RPC
Adakah RPC mempunyai mekanisme tamat masa terbina dalam? Jawapannya tidak. RPC bergantung pada protokol rangkaian dan sistem pengendalian asas untuk mengendalikan tamat masa. Pelaksanaan khusus berbeza-beza bergantung pada rangka kerja RPC yang digunakan dan platform yang dijalankan.
Melaksanakan Tamat Masa dengan Saluran
Jika tiada mekanisme tamat masa RPC asli, anda boleh melaksanakan corak tamat masa menggunakan saluran. Berikut ialah contoh menggunakan pakej golang.org/x/net/rpc:
<code class="go">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 }</code>
Dalam contoh ini, goroutine dicipta untuk melakukan panggilan RPC sementara goroutine utama menunggu pada saluran (c). Jika panggilan RPC kembali sebelum tamat masa tamat, hasilnya disimpan dalam saluran. Jika tidak, penyataan pilih jatuh ke dalam kes timeoutNanoseconds, menunjukkan bahawa panggilan telah tamat masa.
Atas ialah kandungan terperinci Bagaimana untuk Melaksanakan Tamat Masa dalam Panggilan RPC Tanpa Sokongan Asli?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!