關於PHP最佳化速度的問題,檔案快取,影響會大嗎?
由於條件有限,沒有MemCache,但是很多地方如“地區資訊、各種樹型分類、全域菜單連結”等等資訊,直接從資料庫取的話,實在實在太慢了,而且一個頁面下來語句太多了,所以採用了一個辦法,就是把這類資料直接儲存到硬碟下,要的時候就直接從硬碟讀取。
項目做得差不多了,發現用到這類方法的地方好像挺多,現在就是膽心到時候正式上線的時候,過多的讀取會不會直接就掛了?
有沒有這方面有經驗的,給下回複。當前的話,我測試的速度還是蠻快的,但是畢竟沒有經過壓力。 緩衝 最佳化 php 資料
分享到:
------解決方案--------------------
自己搞個工具做下壓力測試, 看下IO撐得住不。搞個緩衝很快啊,隨便上一個就可以了,又不會難
------解決方案--------------------
最好的就是讀記憶體 就是緩衝放在記憶體中 具體就是ls說的 而檔案放在硬碟上 - - 感覺和讀資料庫 五十步 一百步的區別 硬碟是個瓶頸啊
------解決方案--------------------
由於條件有限,沒有MemCache,但是很多地方如“地區資訊、各種樹型分類、全域菜單連結”等等資訊,直接從資料庫取的話,實在實在太慢了
最好還是最佳化你的查詢和程式。
------解決方案--------------------
我簡單描述一下我的做法:
我的網站有一個龐大的分類表,這個分類表分為多個層次,每一個層次都儲存了該分類下有多少條新聞.
為了防止每次都要重新讀取分類表,所以我就建立了一個function,這個function只有在添加新聞的時候才會被調用,他的作用就是用來讀取每一個分類,並計算每一個分類下都有多少個新聞,計算完畢之後就把分類重新組合成array,然後用這個function把我的array存入一個php檔案內,這樣前台在顯示的時候只需要require這個php檔案進來然後遍曆array輸出即可,就不需要重新讀資料庫了.
也就是提前把資料庫中的分類讀出來整合成array存入一個php檔案裡,顯示的時候就require此php檔案就行了,不需要每次讀取資料庫.
------解決方案--------------------
項目做得差不多了,在這種情況下,你如果不想對代碼大動幹戈,最好的方法加中間緩衝層,如果沒有涉及到server叢集,你可以開啟server端eAccelerator、apc、xcache緩衝opcode開啟,如果是server叢集,就需要在反向 Proxy上做文章了
------解決方案--------------------
可以再第一次取出的時候寫成檔案儲存體,之後再讀取的時候直接讀取檔案就行了,如果資料有修改就重新寫入,很多架構都是這麼做的