Linux服務器運行一段時間后,由於其內存管理機制,會將暫時不用的內存轉為buff/cache,這樣在程序使用到這一部分數據時,能夠很快的取出,從而提高系統的運行效率,所以這也正是linux內存管理中非常出色的一點,所以乍一看內存剩余的非常少,但是在程序真正需要內存空間時,linux會將緩存讓出給程序使用,這樣達到對內存的最充分利用,所以真正剩余的內存是free+buff/cache
但是有些時候大量的緩存占據空間,這時候應用程序回去使用swap交換空間,從而使系統變慢,這時候需要手動去釋放內存,釋放內存的時候,首先執行命令 sync 將所有正在內存中的緩沖區寫到磁盤中,其中包括已經修改的文件inode、已延遲的塊I/O以及讀寫映射文件,從而確保文件系統的完整性
說到清理內存,那么不得不提到/proc這一個虛擬文件系統,這里面的數據和文件都是內存中的實時數據,很多參數的獲取都可以從下面相應的文件中得到,比如查看某一進程占用的內存大小和各項參數,cpu和主板的詳細信息,顯卡的參數等等;相應的關於內存的管理方式是在/proc/sys/vm/drop_chches文件中,一定要注意這個文件中存放的並不是具體的內存內容,而是0-3這幾個數字,通過文件大小只有1B也可以知道,而這些代號分別告訴系統代表不同的含義如下:
0:0是系統默認值,默認情況下表示不釋放內存,由操作系統自動管理
1:釋放頁緩存
2:釋放dentries和inodes
3:釋放所有緩存
所以根據上面的說明,分別將1,2,3這3個數字重定向到drop_caches中可以實現內存的釋放,一般釋放內存都是重定向3到文件中,釋放所有的緩存
那么下面舉個例子,比如這里只釋放頁緩存,首先使用 free -h 查看當前內存剩余
當前內存剩余570M左右,另外buff/cache是1.3G,根據上面說的現在真正的剩余內存應該是1.8G左右,首先寫緩存到文件系統:
sync
然后執行下面命令釋放內存(頁緩存buff/cache):
echo 1 > /proc/sys/vm/drop_caches
執行完之后,再次查看內存剩余:
會發現內存被釋放了,可用內存確實變為1.8G左右
到這里內存就釋放完了,現在drop_caches中的值為1,如果現在想讓操作系統重新分配內存,那么設置drop_caches的值為0即可:
echo 0 > /proc/sys/vm/drop_caches
另外需要注意的是,在生產環境中的服務器我們不要頻繁的去釋放內存,只在必要時候清理內存即可,更重要的是我們應該從應用程序層面去優化內存的利用和釋放,經常清理內存可能只是暫時屏蔽的應用程序中的一些bug,所以更重要的是程序的調優,其他的交給操作系統來管理