top 內存mem的used很高,或者100%

top 內存mem的used很高,或者100%

 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 查看當前內存剩餘

      free -m

 

 

當前內存剩餘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,所以更重要的是程序的調優,其他的交給操作系統來管理

 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 查看當前內存剩餘

轉載於:https://blog.csdn.net/weixin_30644369/article/details/99926359

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章