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中文網其他相關文章!