PHP 擴展:php-affinity

jopen 9年前發布 | 13K 次閱讀 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;
                    }

提供了如下三個函數:

  1. setaffinity – 設置cpu親和性

  2. getaffinity – 獲取cpu親和性

  3. getcpucores – 獲取cpu核心數量

API 如下:

參考文獻:

  1. https://zh.wikipedia.org/wiki/%E5%A4%84%E7%90%86%E5%99%A8%E4%BA%B2%E5%92%8C%E6%80%A7

  2. http://www.ibm.com/developerworks/cn/linux/l-affinity.html

  3. http://www.cnblogs.com/LubinLew/p/cpu_affinity.html

項目主頁:http://www.baiduhome.net/lib/view/home/1448371981438

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