這篇文章給大家分享的內容是關於PHP面試的一些知識經驗分享,有著一定的參考價值,有需要的朋友可以參考一下
CORS(cross origion resource sharing)跨域資源共享,可以允許跨站請求資源。客戶端需要用特定的方法去請求資源(如xmlhttprequest)同時需要帶上特定的報文頭信息,服務端也要支援跨域的資源請求
memcache可以利用多線程,吞吐量高,適合大訪問量
memcache只支援簡單的key/value結構
memcache無法將資料持久化,且沒法備份,只能用於緩存,重啟後資料遺失
由於memcache支援多線程操作,所以要考慮資料一致性的問題,使用的是cas(check and set)樂觀鎖
#redis由於是單形成,所以可以保證操作的有序性
redis支援多種資料結構,key/value,list,set,zset,dict等
redis資料可以持久化存儲,可以將資料儲存在磁碟中,再次重新啟動時可以讀取出來
redis支援資料備份,即master-slave模式的資料備份
html靜態化,將常用但是更新很少的資料靜態化
圖片伺服器分離,避免影響應用程式伺服器,同時可以針對圖片伺服器進行單獨的配置最佳化,快取設定等
#資料庫集群,庫表雜湊
資料庫集群,可以實現讀寫分離,提高資料庫回應速度,一般為一主多從,或x主y從。例如寫少讀多時,一個伺服器專門用來寫操作,別的伺服器用來讀取操作,這樣可以避免讀寫鎖的影響。不過寫入操作完成後,資料需要同步。
資料庫叢集還有個好處是,當一處資料庫伺服器宕機,別的伺服器上也有完整的資料
分散式資料庫,系統中有多個節點,每個節點完成不同的功能,某個節點掛掉,那麼對應的功能就沒辦法完成了。
資料庫叢集和分散式資料庫的差異。假如一個任務一個節點需要1小時完成,現在有10個這樣的任務,以及10個節點。分散式資料庫可把任務拆分稱10個任務,每個節點完成不同的任務,不考慮子任務的依賴,一個小時後所有任務完成。資料庫叢集中每個節點都可以完成完整的任務,它可以將10個任務平均到每個節點上,這樣也是一個小時後所有任務完成。
sql優化
表內資料過多,則可以考慮將表拆分,再用hash映射
#索引最佳化
快取
#鏡像,用於提高存取速度
#負載平衡,解決高並發和大量存取問題
CDN,讓使用者存取最近的cdn伺服器,獲得最快速的回應
資料壓縮
__set/__get 處理類別中不存在的屬性
__call/_callStatic 呼叫類別中不存在的方法/靜態方法時會觸發。 __callStatic本身也得宣告成靜態方法
return只是語言結構,不是函數,沒必要將回傳值用括號括起來,括起來反而會降低效率
如果傳回值不提供參數,此時回傳null,此時一定不能帶括號。如果帶括號會造成解析錯誤
當傳回變數的參考的時候一定不能帶括號。否則會變成傳回引用的值,而不是引用本身
以上是關於PHP的一些知識經驗分享的詳細內容。更多資訊請關注PHP中文網其他相關文章!