⑴ Linux下如何釋放內存,swap分區滿了怎麼辦
終止占內存多的進程
可以增加swap區
⑵ 如何為linux釋放內存和緩存
在Linux系統下,我們一般不需要去釋放內存,因為系統已經將內存管理的很好。但是凡事也有例外,有的時候內存會被緩存佔用掉,導致系統使用SWAP空間影響性能,此時就需要執行釋放內存(清理緩存)的操作了。
Linux系統的緩存機制是相當先進的,他會針對dentry(用於VFS,加速文件路徑名到inode的轉換)、Buffer Cache(針對磁碟塊的讀寫)和Page Cache(針對文件inode的讀寫)進行緩存操作。但是在進行了大量文件操作之後,緩存會把內存資源基本用光。但實際上我們文件操作已經完成,這部分緩存已經用不到了。這個時候,我們難道只能眼睜睜的看著緩存把內存空間占據掉么?
所以,我們還是有必要來手動進行Linux下釋放內存的操作,其實也就是釋放緩存的操作了。
要達到釋放緩存的目的,我們首先需要了解下關鍵的配置文件/proc/sys/vm/drop_caches。這個文件中記錄了緩存釋放的參數,默認值為0,也就是不釋放緩存。他的值可以為0~3之間的任意數字,代表著不同的含義:
0 – 不釋放
1 – 釋放頁緩存
2 – 釋放dentries和inodes
3 – 釋放所有緩存
知道了參數後,我們就可以根據我們的需要,使用下面的指令來進行操作。
首先我們需要使用sync指令,將所有未寫的系統緩沖區寫到磁碟中,包含已修改的 i-node、已延遲的塊 I/O 和讀寫映射文件。否則在釋放緩存的過程中,可能會丟失未保存的文件。
#sync
接下來,我們需要將需要的參數寫進/proc/sys/vm/drop_caches文件中,比如我們需要釋放所有緩存,就輸入下面的命令:
#echo 3 > /proc/sys/vm/drop_caches
此指令輸入後會立即生效,可以查詢現在的可用內存明顯的變多了。
要查詢當前緩存釋放的參數,可以輸入下面的指令:
#cat /proc/sys/vm/drop_caches
#free -m
對於清除swap,只有先關閉swap了,用:
#swapoff -a
而後啟用swap,因為只是清除,不是說不要用swap的嘛 :
#swapon -a
http://blog.sina.com.cn/s/blog_539d6e0c0100ys3o.html
Linux 自動釋放內存腳本
發表於119 天前 ? 技術文章 ? 暫無評論
腳本下載地址:Cached
腳本內容:
#! /bin/bash
# cache釋放:
# To free pagecache:
sync
sync
#echo 1 > /proc/sys/vm/drop_caches
# To free dentries and inodes:
#echo 2 > /proc/sys/vm/drop_caches
# To free pagecache, dentries and inodes:
echo 3 > /proc/sys/vm/drop_caches
# 說明,釋放前最好sync一下,防止丟數據。
利用系統crontab實現每天自動運行:
crontab -e
輸入以下內容:
00 00 * * * /root/Cached.sh
每天0點釋放一次內存,這個時間可以根據自己需要自行設置,我的伺服器情況是每天自動釋放一次就OK了
在設置這個腳本的時候,發生了一系列的問題
在測試運行./Cached.sh時提示錯誤:Permission denied 許可權的問題
解決方法:
chmod +x .Cached.sh
或
chmod 777 Cached.sh
接著又出現錯誤提示:/bin/bash^M: bad interpreter: No such file or directory
這是因為在windows下編輯的.sh文件編碼格式和linux下不一樣,轉換一下編碼格式即可:
dos2unix Cached.sh
http://blog.sinorain.com/archives/157
⑶ Linux下swap耗盡該怎麼辦如何釋放swap
Linux下交換內存耗盡如何查看及如何處理。以及查看shell腳本描述。交換內存不足時,啟動應用時會報內存不足。
1、啟動應用時報內存不足,直接Linux命令行top查看下。swap used100%,0free。
2、reboot伺服器能有效的釋放swap,可是很多情況下是不能重啟伺服器的。這時就要弄明白是什麼占著內存。查看下/proc目錄下內容,發現很多數字命名的目錄,這些就是Linux的進程了。
3、要讓進程釋放swap的方法只有kill掉該進程了。寫個腳本來查看具體是哪些進程占著內存啦。
一、對/proc目錄下所有以數字為名的目錄進行遍歷
二、1目錄是根進程重啟會導致系統重啟,所以直接排除掉。
三、算出每個進程佔用內存的大小,然後按照大小排序
四、輸出內存佔用大於1MB的進程
4、將運行結果保存到swap.log文件中
5、查看swap.log.10325這個進程內存佔用最多有130幾M。
6、直接kill掉,然後再top查看。ok,swap一下子釋放了很多,搞定。
注意事項:proc目錄下1目錄不能直接kill掉。
⑷ 刪除swap分區,對linux運行效率影響有多大
看應用
您的提問(回答)過於簡略,請再豐富一下內容重新提交
⑸ 該怎麼樣才能清除並刷新Linux的SWAP分區緩存~~
swapoff -a && swapon -a
⑹ 如何清理Linux中的swap,buffer及cache
使用 Furius ISO Mount 軟體,該方法的優點是無需記住以上命令,也無需輸入用戶密碼提權,推薦大家使用。首先安裝 Furius ISO Mount,Ubuntu 用戶可在 Ubuntu 軟體中心搜索安裝,或者在終端中輸入sudo apt-get
install furiusisomount。
其他 Linux 發行版請使用相應軟體包管理器安裝或自行編譯安裝。
註:由於許可權問題,部分發行版(Ubuntu 用戶無需進行此操作)可能需要將用戶添加到 fuse 組,執行sudo adser username
fuse即可。
⑺ linux swap文件被刪除,如何恢復
#創建256M大小的文件,文件塊大小為1M,傳送大小為256塊
dd if=/dev/zero of=/tmp/swapfile bs=1024k count=256
#格式化文件
mkswap /tmp/swapfile
#載入交換文件
swapon /tmp/swap
⑻ 如何清除linux的內存緩存,緩沖和交換空間
linux和其他操作系統一樣,已經實現了很有效的內存管理機制,但是任何一個進程損壞了系統的內存,那麼你就必須清理它,linux提供了一個比較好的方式刷新\清除RAM緩存。
注意:並不是什麼時候都需要清除RAM緩存的,大家都知道,linux查找數據都是優先從RAM緩存中查找的,一旦清空緩存,所有的數據都需要從磁碟讀取,所以只在需要的時候清空緩存,才是正確的選擇。
如何清除linux緩存?
1.只清除PageCache:
# sync; echo 1 > /proc/sys/vm/drop_caches
2.清除dentries and inodes
# sync; echo 2 > /proc/sys/vm/drop_caches
3.同時清除PageCache和dentries and inodes
# sync; echo 3 > /proc/sys/vm/drop_caches
對上面的命令的解釋:
sync將會刷新系統的buffer 緩存。
根據官方內核文檔描述,對drop_caches寫入值將會在不殺死任何應用服務的情況下清空緩存。
在生產環境中建議使用echo 1,因為它會優先清空磁碟緩存。
效果展示:
使用shell腳本自動在晚上2點清除RAM緩存:
vim clearcache.sh
#!/bin/bash
echo "echo 1 > /proc/sys/vm/drop_caches"
# chmod 755 clearcache.sh
# crontab -e
0 3 * * * /path/to/clearcache.sh
如何清除交換空間?
簡單的清除可以使用如下的命令
1
# swapoff -a && swapon -a
結合上面的腳本:
vim clearcache.sh
#!/bin/bash
echo "echo 1 > /proc/sys/vm/drop_caches" && swapoff -a && swapon -a &&
printf '\n%s\n' 'Ram-cache and Swap Cleared'
希望我的回答能幫到您,滿意請採納,謝謝!
⑼ 如何控制Linux清理cache機制
Linux下的緩存機制及清理buffer/cache/swap的方法梳理
(1)緩存機制
為了提高文件系統性能,內核利用一部分物理內存分配出緩沖區,用於緩存系統操作和數據文件,當內核收到讀寫的請求時,內核先去緩存區找是否有請求的數據,有就直接返回,如果沒有則通過驅動程序直接操作磁碟。
緩存機制優點:減少系統調用次數,降低CPU上下文切換和磁碟訪問頻率。
CPU上下文切換:CPU給每個進程一定的服務時間,當時間片用完後,內核從正在運行的進程中收回處理器,同時把進程當前運行狀態保存下來,然後載入下一個任務,這個過程叫做上下文切換。實質上就是被終止運行進程與待運行進程的進程切換。
(2)查看緩存區及內存使用情況
[root@localhost ~]# free -m
total used free shared buffers cached
Mem: 7866 7725 141 19 74 6897
-/+ buffers/cache: 752 7113
Swap: 16382 32 16350
可以看到內存總共8G,已使用7725M,剩餘141M,不少的人都是這么看的,這樣並不能作為實際的使用率。因為有了緩存機制,具體該怎麼算呢?
空閑內存=free(141)+buffers(74)+cached(6897)
已用內存=total(7866)-空閑內存
由此算出空閑內存是7112M,已用內存754M,這才是真正的使用率,也可參考-/+ buffers/cache這行信息也是內存正確使用率。
(3)可見緩存區分為buffers和cached,他們有什麼區別呢?
內核在保證系統能正常使用物理內存和數據量讀寫情況下來分配緩沖區大小。buffers用來緩存metadata及pages,可以理解為系統緩存,例如,vi打開一個文件。cached是用來給文件做緩存,可以理解為數據塊緩存,例如,dd if=/dev/zero of=/tmp/test count=1 bs=1G 測試寫入一個文件,就會被緩存到緩沖區中,當下一次再執行這個測試命令時,寫入速度會明顯很快。
(4)隨便說下Swap做什麼用的呢?
Swap意思是交換分區,通常我們說的虛擬內存,是從硬碟中劃分出的一個分區。當物理內存不夠用的時候,內核就會釋放緩存區(buffers/cache)里一些長時間不用的程序,然後將這些程序臨時放到Swap中,也就是說如果物理內存和緩存區內存不夠用的時候,才會用到Swap。
swap清理:
swapoff -a && swapon -a
注意:這樣清理有個前提條件,空閑的內存必須比已經使用的swap空間大
(5)怎樣釋放緩存區內存呢?
a)直接改變內核運行參數
#釋放pagecache
echo 1 >/proc/sys/vm/drop_caches
#釋放dentries和inodes
echo 2 >/proc/sys/vm/drop_caches
#釋放pagecache、dentries和inodes
echo 3 >/proc/sys/vm/drop_caches
b)也可以使用sysctl重置內核運行參數
sysctl -w vm.drop_caches=3
注意:這兩個方式都是臨時生效,永久生效需添加sysctl.conf文件中,一般寫成腳本手動清理,建議不要清理。
修改/etc/sysctl.conf 添加如下選項後就不會內存持續增加
vm.dirty_ratio = 1
vm.dirty_background_ratio=1
vm.dirty_writeback_centisecs=2
vm.dirty_expire_centisecs=3
vm.drop_caches=3
vm.swappiness =100
vm.vfs_cache_pressure=163
vm.overcommit_memory=2
vm.lowmem_reserve_ratio=32 32 8
kern.maxvnodes=3
上面的設置比較粗暴,使cache的作用基本無法發揮。需要根據機器的狀況進行適當的調節尋找最佳的折衷。
⑽ linux 清理交換區SWAP,對正在伺服器上運行的其它應用有什麼影響
SWAP其實就是突發內存,也被稱作虛擬內存
如圖是真實的內存條,SWAP是從硬碟劃分過來,當作突發內存用的。當應用程序技術量過大的時候,會把一些運算放到SWAP里進行
所以如果SWAP內存有正在運行的程序,清理SWAP就會造成錯誤,所以在運行程序的時候不要清理SWAP分區