兩台機器主要用來跑nginx和php,記憶體分別為8G和4G,一段時間以後free命令的輸出結果中的cached數值都會越來越大,
自己搜了幾圈以後得知,cached主要負責快取檔案使用, 記錄檔過大造成cached區記憶體增大把記憶體佔用完 .
Free中的buffer和cache:(它們都是佔用記憶體):
buffer : 作為buffer cache的記憶體,是塊裝置的讀寫緩衝區
cache: 作為page cache的記憶體, 檔案系統的cache
如果 cache 的值很大,說明cache住的檔案數很多。
但是仍有兩個疑問:
1.用來跑php的這個兩個機器的記憶體使用量情況(cached佔用)跟php執行請求的數量有些什麼關係?比如這兩個站,是不是訪問數量越大,cached的值就一定越大?
2.執行sync命令,將cached寫入磁碟後,對之後的訪問有沒有什麼影響?
本人菜鳥,請大神指點。。。
回複內容:
兩台機器主要用來跑nginx和php,記憶體分別為8G和4G,一段時間以後free命令的輸出結果中的cached數值都會越來越大,
自己搜了幾圈以後得知,cached主要負責快取檔案使用, 記錄檔過大造成cached區記憶體增大把記憶體佔用完 .
Free中的buffer和cache:(它們都是佔用記憶體):
buffer : 作為buffer cache的記憶體,是塊裝置的讀寫緩衝區
cache: 作為page cache的記憶體, 檔案系統的cache
如果 cache 的值很大,說明cache住的檔案數很多。
但是仍有兩個疑問:
1.用來跑php的這個兩個機器的記憶體使用量情況(cached佔用)跟php執行請求的數量有些什麼關係?比如這兩個站,是不是訪問數量越大,cached的值就一定越大?
2.執行sync命令,將cached寫入磁碟後,對之後的訪問有沒有什麼影響?
本人菜鳥,請大神指點。。。
哪裡有過大?cached 和 buffers 佔據 available 部分中的絕大部分是正常的。你說你的記憶體,free 著就是什麼用處都沒有,但你以為那些部分就不需要通電、重新整理嗎?
cached 通常屬於 available 部分(該資料 3.14 核心之後提供,procps-ng 較新版本也顯示),也就是可用記憶體。什麼時候程式需要了,什麼時候拿去用。暫時不需要?那我從磁碟那個慢到死的傢伙裡好不容易讀出來的資料先留著,指不定使用者還要用到呢。
有興趣可以 echo 3 到那什麼檔案/proc/sys/vm/drop_caches清空一下這些部分,然後 ls /usr/lib 試試。然後立即再執行一次,是不是有緩衝之後就快多了?
至於 sync 命令。它和 cached 有關,但是不是你所想的那個功能。它的功能是,把髒頁寫回磁碟,也就是把修改過的資料還沒寫到磁碟的資料寫到磁碟上。因為核心會延遲提交,每次提交多積累一些資料,以提高效率、降低延遲。沒有使用的必要,只會讓系統卡一下而已。****加粗文字加粗文字
cached佔用多也沒有關係啊,必要時系統會自動回收檔案快取,然後再分配的。緩衝需要寫入磁碟的話,檔案系統自己會完成的,一般沒必要sync吧
可以看一下PHP設定檔中memory_limit=xxx。也許能幫到樓主!