Infinite-Loop Goroutine Blocks Go HTTP Server
Waktu jalan Go, bertanggungjawab untuk mengurus pelaksanaan serentak, berbangga dengan operasi tanpa sekatan. Walau bagaimanapun, senario yang melibatkan goroutine gelung tak terhingga yang dimulakan dari dalam pelayan HTTP menimbulkan kebimbangan. Walaupun mempunyai benang dan goroutin yang mencukupi (mengikut runtime.GOMAXPROCS), gelung tak terhingga ini nampaknya menghalang pengendalian pelayan terhadap permintaan lain.
Untuk menggambarkan isu ini, anda telah menyediakan kod sampel yang menampilkan pelayan dengan infiniti -loop goroutine (dilumpuhkan secara lalai) dan pelanggan menghantar permintaan HTTP serentak. Dengan goroutine dilumpuhkan, pelanggan memaparkan set asterisk yang dijangkakan. Walau bagaimanapun, mendayakannya membawa kepada sekatan dalam output pelanggan selepas beberapa permintaan.
Misteri berterusan walaupun selepas bereksperimen dengan runtime.LockOSThread dalam goroutine, kerana ia gagal menyelesaikan sekatan. Menurut dokumentasi Go, runtime.LockOSThread harus melaksanakan gelung tak terhingga dalam urutan yang berasingan, meninggalkan gorouti lain tidak terjejas.
Tingkah laku membingungkan ini boleh dikaitkan dengan penjadual masa jalan Go. Walaupun preemptive sedikit sebanyak, ia tidak sepenuhnya begitu. Go 1.2 memperkenalkan penambahbaikan dengan memaksa panggilan penjadual sekali-sekala semasa panggilan fungsi. Walau bagaimanapun, gelung tak terhingga dalam contoh ini kekurangan panggilan fungsi, memintas penyelesaian ini.
Pertimbangkan untuk menambah kerja bermakna pada pengendali gelung tak terhingga anda. Sebagai alternatif, panggilan yang disengajakan ke masa jalan.Gosched boleh mengurangkan isu penyekatan.
Atas ialah kandungan terperinci Mengapakah Infinite-Loop Goroutine Menyekat Pelayan HTTP Go Walaupun Sumber Mencukupi?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!