首頁 >後端開發 >PHP問題 >php高效能介面怎麼設計

php高效能介面怎麼設計

angryTom
angryTom原創
2019-11-20 15:56:012808瀏覽

php高效能介面怎麼設計

php高效能介面怎麼設計

#php介面設計要考慮效能,這樣才能有效面對高並發的情況,下面來說說PHP介面優化提升效能的幾個技巧。

一、伺服器

從設定上做提升,對於系統整體的執行效率是相當明顯的,這一點沒有什麼好質疑的,只要有實力,自然就可以多在這方面做提升了。

二、資料查詢

這個查詢的最佳化,涉及sql的最佳化,或到資料庫的最佳化,下面有幾個簡單的最佳化方案。

1. sql的優化,適當使用鍊錶查詢,使用連接(JOIN)來代替子查詢,一般大表和多表的情況避免使用JOIN,這種情況下使用JOIN反而達不到簡化查詢的效果。

2. sql的最佳化,查詢表格資料時精確欄位名稱進行查詢,避免不必要的欄位查詢。

3. sql的最佳化,適當使用主外鍵和索引,索引欄位的查詢效率在大表查詢的效率比較相當明細。但針對對索引得使用,稍作備註。索引在很多情況下是會失效得,比如,索引列得字段內容若整體佔比過大,那這個索引也就沒什麼作用了;not in ,not exist 中也是無效得;對索引列進行運算.需要建立函數索引等

4. sql的最佳化,適當使用in查詢,盡量少用,最好用union代替,效率會明顯高。用in時,盡量使用索引欄位。 sql的最佳化,適當使用模糊查詢。最好不用,替換成全等,因為模糊中無法用索引

5. 資料庫的最佳化,字段使用合理的字段類型,另外一個提高效率的方法是在可能的情況下,應該盡量把字段設定為NOTNULL,避免空間浪費。

6. 資料庫的最佳化,合理設計表結構。例如,有時多些必要得冗餘得字段,要好連表查詢。

7. 資料庫的最佳化,合理設計索引,在聯表查詢或條件篩選中,資料表增加索引後查詢的效率會快特別多。

三、程式碼最佳化

程式碼上的最佳化也是因人而異的,每個人可能編碼習慣和風格不同,對於提高程式碼效能有各自的見解,以下是我的部分看法。

1. foreach合理使用,盡量少在循環中套用循環,在循環次數過多的情況下,非常耗性能。

2. 循環中,盡量避免資料操作,特別是查詢操作,在循環次數過多的情況下,多次呼叫效率很低,可一次取得資料再拼接。

3. 同理,在循環中,避免配置的多次獲取,和time()函數方法的調用,這種一次聲明就可以重複使用。

4. 在php中,單引號和雙引號是有區別的,作為一種習慣字符串我都用單引號,因為它無需編譯,對於效率,可能談不上差異大小,可能就一點點

5. 合理利用在php中的函數,像數組函數就非常豐富,要充分利用,一般不要自己去做他本身就支持的函數方法

6.可以用上字典的概念,將陣列以新索引形式儲存起來,我在資料的重組中很常用

7. 根據場景,合理使用快取可以減少重複的資料查詢,提高效率

8. 合理拆分功能,例如一個列表查詢,並帶有詳情查看,可以將此處拆成兩個接口實現,在需要時獲取數據,減少資源浪費。

四、業務邏輯最佳化

跟回應無關的程式(如記錄日誌等)耗時過多,使用fastcgi_finish_request()函數沖刷(flush)所有回應的資料給客戶端並結束請求, 這使得客戶端結束連線後,需要大量時間運行的任務能夠繼續運行,且不影響回應客戶端的時間。

echo '例子:';
file_put_contents('log.txt', date('Y-m-d H:i:s') . " 上传视频\n", FILE_APPEND);
fastcgi_finish_request();
sleep(1);
file_put_contents('log.txt', date('Y-m-d H:i:s') . " 转换格式\n", FILE_APPEND);
sleep(1);
file_put_contents('log.txt', date('Y-m-d H:i:s') . " 提取图片\n", FILE_APPEND);

更多PHP相關知識,請造訪PHP中文網

以上是php高效能介面怎麼設計的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn