A. linux資料庫伺服器物理內存和虛擬內存滿了怎麼排查和解決
一、查看物理內存
執行如下命令即可查看物理內存,執行效果如下圖所示:
dmidecode -t memory | grep Size
二、配置空間
物理內存是沒辦法配置的,只能配置虛擬內存,在Linux系統即Swap分區。具體操作swap分區的方法如下:
B. Linux內存機制(swap)
我們知道,直接從物理內存讀寫數據要比從硬碟讀寫數據要快的多,因此,我們希望所有數據的讀取和寫入都在內存完成,而內存是有限的,這樣就引出了物理內存與虛擬內存的概念。
物理內存就是系統硬體提供的內存大小,是真正的內存,相對於物理內存,在linux下還有一個虛擬內存的概念,虛擬內存就是為了滿足物理內存的不足而提出的策略,它是利用磁碟空間虛擬出的一塊邏輯內存,用作虛擬內存的磁碟空間被稱為交換空間(Swap Space)。
作為物理內存的擴展,linux會在物理內存不足時,使用交換分區的虛擬內存,更詳細的說,就是內核會將暫時不用的內存塊信息寫到交換空間,這樣以來,物理內存得到了釋放,這塊內存就可以用於其它目的,當需要用到原始的內容時,這些信息會被重新從交換空間讀入物理內存。
Linux的內存管理採取的是分頁存取機制,為了保證物理內存能得到充分的利用,內核會在適當的時候將物理內存中不經常使用的數據塊自動交換到虛擬內存中,而將經常使用的信息保留到物理內存。
要深入了解linux內存運行機制,需要知道下面提到的幾個方面:
Linux系統會不時的進行頁面交換操作,以保持盡可能多的空閑物理內存,即使並沒有什麼事情需要內存,Linux也會交換出暫時不用的內存頁面。這可以避免等待交換所需的時間。
Linux 進行頁面交換是有條件的,不是所有頁面在不用時都交換到虛擬內存,linux內核根據」最近最經常使用「演算法,僅僅將一些不經常使用的頁面文件交換到虛擬 內存,有時我們會看到這么一個現象:linux物理內存還有很多,但是交換空間也使用了很多。其實,這並不奇怪,例如,一個佔用很大內存的進程運行時,需 要耗費很多內存資源,此時就會有一些不常用頁面文件被交換到虛擬內存中,但後來這個佔用很多內存資源的進程結束並釋放了很多內存時,剛才被交換出去的頁面 文件並不會自動的交換進物理內存,除非有這個必要,那麼此刻系統物理內存就會空閑很多,同時交換空間也在被使用,就出現了剛才所說的現象了。關於這點,不 用擔心什麼,只要知道是怎麼一回事就可以了。
交換空間的頁面在使用時會首先被交換到物理內存,如果此時沒有足夠的物理內存來容納這些頁 面,它們又會被馬上交換出去,如此以來,虛擬內存中可能沒有足夠空間來存儲這些交換頁面,最終會導致linux出現假死機、服務異常等問題,linux雖 然可以在一段時間內自行恢復,但是恢復後的系統已經基本不可用了。
因此,合理規劃和設計Linux內存的使用,是非常重要的.
在Linux 操作系統中,當應用程序需要讀取文件中的數據時,操作系統先分配一些內存,將數據從磁碟讀入到這些內存中,然後再將數據分發給應用程序;當需要往文件中寫 數據時,操作系統先分配內存接收用戶數據,然後再將數據從內存寫到磁碟上。然而,如果有大量數據需要從磁碟讀取到內存或者由內存寫入磁碟時,系統的讀寫性 能就變得非常低下,因為無論是從磁碟讀數據,還是寫數據到磁碟,都是一個很消耗時間和資源的過程,在這種情況下,Linux引入了buffers和 cached機制。
buffers與cached都是內存操作,用來保存系統曾經打開過的文件以及文件屬性信息,這樣當操作系統需要讀取某些文件時,會首先在buffers 與cached內存區查找,如果找到,直接讀出傳送給應用程序,如果沒有找到需要數據,才從磁碟讀取,這就是操作系統的緩存機制,通過緩存,大大提高了操 作系統的性能。但buffers與cached緩沖的內容卻是不同的。
buffers是用來緩沖塊設備做的,它只記錄文件系統的元數據(metadata)以及 tracking in-flight pages,而cached是用來給文件做緩沖。更通俗一點說:buffers主要用來存放目錄裡面有什麼內容,文件的屬性以及許可權等等。而cached直接用來記憶我們打開過的文件和程序。
為了驗證我們的結論是否正確,可以通過vi打開一個非常大的文件,看看cached的變化,然後再次vi這個文件,感覺一下兩次打開的速度有何異同,是不是第二次打開的速度明顯快於第一次呢?接著執行下面的命令:
find / -name .conf 看看buffers的值是否變化,然後重復執行find命令,看看兩次顯示速度有何不同。
上面這個60代表物理內存在使用40%的時候才會使用swap(參考網路資料:當剩餘物理內存低於40%(40=100-60)時,開始使用交換空間) swappiness=0的時候表示最大限度使用物理內存,然後才是 swap空間,swappiness=100的時候表示積極的使用swap分區,並且把內存上的數據及時的搬運到swap空間裡面。
值越大表示越傾向於使用swap。可以設為0,這樣做並不會禁止對swap的使用,只是最大限度地降低了使用swap的可能性。
通常情況下:swap分區設置建議是內存的兩倍 (內存小於等於4G時),如果內存大於4G,swap只要比內存大就行。另外盡量的將swappiness調低,這樣系統的性能會更好。
B. 修改swappiness參數
永久性修改:
立即生效,重啟也可以生效。
一般系統是不會自動釋放內存的 關鍵的配置文件/proc/sys/vm/drop_caches。這個文件中記錄了緩存釋放的參數,默認值為0,也就是不釋放緩存。他的值可以為0~3之間的任意數字,代表著不同的含義:
0 – 不釋放 1 – 釋放頁緩存 2 – 釋放dentries和inodes 3 – 釋放所有緩存
前提:首先要保證內存剩餘要大於等於swap使用量,否則會宕機!根據內存機制,swap分區一旦釋放,所有存放在swap分區的文件都會轉存到物理內存上。通常通過重新掛載swap分區完成釋放swap。
a.查看當前swap分區掛載在哪?b.關停這個分區 c.查看狀態:d.查看swap分區是否關停,最下面一行顯示全 e.將swap掛載到/dev/sda5上 f.查看掛載是否成功
C. Linux上的虛擬內存swap簡介
在Linux操作系統中,swap分區的作用相當於Windows系統下的虛擬內存。當物理內存不足時,將部分硬碟空間當內存使用,由於不是真正的內存,因此將其稱之為虛擬內存,它的目的就是為了解決內存不足的情況。
Linux操作系統中的swap可以分為兩種:一種是將某個物理磁碟分區作為swap,另一種是通過文件來實現swap。
既然配置swap對桌面系統有幫助,那麼配置多少大小的swap比較合適呢?下面是ubuntu給出的建議:
或者直接將swap設置為物理內存的2倍!
輸入命令 swapon -s 可以查看系統的swap信息,從下面的輸出可以看出,設置了一個大小為1G的虛擬內存。
重啟系統,再次執行 swapon -s 查看虛擬內存。
本文的測試環境為阿貝雲免費雲伺服器(https://www.abeiyun.com/),阿貝雲目前正在進行"免費虛擬主機"和「免費雲伺服器」體驗活動,感興趣的朋友可以試試。
D. linux中查看虛擬內存和cpu佔用率的命令是什麼
linux虛擬內存統計:vmstat
命令
vmstat
-
報告虛擬內存的統計信息。vmstat
對系統的進程情況、內存使用情況、交換頁和
I/O
塊使用情況、中斷以及
CPU
使用情況進行統計並報告相應的信息。Memory
swpd:
虛擬內存使用情況,單位:KBfree:
空閑的內存,單位KBbuff:
被用來做為緩存的內存數,單位:KB.si:
從磁碟交換到內存的交換頁數量,單位:KB/秒so:
從內存交換到磁碟的交換頁薯慶數量,單位:KB/秒。運行
vmstat
不須要特別的使用許可權
這些系統信息是用來向用戶提供分析系統瓶頸問題信息的。linux在計算進程情況時不將正在運行的
vmstat
自己計算進去。
vmstat對系統的虛擬內存、進程、CPU活動進行監視,同時它也對磁碟和forks和vforks操作的個數進行匯總。
不足是:vmstat不能對某個進程進行深入分析,它僅是一對系統的整體情況進行分析。
例如:[angel@home
/angel]#
vmstat
procs
memory
swap
io
system
cpu
r
b
w
swpd
free
buff
cache
si
so
bi
bo
in
cs
us
sy
id
0
0
0
7180
1852
56092
48400
0
0
6
5
24
8
0
0
18
其中:
Procs
r:
等待運行的進程數
b:
處在非中斷睡眠狀態的進程數
w:
被交換出去的可運行的進程數。
Memory
swpd:
虛擬內存使用情況,單位:KB
free:
空閑的內存,單位KB
buff:
被用來做為緩存的內唯咐存數,單位:KB
Swap
si:
從磁碟交換到內存的交換頁數量,單位:KB/秒
so:
從內存交換到磁碟的交換頁數量,單位:KB/秒
IO
bi:
發送到塊設備的塊數,單位:塊/秒
bo:
從塊設備接收到的塊數,單位:塊/秒
System
in:
每秒的中斷數,包括時鍾中斷
cs:
每秒的環境(上下文)切換次數
CPU
按
CPU
的總使用百分比來顯數山握示
us:
CPU
使用時間
sy:
CPU
系統使用時間
id:
閑置時間
E. 2021-01-11:linux中,如何看內存的使用情況呢
1./proc/meminfo
查看 RAM 使用情況最簡單的方法是通過 /proc/meminfo。這個動態更新的虛擬文件實際上是許多其他內存相關工具 (如:free / ps / top) 等的組合顯示。/proc/meminfo 列出了所有你想了解的內存的使用情況。進程的內存使用信息也可以通過 /proc//statm 和 /proc//status 來查看。
$cat/proc/meminfo
圖0:Linux下查看內存使用情況方法總結
2.atop
atop 命令是一個終端環境的監控命令。它顯示的是各種系統資源(CPU, memory, network, I/O, kernel)的綜合,並且在高負載的情況下進行了彩色標注。
$sudoatop
3.free
free 命令是一個快速查看內存使用情況的方法,它是對 /proc/meminfo 收集到的信息的一個概述。
$free-h
4.GNOME System Monitor
GNOME System Monitor 是一個顯示最近一段時間內的 CPU、內存、交換區及網路的使用情況的視圖工具。它還提供了一種查看 CPU 及內存使用情況的方法。
$gnome-system-monitor
5.htop
htop 命令顯示了每個進程的內存實時使用率。它提供了所有進程的常駐內存大小、程序總內存大小、共享庫大小等的報告。列表可以水平及垂直滾動。
$htop
6.KDE System Monitor
功能同 4 中介紹的 GENOME 版本。
$ksysguard
7.memstat
memstat 是一個有效識別 executable(s), process(es) and shared libraries 使用虛擬內存情況的命令。給定一個進程 ID,memstat 可以列出這個進程相關的可執行文件、數據和共享庫。
$memstat-p
8.nmon
nmon 是一個基於 ncurses 的系統基準測試工具,它可以監控 CPU、內存、I/O、文件系統及網路資源等的互動模式。對於內存的使用,它可以實時的顯示總 / 剩餘內存、交換空間等信息。
$nmon
9.ps
ps 命令可以實時的顯示各個進程的內存使用情況。Reported memory usage information includes %MEM (percent of physical memory used), VSZ (totalamount of virtual memory used), and RSS (total amount of physical memory used)。你可以使用 「–sort」 選項對進程進行排序,例如按 RSS 進行排序:
$psaux–sort-rss
圖8:Linux下查看內存使用情況方法總結
10.smem
smem 命令允許你統計基於 / proc 信息的不同進程和用戶的內存使用情況。內存使用情況的分析可以導出圖表(如條形圖和餅圖)。
11.top
top 命令提供了實時的運行中的程序的資源使用統計。你可以根據內存的使用和大小來進行排序。
12.vmstat
vmstat 命令顯示實時的和平均的統計,覆蓋 CPU、內存、I/O 等內容。例如內存情況,不僅顯示物理內存,也統計虛擬內存。
F. linux里查看虛擬內存的命令是什麼
free -m最後一排的swap就是虛擬內存
G. linux 下怎麼查看一個進程佔用內存大小
這里介紹下查看一個進程佔用內存大小的方法。
1、首先單擊桌面左上角的應用程序,選擇系統工具選項,如下圖所示。