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 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!