PHP 擴展:php-affinity
Php-affinity 通過設置cpu親和性,可以將進程綁定到一個cpu核心上。一般在如下場景我們可能會希望修改進程的cpu親和性:
-
頻繁的并行運算
-
線程可伸縮性測試(通過增加cpu核心數量模擬線性擴展)
-
運行時間敏感的,決定性的進程
向nginx,swoole等開源軟件,都提供了設置cpu親和性的方法。nginx官方建議worker數量等同于cpu核心數量也是為了將一個進程綁定到一個cpu核心上,同時避免進程切換帶來的開銷。
Php本身并沒有提供設置cpu親和性的函數,我們可以通過兩種方式實現:
-
調用系統命令,修改當前進程cpu親和性
-
編寫php擴展,封裝系統調用。
php-affinity是使用c編寫的php擴展,項目地址:https://github.com/huyanping/php-affinity
/** * set CPU affinity * * @param $cpu_id * @return bool */ functionsetaffinity($cpu_id){ $num= getcpucores(); if($cpu_id>= $num){ returnfalse; } $set= system_call($cpu_id); if($set=== -1){ returnfalse; } returntrue; } /** * get CPU affinity * * @return bool */ functiongetaffinity(){ $cpu_id= system_call(); if($cpu_id=== -1){ returnfalse; } return$cpu_id; } /** * get number of CPU * * @return bool */ functiongetcpucores(){ $nums= system_call(); if($nums=== -1){ returnfalse; } return$nums; }
提供了如下三個函數:
-
setaffinity – 設置cpu親和性
-
getaffinity – 獲取cpu親和性
-
getcpucores – 獲取cpu核心數量
API 如下:
參考文獻:
本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!