Dalam swoole, pelayan Swoole menerima data dan mencetuskan panggilan balik onReceive dalam proses pekerja untuk menghasilkan coroutine yang sepadan untuk setiap permintaan juga boleh dibuat dalam coroutine dilaksanakan di bahagian bawah Ia adalah satu-benang, jadi hanya satu coroutine berfungsi pada masa yang sama.
Persekitaran pengendalian tutorial ini: sistem Windows 10, versi Swoole 4, komputer DELL G3
Apakah itu proses?
Proses ialah contoh permulaan permohonan. Sumber fail bebas, sumber data dan ruang ingatan.
Apakah benang?
Thread tergolong dalam proses dan merupakan pelaksana program. Satu proses mengandungi sekurang-kurangnya satu utas utama dan juga boleh mempunyai lebih banyak utas anak. Thread mempunyai dua strategi penjadualan, satu ialah: penjadualan perkongsian masa, dan satu lagi ialah: penjadualan preemptive.
Apakah itu coroutine?
Coroutine ialah benang ringan, coroutine juga tergolong dalam benang dan coroutine dilaksanakan dalam benang. Penjadualan coroutines ditukar secara manual oleh pengguna, jadi ia juga dipanggil benang ruang pengguna. Penciptaan, penukaran, penggantungan dan pemusnahan coroutine adalah semua operasi ingatan, dan penggunaannya sangat rendah. Strategi penjadualan coroutine ialah: penjadualan kolaboratif.
Prinsip Swoole coroutine
Swoole4 adalah single-threaded dan multi-process, jadi hanya akan ada satu coroutine yang berjalan dalam proses yang sama pada masa yang sama.
Pelayan Swoole menerima data dan mencetuskan panggilan balik onReceive dalam proses pekerja, menghasilkan Ctrip. Swoole mencipta Ctrip yang sepadan untuk setiap permintaan. Sub-coroutine juga boleh dibuat dalam coroutine.
Pelaksanaan asas coroutine adalah satu benang, jadi hanya terdapat satu coroutine yang berfungsi pada masa yang sama dan pelaksanaan coroutine adalah bersiri.
Oleh itu, apabila multi-tasking dan multi-coroutine dilaksanakan, apabila 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 terdapat acara penyiapan IO, penjadual asas menyambung semula pelaksanaan coroutine yang sepadan dengan acara tersebut. . Oleh itu, coroutine tidak mempunyai penggunaan masa IO dan sangat sesuai untuk senario IO berkonkurensi tinggi. (Seperti yang ditunjukkan dalam gambar di bawah)
Proses pelaksanaan coroutine Swoole
Coroutine tidak mempunyai IO dan sedang menunggu pelaksanaan biasa kod PHP tidak akan menyebabkan penukaran aliran pelaksanaan
Apabila coroutine menemui IO, ia akan segera menukar kawalan Selepas IO selesai, aliran pelaksanaan akan ditukar kembali ke coroutine asal. Klik
coroutine dan selari coroutine untuk melaksanakan dalam urutan, logik yang sama seperti proses pelaksanaan bersarang coroutine sebelumnya
dimasukkan lapisan demi lapisan dari luar ke dalam sehingga IO berlaku, dan kemudian bertukar kepada coroutine luar tidak akan menunggu untuk tamat coroutine anak
Pelaksanaan. susunan coroutine
Mari kita lihat contoh asas dahulu:
go(function () { echo "hello go1 \n";});echo "hello main \n";go(function () { echo "hello go2 \n";});
go() ialah singkatan Co::create(), yang digunakan untuk buat coroutine dan terima panggil balik sebagai parameter Kod dalam panggil balik akan berada di sini Dilaksanakan dalam coroutine yang baru dibuat.
Catatan: SwooleCoroutine boleh disingkatkan sebagai Co
Hasil pelaksanaan kod di atas:
root@b98940b00a9b /v/w/c/p/swoole# php co.phphello go1 hello main hello go2
Hasil pelaksanaan adalah sama seperti susunan yang biasa kita tulis kod , nampaknya tiada perbezaan Proses pelaksanaan sebenar:
Jalankan. kod ini, sistem memulakan proses baharu
bertemu go(), Coroutine dijana dalam proses semasa dan heelo go1 dikeluarkan dalam coroutine keluar
Proses terus melaksanakan kod ke bawah dan mengeluarkan hello main
Jana semula coroutine, keluarkan heelo go2 dalam coroutine, keluar dari coroutine
Jalankan kod ini, sistem memulakan proses baharu Jika anda tidak faham ayat ini, anda boleh Gunakan kod berikut:
// co.php<?phpsleep(100);
Laksanakan dan gunakan ps aux. untuk melihat proses dalam sistem:
root@b98940b00a9b /v/w/c/p/swoole# php co.php &⏎ root@b98940b00a9b /v/w/c/p/swoole# ps auxPID USER TIME COMMAND 1 root 0:00 php -a 10 root 0:00 sh 19 root 0:01 fish 749 root 0:00 php co.php 760 root 0:00 ps aux
Mari kita buat sedikit perubahan dan alami penjadualan coroutine:
use Co;go(function () { Co::sleep(1); // 只新增了一行代码 echo "hello go1 \n";});echo "hello main \n";go(function () { echo "hello go2 \n";}); \Co::sleep() 函数功能和 sleep() 差不多, 但是它模拟的是 IO等待(IO后面会细讲). 执行的结果如下: root@b98940b00a9b /v/w/c/p/swoole# php co.phphello main hello go2 hello go1
Mengapa ia tidak dilaksanakan secara berurutan:
Jalankan kod ini, sistem memulakan proses baharu
Apabila go() ditemui, coroutine
dijana dalam proses semasa Coroutine menghadapi sekatan IO (di sini ialah menunggu IO disimulasikan oleh Co::sleep()), dan coroutine Serah kawalan dan masukkan baris gilir penjadualan coroutine
Proses terus melaksanakan ke bawah dan mengeluarkan hello main
Melaksanakan coroutine seterusnya dan output hello go2
Sebelumnya coroutine sudah sedia, teruskan pelaksanaan, dan keluarkan hello go1
Pada ketika ini, anda sudah boleh melihat coroutine swoole dan Mengenai hubungan antara proses dan penjadualan coroutine, mari tukar atur cara tadi:
go(function () { Co::sleep(1); echo "hello go1 \n";});echo "hello main \n";go(function () { Co::sleep(1); echo "hello go2 \n";});
Saya rasa anda sudah tahu rupa outputnya:
root@b98940b00a9b /v/w/c/p/swoole# php co.phphello main hello go1 hello go2
Pembelajaran yang disyorkan : tutorial swole
Atas ialah kandungan terperinci Apakah prinsip pelaksanaan coroutine swoole?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!