首頁 > 後端開發 > php教程 > PHP效能問題分析+最佳化

PHP效能問題分析+最佳化

little bottle
發布: 2023-04-06 06:58:02
轉載
2470 人瀏覽過

這篇文章是關於PHP效能問題分析 最佳化,有興趣的朋友可以來了解一下喔!

什麼情況下,遇到了PHP效能問題?
    1 PHP語法使用的不恰當
    2 使用PHP語言做不了它不擅長做的事
    3 用php語言連結的服務不給力##   ##   14 PHP自身的短板
    5 我也不知道的問題


效能問題解析
        PHP的效能問題,佔整個專案效能問題的比例小於50%

        效能最佳化項目,不要侷限於僅最佳化PHP

    php語言等級的效能最佳化
             |
    php週邊問題的效能最佳化
            |
            |
#      與選擇壓力


##Apache Benchmark(ab)(自行下載)
    ab是Apache提供的壓力測試軟體,安裝apache伺服器時會自備此壓測軟體。


如何使用?
    ./ab -n1000 -c100 http://www.baidu.com/         -n請求數
                    url目標壓縮位址




PHP-壓力測試工具使用示範




    主要專注於每秒並發盡可能的多

    請求耗時的少

多重使用PHP自身能力

    最佳化:少寫程式碼,多使用PHP自身能力##       效能問題: 自身能力      程式碼冗餘較多,可讀性不佳,且效能低
    為甚效能低?
         PHP程式碼需要編譯解析為底層語言,此流程每次要求都會處理一遍,且開銷大。

    好的方法:
        多使用PHP內建變數\常數\函數

PHP自身能力效能測試程式碼準備

    
#php程式碼運算

##*.php ---Scanner---> Exprs -----Parser--->Opcodes---Exec--->Output




php內建函數之間的效能測試



    最佳化點:php內建函數的效能優劣

         說明: php內建函數,之間仍存在區塊慢差異
        好的建議: 多去了解PHP內建函數的時間複雜度


php內建函數之間的效能測試程式碼測試



    isset($arr[$i]); //平均50ms
    array_key_exists($i,$arr);//平均85ms


減少PHP魔法函數的使用

    狀況描述:  PHP提供的魔法函數,表現不佳
    為什麼效能低為了給PHP程式猿省事PHP語言為你做了很多

    好的方法盡可能規避使用PHP魔法函數




PHP 停用錯誤抑制符號

    @的實際邏輯
##        在程式碼開始前結束後增加Opcode 忽略報錯

    php -dv|d.active=1 -dv|d.execute=0 at.php

    只是想看並不是真的想執行


#PHP-合理的使用記憶體和正規表示式
    最佳化點:合理使用記憶體

    PHP有記憶體回收機制保底,但也請小心使用記憶體

   好的建議使用正則表達式

        正則表達式的回溯開銷較大,

    好的建議:
        利用字符串處理函數,實現相同邏輯


PHP-避免在循環內做運算

    最佳化點:避免在循環內做運算

    情境說明:
        循環內的計算式將會重複計算

    程式碼範例:
                    $str = "hello world";
   );        {
                //do something
           }


PHP-減少計算中運算子
PHP不適合做大數據量運算


PHP適合場景

    適合銜接Webserver與後盾服務,UI呈現


PHP-務必使用引號字串做鍵值

    PHP會將沒有引號的鍵值當作常數,產生查找常數的開銷

    嚴格使用引號的字串作為鍵值




#PHP週邊問題的分析與闡述



    PHP週邊都有什麼?

        linux運作環境  php   硬碟(檔案儲存)  資料庫(例如mysql) 快取網路
php週邊對PHP程式的影響分析

#減少檔案類別的操作

    常見PHP場景的開銷順序:

        讀寫磁碟讀寫資料庫讀寫記憶體讀寫網路資料

        讀寫入記憶體<< 讀寫資料庫< 讀取與寫入網路資料



#11212



筆筆網路資料



減少PHP發起網路請求    
    網路請求的坑:
        1 對方介面的不確定因素
  性
    最佳化網路請求

        1 設定逾時時間
            連線逾時200ms##         寫逾時   500ms
        
        2 將序列請求並行化

            1 curl_multi_*()
            2 使用swoole 
#  與定時的時間延長者為依定的時間決定的比例是依定的時間決定的比例curl_multi_add_handle 為curl批次會話中新增單獨的curl句柄
        curl_multi_close 關閉一組cURL句柄
      curl_multi_exec 位元組執行子使用的當前位元連接子#L#L.curl_multi_getcontent 如果設定了CURLOPT_RETURNTRANSFER,則回傳取得的輸出的文字流
        curl_multi_info_read 取得目前解析的cURL的相關傳輸資訊# #.     curl_multi_select 等待所有cURL批次中的活動連結
        curl_multi_setopt Set an option for the cURL multi handle
        curl_multi_strerror -#      擴充來做




壓縮PHP輸出的利弊


    壓縮php介面的輸出    如何壓縮?         使用Gzip即可
    利  為我們的資料輸出,可更快擷取資料
    弊  額外的資料
#    在什麼情況下做輸出內容的快取?
        多次要求,內容不變狀況


Smarty調優與重疊時間視窗想法

    Smarty開啟caching

    重疊時間視窗想法  
        序列:
            Process1 Process2 Process3 Process4

                 process2
                    process3
     一個任務不強烈依賴前一個任務的時候,可以使用重疊時間




PHP旁路處理方案



    一般普通的: x.php -> Process1 ->process2 ->process3 -> process4->
    
    旁路方案: x.php -> Process1 ->process2(同時) ->Process33 -> Process1 ->process2(同時) ->Process33) -> (同時) -->Process4->

推薦教學:
PHP影片教學


以上是PHP效能問題分析+最佳化的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:cnblogs.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板