目錄
1.代碼最佳化,兩種常見“代碼最佳化”方法。... 3
1.1代碼品質上,盡量避免代碼冗餘。... 3
1.2去掉多餘的代碼注釋... 3
2.使用緩衝技術... 4
3. Web 內容壓縮... 5
4.資料庫最佳化... 5
4.1資料庫設計... 5
4.2 SQL語句最佳化... 5
4.3 mysql緩衝... 6
1.代碼最佳化,兩種常見“代碼最佳化”方法。
一種是從代碼品質上提高,一種是通過最佳化引擎來對網站代碼進行最佳化。
1.1代碼品質上,盡量避免代碼冗餘。
(1)不在迴圈中對資料庫進行select操作。
(2)在程式開標頭檔包含代碼中盡量使用require_once()或require() ,在流程式控制制區段的檔案包含使用include_once()或include(),包含檔案時要使用完整路徑,解析作業系統路徑所需時間就會變少。
(3)在執行for迴圈之前要事先確定最大迴圈數,不要每迴圈一次都計算最大值。
(4)隨時登出那些不使用的變數,尤其是大數組,以便釋放記憶體。
(5)使用分支語句(switch,case)好過使用多個if,elseif語句。
(6)用單引號來代替多引號包含字串執行效率更快一些,因為單引號不需要解析變數。
(7)避免使用select * from mytable這樣的句子 。
1.2去掉多餘的代碼注釋
使用Zend Optimizer引擎來在不去掉多餘注釋的前提下達到提升運行速度的目的。
裝這個引擎比較簡單,下載對應平台的版本以後,解開壓縮檔,然後在 php.ini 檔案裡面加上下面兩行,重新啟動 Web 服務器,就搞定了。
zend_optimizer.optimization_level=15
zend_extension="/path/to/ZendOptimizer.so"
zend_loader.enable=Off
如果是 Win32 平台的應該是:
zend_optimizer.optimization_level=15
zend_extension_ts="C:\\path\\to\\ZendOptimizer.dll"
zend_loader.enable=Off
其實第三行是可選的。因為看起來把 zend_loader 關掉能提高一點速度,因此值得把這第三行放到 php.ini 。需要注意的是,關掉的前提條件是你沒有在使用 Zend 加密程式。
2.使用緩衝技術
(1)記憶體緩衝 使用得最普遍的是memcached這種系統把資料庫資料放在一個很大的記憶體池裡,在Live App中減少資料庫負載,提升訪問速度。
(2)靜態緩衝 靜態緩衝是指頁面靜態化,直接產生HTML或XML等文字檔,有更新的時候重產生一次,適合於不太變化的頁面。
3. Web 內容壓縮
幾乎所有的瀏覽器都支援Gzip的壓縮方式,gzip可以降低80%的輸出,付出的代價是大概增加了10%的cpu計算量。但是賺到的是不僅佔用的頻寬減少了,而且你的頁面載入會變得很快,最佳化了你的PHP網站效能。
你可以在PHP.ini中開啟它
zlib.output_compression = On
zlib.output_compression_level = (level)(level可能是1-9之間的數字,你可以設定不同的數字使得他適合你的網站。)
如果你使用apache,你也可以啟用mod_gzip模組,他是高度可定製的。
4.資料庫最佳化4.1資料庫設計
(1)選擇合適的欄位類型和字元長度
(2)適當建立索引
(3)檔案、圖片等大檔案用檔案系統儲存,不用資料庫
(4)寧可集中大量操作,避免頻繁讀寫
4.2 SQL語句最佳化
(1)讀寫分離 如果資料庫壓力很大,一台機器支撐不了,那麼可以用mysql複製實現多台機器同步,將資料庫的壓力分散。
(2)比如盡量不再運算子的左側使用函數;使用事務來完成需要一系列sql語句才能完成的操作;保持sql語句中進行運算的兩個欄位類型一直;等等……
4.3 mysql緩衝
開啟QueryCache緩衝,當查詢接收到一個和之前同樣的查詢, 伺服器將會從查詢快取種檢索結果,而不是再次分析和執行上次的查詢