# vi /etc/php.iniphp
(1) PHP函數禁用找到:html
disable_functions =
該選項能夠設置哪些PHP函數是禁止使用的,PHP中有一些函數的風險性仍是至關大的,能夠直接執行一些系統級腳本命令,若是容許這些函數執行,當PHP程序出現漏洞時,損失是很是嚴重的!如下咱們給出推薦的禁用函數設置:c++
disable_functions = phpinfo,passthru,exec,system,popen,chroot,escapeshellcmd,escapeshellarg,shell_exec,proc_open,proc_get_status正則表達式
需注意:若是您的服務器中含有一些系統狀態檢測的PHP程序,則不要禁用shell_exec,proc_open,proc_get_status等函數。(2) PHP腳本執行時間找到:shell
max_execution_time = 30數據庫
該 選項設定PHP程序的最大執行時間,若是一個PHP腳本被請求,且該PHP腳本在max_execution_time時間內沒能執行完畢,則PHP再也不 繼續執行,直接給客戶端返回超時錯誤。沒有特殊須要該選項可保持默認設置30秒,若是您的PHP腳本確實須要長執行時間則能夠適當增大該時間設置。(3) PHP腳本處理內存佔用找到:apache
memory_limit = 8M數組
該選項指定PHP腳本處理所能佔用的最大內存,默認爲8MB,若是您的服務器內存爲1GB以上,則該選項能夠設置爲12MB以得到更快的PHP腳本處理效率。(4) PHP全局函數聲明找到:緩存
register_globals = Off安全
網絡上不少關於PHP設置的文章都推薦將該選項設置爲On,其實這是一種及其危險的設置方法,極可能引發嚴重的安全性問題。若是沒有特殊的須要,強烈推薦保留默認設置!(5) PHP上傳文件大小限制找到:
upload_max_filesize = 2M
該選項設定PHP所能容許最大上傳文件大小,默認爲2MB。根據實際應用需求,能夠適當增大該設置。(6) Session存儲介質找到:
session.save_path
如 果你的PHP程序使用Session對話,則能夠將Session存儲位置設置爲/dev/shm,/dev/shm是Linux系統獨有的TMPFS文 件系統,是之內存爲主要存儲方式的文件系統,比RAMDISK更優秀,由於可使用DISKSWAP做爲補充,並且是系統自帶的功能模塊,不須要另行配 置。想一想看,從磁盤IO操做到內存操做,速度會快多少?只是須要注意,存儲在/dev/shm的數據,在服務器重啓後會所有丟失。不過這對於 Session來講是無足輕重的。
因爲水平有限,有些仍是不太明白爲何。若是有更好建議的歡迎隨時補充!
0、 用單引號代替雙引號來包含字符串,這樣作會更快一些。由於PHP會在雙引號包圍的字符串中搜尋變量,單引號則不會,注意:只有echo能這麼作,它是一種 能夠把多個字符串看成參數的「函數」(譯註:PHP手冊中說echo是語言結構,不是真正的函數,故把函數加上了雙引號)。
PS:在單引號中,PHP不會自動搜尋變量、轉義字符等,所以效率上快不少。而通常來講字符串是沒有變量的,因此使用雙引號會致使性能不佳。
一、若是能將類的方法定義成static,就儘可能定義成static,它的速度會提高將近4倍。
PS:事實上,function、method、static method的速度不會有太大差別。具體可見「PHP函數的實現原理及性能分析【轉載】」一文。
二、$row[’id’] 的速度是$row[id]的7倍。
PS:不太懂,貌似差別只有後者會先判斷id這個宏是否存在,若是不存在則自動轉變爲字符串。
三、echo 比 print 快,而且使用echo的多重參數(譯註:指用逗號而不是句點)代替字符串鏈接,好比echo $str1,$str2。
PS:若是使用echo $str1.$str2 就會須要 PHP 引擎首先把全部的變量鏈接起來,而後在輸出,而echo $str1,$str2,PHP 引擎就會按照循序輸出他們
四、在執行for循環以前肯定最大循環數,不要每循環一次都計算最大值,最好運用foreach代替。
PS: 像count、strlen這樣的操做實際上是O(1)的,所以不會帶來太多消耗,固然避免每次循環都計算是比較好的策略。最好用foreach代替 for,這個效率更高,若是考慮到foreach($array as $var)每次拷貝的消耗,可使用foreach($array as &$var)這樣的引用。
五、註銷那些不用的變量尤爲是大數組,以便釋放內存。
PS:若是沒有記錯的話,unset($array)不會馬上釋放內存,但隨時釋放是個好習慣。
六、儘可能避免使用__get,__set,__autoload。
七、require_once()代價昂貴。
PS:require_once和include_once須要判重,所以效率上要低,可是5.2版本後效率問題已經基本解決。
八、include文件時儘可能使用絕對路徑,由於它避免了PHP去include_path裏查找文件的速度,解析操做系統路徑所需的時間會更少。
PS:支持,儘可能少用iniset()來設置include_path。
九、若是你想知道腳本開始執行(譯註:即服務器端收到客戶端請求)的時刻,使用$_SERVER['REQUEST_TIME']要好於time()。
PS:$_SERVER['REQUEST_TIME']保存了發起該請求時刻的時間戳,而time()則返回當前時刻的Unix時間戳。
十、函數代替正則表達式完成相同功能。
PS:這種函數是指strtok、strstr、strpos、str_replace、substr、explode、implode等等。
十一、str_replace函數比preg_replace函數快,但strtr函數的效率是str_replace函數的四倍。
PS:字符串操做比正則替換要快。
十二、若是一個字符串替換函數,可接受數組或字符做爲參數,而且參數長度不太長,那麼能夠考慮額外寫一段替換代碼,使得每次傳遞參數是一個字符,而不是隻寫一行代碼接受數組做爲查詢和替換的參數。
PS:須要考慮到內置函數和用戶自定義函數的開銷差別,恐怕這種作法得不償失。
1三、使用選擇分支語句(譯註:即switch case)好於使用多個if,else if語句。
PS:php中switch支持數值和字符串變量,比C的switch要好用,建議使用。
1四、用@屏蔽錯誤消息的作法很是低效,極其低效。
PS:有什麼替代方法嗎?沒有的話仍是不得不用的……
1五、打開apache的mod_deflate模塊,能夠提升網頁的瀏覽速度。
1六、數據庫鏈接當使用完畢時應關掉,不要用長鏈接。
PS:在鏈接以前,最好設置一下相應的超時機制,例如連接超時、讀寫超時、等待超時等。
1七、錯誤消息代價昂貴。
1八、在方法中遞增局部變量,速度是最快的。幾乎與在函數中調用局部變量的速度至關。
1九、遞增一個全局變量要比遞增一個局部變量慢2倍。
20、遞增一個對象屬性(如:$this->prop++)要比遞增一個局部變量慢3倍。
2一、遞增一個未預約義的局部變量要比遞增一個預約義的局部變量慢9至10倍。
2二、僅定義一個局部變量而沒在函數中調用它,一樣會減慢速度(其程度至關於遞增一個局部變量)。PHP大概會檢查看是否存在全局變量。
2三、方法調用看來與類中定義的方法的數量無關,由於我(在測試方法以前和以後都)添加了10個方法,但性能上沒有變化。
2四、派生類中的方法運行起來要快於在基類中定義的一樣的方法。
2五、調用帶有一個參數的空函數,其花費的時間至關於執行7至8次的局部變量遞增操做。相似的方法調用所花費的時間接近於15次的局部變量遞增操做。
2六、Apache解析一個PHP腳本的時間要比解析一個靜態HTML頁面慢2至10倍。儘可能多用靜態HTML頁面,少用腳本。
2七、除非腳本能夠緩存,不然每次調用時都會從新編譯一次。引入一套PHP緩存機制一般能夠提高25%至100%的性能,以避免除編譯開銷。
2八、儘可能作緩存,可以使用memcached。memcached是一款高性能的內存對象緩存系統,可用來加速動態Web應用程序,減輕數據庫負載。對運算碼 (OP code)的緩存頗有用,使得腳本沒必要爲每一個請求作從新編譯。
2九、當操做字符串並須要檢驗其長度是否知足某種要求時,你想固然地會使用strlen()函數。此函數執行起來至關快,由於它不作任何計算,只返 回在zval 結構(C的內置數據結構,用於存儲PHP變量)中存儲的已知字符串長度。可是,因爲strlen()是函數,多多少少會有些慢,由於函數調用會通過諸多步 驟,如字母小寫化(譯註:指函數名小寫化,PHP不區分函數名大小寫)、哈希查找,會跟隨被調用的函數一塊兒執行。在某些狀況下,你可使用isset() 技巧加速執行你的代碼。
(舉例以下)
if (strlen($foo) < 5) { echo 「Foo is too short」$$ }
(與下面的技巧作比較)
if (!isset($foo{5})) { echo 「Foo is too short」$$ }
調用isset()恰巧比strlen()快,由於與後者不一樣的是,isset()做爲一種語言結構,意味着它的執行不須要函數查找和字母小寫化。也就是說,實際上在檢驗字符串長度的頂層代碼中你沒有花太多開銷。
PS:長見識了。
30、當執行變量$i的遞增或遞減時,$i++會比++$i慢一些。這種差別是PHP特有的,並不適用於其餘語言,因此請不要修改你的C或Java 代碼並期望它們能當即變快,沒用的。++$i更快是由於它只須要3條指令(opcodes),$i++則須要4條指令。後置遞增實際上會產生一個臨時變 量,這個臨時變量隨後被遞增。而前置遞增直接在原值上遞增。這是最優化處理的一種,正如Zend的PHP優化器所做的那樣。牢記這個優化處理不失爲一個好 主意,由於並非全部的指令優化器都會作一樣的優化處理,而且存在大量沒有裝配指令優化器的互聯網服務提供商(ISPs)和服務器。
3一、並非事必面向對象(OOP),面向對象每每開銷很大,每一個方法和對象調用都會消耗不少內存。
3二、並不是要用類實現全部的數據結構,數組也頗有用。
3三、不要把方法細分得過多,仔細想一想你真正打算重用的是哪些代碼?
3四、當你須要時,你總能把代碼分解成方法。
PS:分解成方法要適當,行數少使用頻率高的方法儘可能用直接寫代碼,能夠減小函數堆棧開銷;且方法嵌套不宜過深,不然大大影響PHP的運行效率。
3五、儘可能採用大量的PHP內置函數。
3六、若是在代碼中存在大量耗時的函數,你能夠考慮用C擴展的方式實現它們。
3七、評估檢驗(profile)你的代碼。檢驗器會告訴你,代碼的哪些部分消耗了多少時間。Xdebug調試器包含了檢驗程序,評估檢驗整體上能夠顯示出代碼的瓶頸。
3八、mod_zip可做爲Apache模塊,用來即時壓縮你的數據,並可以讓數據傳輸量下降80%。
3九、在能夠用file_get_contents替代file、fopen、feof、fgets等系列方法的狀況下,儘可能用 file_get_contents,由於他的效率高得多!可是要注意file_get_contents在打開一個URL文件時候的PHP版本問題;
PS:這個要記住,儘可能使用file_get_contents和file_put_contents,不須要本身判斷文件句柄打開是否成功。
40、儘可能的少進行文件操做,雖然PHP的文件操做效率也不低的;
4一、優化Select SQL語句,在可能的狀況下儘可能少的進行Insert、Update操做(在update上,我被惡批過);
4二、儘量的使用PHP內部函數(可是我卻爲了找個PHP裏面不存在的函數,浪費了本能夠寫出一個自定義函數的時間,經驗問題啊!);
PS:內置函數比用戶自定義函數效率高了將近一個數量級。
4三、循環內部不要聲明變量,尤爲是大變量:對象(這好像不僅是PHP裏面要注意的問題吧?);
PS:這個必須的,變量過多或者過大時,每次重分配的開銷就沒法忽略。
4四、多維數組儘可能不要循環嵌套賦值;
4五、在能夠用PHP內部字符串操做函數的狀況下,不要用正則表達式;
4六、foreach效率更高,儘可能用foreach代替while和for循環;
4七、用單引號替代雙引號引用字符串;
PS:暈,這個不就是第一條嗎?
4八、「用i+=1代替i=i+1。符合c/c++的習慣,效率還高」;
4九、對global變量,應該用完就unset()掉;