Rumah > rangka kerja php > Swoole > Apakah prinsip pelaksanaan coroutine swoole?

Apakah prinsip pelaksanaan coroutine swoole?

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Lepaskan: 2022-02-14 17:42:41
asal
6897 orang telah melayarinya

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.

Apakah prinsip pelaksanaan coroutine swoole?

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

Apakah prinsip pelaksanaan coroutine swoole

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)

Apakah prinsip pelaksanaan coroutine swoole?

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";});
Salin selepas log masuk

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
Salin selepas log masuk

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);
Salin selepas log masuk

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
Salin selepas log masuk

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
Salin selepas log masuk

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";});
Salin selepas log masuk

Saya rasa anda sudah tahu rupa outputnya:

root@b98940b00a9b /v/w/c/p/swoole# php co.phphello main
hello go1
hello go2
Salin selepas log masuk

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!

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