自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

PHP協(xié)程:Go+Chan+Defer

開發(fā) 后端
Swoole4提供的Go + Chan + Defer為PHP帶來了一種全新的CSP并發(fā)編程模式。靈活使用Swoole4提供的各項(xiàng)特性,可以解決工作中各類復(fù)雜功能的設(shè)計(jì)和開發(fā)。

 [[251467]]

Swoole4為PHP語言提供了強(qiáng)大的CSP協(xié)程編程模式。底層提供了3個(gè)關(guān)鍵詞,可以方便地實(shí)現(xiàn)各類功能

Swoole4提供的PHP協(xié)程語法借鑒自Golang,在此向GO開發(fā)組致敬

PHP+Swoole協(xié)程可以與Golang很好地互補(bǔ)。Golang:靜態(tài)語言,嚴(yán)謹(jǐn)強(qiáng)大性能好,PHP+Swoole:動(dòng)態(tài)語言,靈活簡單易用

本文基于Swoole-4.2.9和PHP-7.2.9版本

關(guān)鍵詞

  •  go :創(chuàng)建一個(gè)協(xié)程
  •  chan :創(chuàng)建一個(gè)通道
  •  defer :延遲任務(wù),在協(xié)程退出時(shí)執(zhí)行,先進(jìn)后出

這3個(gè)功能底層實(shí)現(xiàn)全部為內(nèi)存操作,沒有任何IO資源消耗。就像PHP的Array一樣是非常廉價(jià)的。如果有需要就可以直接使用。這與socket和file操作不同,后者需要向操作系統(tǒng)申請端口和文件描述符,讀寫可能會(huì)產(chǎn)生阻塞的IO等待。

協(xié)程并發(fā)

使用go函數(shù)可以讓一個(gè)函數(shù)并發(fā)地去執(zhí)行。在編程過程中,如果某一段邏輯可以并發(fā)執(zhí)行,就可以將它放置到go協(xié)程中執(zhí)行。

順序執(zhí)行 

  1. function test1()   
  2. {  
  3.     sleep(1);  
  4.     echo "b";  
  5. }  
  6. function test2()   
  7. {  
  8.     sleep(2);  
  9.     echo "c";  
  10. }  
  11. test1();  
  12. test2(); 

執(zhí)行結(jié)果: 

  1. htf@LAPTOP-0K15EFQI:~$ time php b1.php  
  2. bc  
  3. real    0m3.080s  
  4. user    0m0.016s  
  5. sys     0m0.063s  
  6. htf@LAPTOP-0K15EFQI:~$ 

上述代碼中,test1和test2會(huì)順序執(zhí)行,需要3秒才能執(zhí)行完成。

并發(fā)執(zhí)行

使用go創(chuàng)建協(xié)程,可以讓test1和test2兩個(gè)函數(shù)變成并發(fā)執(zhí)行。 

  1. Swoole\Runtime::enableCoroutine();  
  2. go(function ()   
  3. {  
  4.     sleep(1);  
  5.     echo "b";  
  6. });    
  7. go(function ()   
  8. {  
  9.     sleep(2);  
  10.     echo "c";  
  11. }); 

Swoole\Runtime::enableCoroutine()作用是將PHP提供的stream、sleep、pdo、mysqli、redis等功能從同步阻塞切換為協(xié)程的異步IO 

執(zhí)行結(jié)果: 

  1. bchtf@LAPTOP-0K15EFQI:~$ time php co.php  
  2. bc  
  3. real    0m2.076s  
  4. user    0m0.000s  
  5. sys     0m0.078s  
  6. htf@LAPTOP-0K15EFQI:~$ 

可以看到這里只用了2秒就執(zhí)行完成了。

  •  順序執(zhí)行耗時(shí)等于所有任務(wù)執(zhí)行耗時(shí)的總和 :t1+t2+t3...
  •  并發(fā)執(zhí)行耗時(shí)等于所有任務(wù)執(zhí)行耗時(shí)的***值 :max(t1, t2, t3, ...)

協(xié)程通信

有了go關(guān)鍵詞之后,并發(fā)編程就簡單多了。與此同時(shí)又帶來了新問題,如果有2個(gè)協(xié)程并發(fā)執(zhí)行,另外一個(gè)協(xié)程,需要依賴這兩個(gè)協(xié)程的執(zhí)行結(jié)果,如果解決此問題呢?

答案就是使用通道(Channel),在Swoole4協(xié)程中使用new chan就可以創(chuàng)建一個(gè)通道。通道可以理解為自帶協(xié)程調(diào)度的隊(duì)列。它有兩個(gè)接口push和pop:

  •  push:向通道中寫入內(nèi)容,如果已滿,它會(huì)進(jìn)入等待狀態(tài),有空間時(shí)自動(dòng)恢復(fù)
  •  pop:從通道中讀取內(nèi)容,如果為空,它會(huì)進(jìn)入等待狀態(tài),有數(shù)據(jù)時(shí)自動(dòng)恢復(fù)

使用通道可以很方便地實(shí)現(xiàn)并發(fā)管理。 

  1. $chan = new chan(2);  
  2. # 協(xié)程1  
  3. go (function () use ($chan) {  
  4.     $result = [];  
  5.     for ($i = 0; $i < 2; $i++)  
  6.     {  
  7.         $result += $chan->pop();  
  8.     }  
  9.     var_dump($result);  
  10. });  
  11. # 協(xié)程2  
  12. go(function () use ($chan) {  
  13.    $cli = new Swoole\Coroutine\Http\Client('www.qq.com', 80);  
  14.        $cli->set(['timeout' => 10]);  
  15.        $cli->setHeaders([  
  16.        'Host' => "www.qq.com",  
  17.        "User-Agent" => 'Chrome/49.0.2587.3',  
  18.        'Accept' => 'text/html,application/xhtml+xml,application/xml',  
  19.        'Accept-Encoding' => 'gzip',  
  20.    ]);  
  21.    $ret = $cli->get('/');  
  22.    // $cli->body 響應(yīng)內(nèi)容過大,這里用 Http 狀態(tài)碼作為測試  
  23.    $chan->push(['www.qq.com' => $cli->statusCode]); 
  24.  });  
  25. # 協(xié)程3  
  26. go(function () use ($chan) {  
  27.    $cli = new Swoole\Coroutine\Http\Client('www.163.com', 80);  
  28.    $cli->set(['timeout' => 10]);  
  29.    $cli->setHeaders([  
  30.        'Host' => "www.163.com",  
  31.        "User-Agent" => 'Chrome/49.0.2587.3',  
  32.        'Accept' => 'text/html,application/xhtml+xml,application/xml',  
  33.        'Accept-Encoding' => 'gzip',  
  34.    ]);  
  35.    $ret = $cli->get('/');  
  36.    // $cli->body 響應(yīng)內(nèi)容過大,這里用 Http 狀態(tài)碼作為測試  
  37.    $chan->push(['www.163.com' => $cli->statusCode]);  
  38. }); 

執(zhí)行結(jié)果: 

  1. htf@LAPTOP-0K15EFQI:~/swoole-src/examples/5.0$ time php co2.php  
  2. array(2) {  
  3.   ["www.qq.com"]=>  
  4.   int(302)  
  5.   ["www.163.com"]=>  
  6.   int(200) 
  7. }  
  8. real    0m0.268s  
  9. user    0m0.016s  
  10. sys     0m0.109s  
  11. htf@LAPTOP-0K15EFQI:~/swoole-src/examples/5.0$ 

這里使用go創(chuàng)建了3個(gè)協(xié)程,協(xié)程2和協(xié)程3分別請求qq.com和163.com主頁。協(xié)程1需要拿到Http請求的結(jié)果。這里使用了chan來實(shí)現(xiàn)并發(fā)管理。

  •  協(xié)程1循環(huán)兩次對通道進(jìn)行pop,因?yàn)殛?duì)列為空,它會(huì)進(jìn)入等待狀態(tài)
  •  協(xié)程2和協(xié)程3執(zhí)行完成后,會(huì)push數(shù)據(jù),協(xié)程1拿到了結(jié)果,繼續(xù)向下執(zhí)行

延遲任務(wù)

在協(xié)程編程中,可能需要在協(xié)程退出時(shí)自動(dòng)實(shí)行一些任務(wù),做清理工作。類似于PHP的register_shutdown_function,在Swoole4中可以使用defer實(shí)現(xiàn)。 

  1. Swoole\Runtime::enableCoroutine();  
  2. go(function () {  
  3.     echo "a";  
  4.     defer(function () {  
  5.         echo "~a";  
  6.     });  
  7.     echo "b";  
  8.     defer(function () {  
  9.         echo "~b";  
  10.     });  
  11.     sleep(1);  
  12.     echo "c";  
  13. }); 

執(zhí)行結(jié)果: 

  1. htf@LAPTOP-0K15EFQI:~/swoole-src/examples/5.0$ time php defer.php  
  2. abc~b~a  
  3. real    0m1.068s  
  4. user    0m0.016s  
  5. sys     0m0.047s  
  6. htf@LAPTOP-0K15EFQI:~/swoole-src/examples/5.0$ 

結(jié)語

Swoole4提供的Go + Chan + Defer為PHP帶來了一種全新的CSP并發(fā)編程模式。靈活使用Swoole4提供的各項(xiàng)特性,可以解決工作中各類復(fù)雜功能的設(shè)計(jì)和開發(fā)。

責(zé)任編輯:龐桂玉 來源: segmentfault
相關(guān)推薦

2024-05-29 08:05:15

Go協(xié)程通信

2016-10-28 17:39:47

phpgolangcoroutine

2017-05-02 11:38:00

PHP協(xié)程實(shí)現(xiàn)過程

2024-12-03 15:15:22

2023-07-27 13:46:10

go開源項(xiàng)目

2017-08-10 15:50:44

PHP協(xié)程阻塞

2021-04-25 09:36:20

Go協(xié)程線程

2024-06-27 07:56:49

2023-07-13 08:06:05

應(yīng)用協(xié)程阻塞

2025-02-28 09:04:08

2021-09-16 09:59:13

PythonJavaScript代碼

2022-10-28 10:45:22

Go協(xié)程GoFrame

2024-08-27 09:46:39

Go協(xié)程效率

2021-05-21 08:21:57

Go語言基礎(chǔ)技術(shù)

2025-01-26 00:00:15

PHP協(xié)程控制權(quán)

2023-11-17 11:36:59

協(xié)程纖程操作系統(tǒng)

2021-09-27 23:28:29

Go多協(xié)程并發(fā)

2025-02-08 09:13:40

2023-10-24 19:37:34

協(xié)程Java

2021-12-09 06:41:56

Python協(xié)程多并發(fā)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號