Rumah > rangka kerja php > Swoole > Adakah coroutine swoole tergolong dalam proses atau benang?

Adakah coroutine swoole tergolong dalam proses atau benang?

WBOY
Lepaskan: 2022-03-14 15:37:57
asal
2848 orang telah melayarinya

Swoole coroutine tergolong dalam benang. Coroutines dilaksanakan dalam utas Coroutines adalah utas ringan Pelaksanaan asas coroutine Swoole adalah satu coroutine yang berfungsi pada masa yang sama, dan utas akan dijadualkan oleh sistem pengendalian untuk berbilang CPU.

Adakah coroutine swoole tergolong dalam proses atau benang?

Persekitaran pengendalian tutorial ini: sistem Windows 10, versi Swoole 4, komputer DELL G3

Adakah coroutine swoole satu proses atau benang

Apakah itu proses?

Proses ialah program yang dijalankan dalam sistem Setelah program berjalan, ia adalah satu proses.

Sesuatu proses boleh dilihat sebagai contoh pelaksanaan program.

Teg: Satu proses tidak boleh mengakses pembolehubah dan struktur data proses lain Jika anda mahu satu proses mengakses sumber proses lain, anda perlu menggunakan komunikasi antara proses, seperti paip, fail, soket. , dsb.

Apakah benang?

Thread tergolong dalam proses dan merupakan pelaksana program.

Sesuatu proses mengandungi sekurang-kurangnya satu utas utama dan juga boleh mempunyai lebih banyak sub-utas Setiap utas menggunakan ruang tindanan proses yang menjadi miliknya.

Benang ialah entiti proses dan laluan pelaksanaan proses tersebut.

Teg: Berbilang rangkaian dalam proses yang sama akan berkongsi sebahagian daripada keadaan dan berbilang rangkaian boleh membaca dan menulis memori yang sama.

Apakah itu coroutine?

Coroutine secara relatifnya adalah mekanisme penjadualan tertentu dalam program; . Operasi, penggunaan adalah sangat rendah.

Coroutine tergolong dalam thread dan coroutine dilaksanakan dalam thread.

Penjadualan coroutine ditukar secara manual oleh pengguna, jadi ia juga dipanggil urutan ruang pengguna.

Strategi penjadualan coroutine ialah: penjadualan kolaboratif.

Perbezaan antara coroutine dan thread:

Coroutine Swoole adalah satu-thread dalam pelaksanaan asas, jadi hanya terdapat satu coroutine yang berfungsi pada masa yang sama bersiri. Ini berbeza daripada urutan berbilang akan dijadualkan oleh sistem pengendalian kepada berbilang CPU untuk pelaksanaan selari.

Semasa satu coroutine sedang berjalan, coroutine lain akan berhenti berfungsi. Coroutine semasa akan tergantung apabila melakukan operasi menyekat IO dan penjadual asas akan memasuki gelung acara. Apabila peristiwa penyiapan IO berlaku, penjadual asas menyambung semula pelaksanaan coroutine yang sepadan dengan acara tersebut.

Penggunaan berbilang teras CPU masih bergantung pada mekanisme berbilang proses enjin Swoole.

Senario terpakai untuk coroutine:

Perkhidmatan konkurensi tinggi, seperti sistem jualan kilat, antara muka API berprestasi tinggi, pelayan RPC, menggunakan mod coroutine, kadar toleransi kesalahan perkhidmatan akan meningkat Sangat meningkat, apabila beberapa antara muka gagal, keseluruhan perkhidmatan tidak akan runtuh.

Crawler boleh mencapai keupayaan serentak yang sangat besar dan boleh menggunakan lebar jalur dengan cekap walaupun dalam persekitaran rangkaian yang sangat perlahan.

Perkhidmatan pemesejan segera, seperti sembang IM, pelayan permainan, Internet of Things, pelayan mesej, dsb., boleh memastikan komunikasi mesej tidak disekat sepenuhnya dan setiap paket mesej boleh diproses serta-merta.

Pembelajaran yang disyorkan:

tutorial swole

Atas ialah kandungan terperinci Adakah coroutine swoole tergolong dalam proses atau benang?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
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