【轉lis的文章】Linux 下判斷Server 記憶體是否不足
下判斷 記憶體是否不足: 起因: 一個客戶近段時間一直讓我檢查他們 Server 記憶體是否需要吃緊。因為他一直使用linux 的Top 命令來看系統執行狀況的。 下面我來寫一下在linux OS 下如何判斷系統是否記憶體吃緊。 我從兩個部分來檢視如何檢查。 第一部分:檢視記憶體使用狀況 Linux 下使用Top [root@itc-test9 ~]# top
top - 17:08:01 up 12 days, 3:48, 2 users, load average: 0.01, 0.01, 0.00
Tasks: 95 total, 1 running, 94 sleeping, 0 stopped, 0 zombie
Cpu(s): 0.0% us, 0.0% sy, 0.0% ni, 99.5% id, 0.5% wa, 0.0% hi, 0.0% si
Mem: 2056000k total, 1963652k used, 92348k free, 59156k buffers
Swap: 4096564k total, 164k used, 4096400k free, 1605276k cached PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
1 root 16 0 4744 552 460 S 0.0 0.0 0:00.46 init 從Top 顯示來看是有1963652K已經使用,只有92348k記憶體空閒。一直問我是否記憶體不足了。下面就來解釋一下Oracle 在Linux 下如何檢視OS 記憶體是否不足。 但我們從Linux command free 來看:
[oracle@itc-test9 ~]free
total used free shared buffers cached
Mem: 2056000 1869596 186404 0 59172 1512236
-/+ buffers/cache: 298188 1757812
Swap: 4096564 164 4096400
-/+ buffers/cache: used=298188k =291.2M free=1757812k=1716.6M 約等於2G。 從Free 命令列來看OS 還有1.76G 空間未使用。 需要解釋一下Free 和Top 在Linux 下的不同顯示問題。 Free命令顯示在作業系統中使用和空閒的記憶體數量。Top 顯示是和Linux 對記憶體使用的方式關係緊密,linux 儘可能的要求使 用實體記憶體來提高Buffer 和Cache 對Disk 的I/O操作。Linux 將盡可能多的將I/O 操作磁碟上的資訊儲存在記憶體當中,如果Oracle(其他程式也一樣)需要更多的記憶體空間,Linux 才會將一些記憶體使用LRU 演算法清理出來,如果不需要則繼續保持這些資料資訊在記憶體中。所以我們使用Top看到的Memory FreeMem: 2056000k total, 1963652k used, 92348k free很少。 第二部分:檢視Swap 的狀況: Swap 空間的使用狀況也能分辨出Oracle 伺服器記憶體是否已經吃緊。 先看Swap 大小設定:
RAM Size Swap Size
1-2G 1.5 倍 RAM
2-8G 1 倍 RAM
>8G 0.75 RAM 基本上每個操做系統(除Windows)都建議Swap 使用上面比例的配置。但根據個人經驗如果Server 的Memory >32G 時,一般都會將Swap 空間設定在 以內,甚至更小。 使用Command more /proc/meminfo 或top 來Monitor Swap 的使用狀況。 [root@itc-test9 ~]# more /proc/meminfo
MemTotal: 2056000 kB
MemFree: 177268 kB
Buffers: 59292 kB
Cached: 1519188 kB
SwapCached: 4 kB
Active: 1092248 kB
Inactive: 654096 kB
HighTotal: 0 kB
HighFree: 0 kB
LowTotal: 2056000 kB
LowFree: 177268 kB
SwapTotal: 4096564 kB
SwapFree: 4096400 kB
[root@itc-test9 ~]# top
top - 17:08:01 up 12 days, 3:48, 2 users, load average: 0.01, 0.01, 0.00
Tasks: 95 total, 1 running, 94 sleeping, 0 stopped, 0 zombie
Cpu(s): 0.0% us, 0.0% sy, 0.0% ni, 99.5% id, 0.5% wa, 0.0% hi, 0.0% si
Mem: 2056000k total, 1963652k used, 92348k free, 59156k buffers
Swap: 4096564k total, 164k used, 4096400k free, 1605276k cached
top - 17:08:01 up 12 days, 3:48, 2 users, load average: 0.01, 0.01, 0.00
Tasks: 95 total, 1 running, 94 sleeping, 0 stopped, 0 zombie
Cpu(s): 0.0% us, 0.0% sy, 0.0% ni, 99.5% id, 0.5% wa, 0.0% hi, 0.0% si
Mem: 2056000k total, 1963652k used, 92348k free, 59156k buffers
Swap: 4096564k total, 164k used, 4096400k free, 1605276k cached PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
1 root 16 0 4744 552 460 S 0.0 0.0 0:00.46 init 從Top 顯示來看是有1963652K已經使用,只有92348k記憶體空閒。一直問我是否記憶體不足了。下面就來解釋一下Oracle 在Linux 下如何檢視OS 記憶體是否不足。 但我們從Linux command free 來看:
[oracle@itc-test9 ~]free
total used free shared buffers cached
Mem: 2056000 1869596 186404 0 59172 1512236
-/+ buffers/cache: 298188 1757812
Swap: 4096564 164 4096400
-/+ buffers/cache: used=298188k =291.2M free=1757812k=1716.6M 約等於2G。 從Free 命令列來看OS 還有1.76G 空間未使用。 需要解釋一下Free 和Top 在Linux 下的不同顯示問題。 Free命令顯示在作業系統中使用和空閒的記憶體數量。Top 顯示是和Linux 對記憶體使用的方式關係緊密,linux 儘可能的要求使 用實體記憶體來提高Buffer 和Cache 對Disk 的I/O操作。Linux 將盡可能多的將I/O 操作磁碟上的資訊儲存在記憶體當中,如果Oracle(其他程式也一樣)需要更多的記憶體空間,Linux 才會將一些記憶體使用LRU 演算法清理出來,如果不需要則繼續保持這些資料資訊在記憶體中。所以我們使用Top看到的Memory FreeMem: 2056000k total, 1963652k used, 92348k free很少。 第二部分:檢視Swap 的狀況: Swap 空間的使用狀況也能分辨出Oracle 伺服器記憶體是否已經吃緊。 先看Swap 大小設定:
RAM Size Swap Size
1-2G 1.5 倍 RAM
2-8G 1 倍 RAM
>8G 0.75 RAM 基本上每個操做系統(除Windows)都建議Swap 使用上面比例的配置。但根據個人經驗如果Server 的Memory >32G 時,一般都會將Swap 空間設定在 以內,甚至更小。 使用Command more /proc/meminfo 或top 來Monitor Swap 的使用狀況。 [root@itc-test9 ~]# more /proc/meminfo
MemTotal: 2056000 kB
MemFree: 177268 kB
Buffers: 59292 kB
Cached: 1519188 kB
SwapCached: 4 kB
Active: 1092248 kB
Inactive: 654096 kB
HighTotal: 0 kB
HighFree: 0 kB
LowTotal: 2056000 kB
LowFree: 177268 kB
SwapTotal: 4096564 kB
SwapFree: 4096400 kB
[root@itc-test9 ~]# top
top - 17:08:01 up 12 days, 3:48, 2 users, load average: 0.01, 0.01, 0.00
Tasks: 95 total, 1 running, 94 sleeping, 0 stopped, 0 zombie
Cpu(s): 0.0% us, 0.0% sy, 0.0% ni, 99.5% id, 0.5% wa, 0.0% hi, 0.0% si
Mem: 2056000k total, 1963652k used, 92348k free, 59156k buffers
Swap: 4096564k total, 164k used, 4096400k free, 1605276k cached
如果你觀察Swap 中的使用量一直在增加,或Swap used 為一個很大的值。那我們基本就能確定在現有的狀況下Oracle server 記憶體出現問題。(我們需要考慮此現象是偶爾發生還是一直出現)我們需要做: 增加記憶體 減少OS 程式使用記憶體資源,如Oracle 減少SGA_target 或Memory_Target(11g) 增大交換空間 你可以透過vmstat 來看當前Swap 活動的狀態。Swap 下面的Si 和So 分別顯示Swap 頁面交換進來和交換出去。
[root@itc-test9 ~]# vmstat 3 8
procs -----------memory---------- ---swap-- -----io---- --system-- ----cpu----
r b swpd free buff cache si so bi bo in cs us sy id wa
0 0 164 175468 59292 1520344 0 0 1 21 4 20 0 0 99 0
0 0 164 175532 59292 1520344 0 0 0 48 1038 41 0 0 100 0
0 0 164 175532 59292 1520344 0 0 0 61 1032 35 0 0 99 0
0 0 164 175532 59292 1520344 0 0 0 11 1028 39 0 0 100 0
0 0 164 175532 59292 1520344 0 0 0 15 1024 39 0 0 100 0 使用Vmstat 命令只能看當前的Swap 頁面的交換入和交換出。那如何看歷史Swap 資訊呢。 Linux 下有一個命令可以看,那就是
procs -----------memory---------- ---swap-- -----io---- --system-- ----cpu----
r b swpd free buff cache si so bi bo in cs us sy id wa
0 0 164 175468 59292 1520344 0 0 1 21 4 20 0 0 99 0
0 0 164 175532 59292 1520344 0 0 0 48 1038 41 0 0 100 0
0 0 164 175532 59292 1520344 0 0 0 61 1032 35 0 0 99 0
0 0 164 175532 59292 1520344 0 0 0 11 1028 39 0 0 100 0
0 0 164 175532 59292 1520344 0 0 0 15 1024 39 0 0 100 0 使用Vmstat 命令只能看當前的Swap 頁面的交換入和交換出。那如何看歷史Swap 資訊呢。 Linux 下有一個命令可以看,那就是
[root@itc-test9 sa]# cd /var/log/sa
[root@itc-test9 sa]# ls -al |grep 13
drwxr-xr-x 2 root root 4096 Apr 13 00:00 .
-rw-r--r-- 1 root root 209328 Apr 13 17:50 sa13
[root@itc-test9 sa]# date ----今天是4/13 號Mon Apr 13 17:58:02 CST 2009
[root@itc-test9 sa]# ll |grep 13
-rw-r--r-- 1 root root 209328 Apr 13 17:50 sa13
[root@itc-test9 sa]# sar -W -f sa13
Linux 2.6.9-5.ELsmp (itc-test9) 04/13/2009 12:00:01 AM pswpin/s pswpout/s
12:10:01 AM 0.00 0.00
12:20:01 AM 0.00 0.00
12:30:01 AM 0.00 0.00
12:40:01 AM 0.00 0.00
12:50:01 AM 0.00 0.00
01:00:01 AM 0.00 0.00
01:10:01 AM 0.00 0.00
01:20:01 AM 0.00 0.00
......(中間略去)...... (中間略去)03:50:01 PM 0.00 0.00
04:00:01 PM 0.00 0.00
04:10:01 PM 0.00 0.00
04:20:01 PM 0.00 0.00
04:30:01 PM 0.00 0.00
04:40:01 PM 0.00 0.00
04:50:01 PM 0.00 0.00
05:00:01 PM 0.00 0.00
05:10:01 PM 0.00 0.00
05:20:01 PM 0.00 0.00
05:30:01 PM 0.00 0.00
05:40:01 PM 0.00 0.00
05:50:01 PM 0.00 0.00
Average: 0.00 0.00
顯示從今天0點到當前的所有Swap 頁面交換的數量
[root@itc-test9 sa]# ls -al |grep 13
drwxr-xr-x 2 root root 4096 Apr 13 00:00 .
-rw-r--r-- 1 root root 209328 Apr 13 17:50 sa13
[root@itc-test9 sa]# date ----今天是4/13 號Mon Apr 13 17:58:02 CST 2009
[root@itc-test9 sa]# ll |grep 13
-rw-r--r-- 1 root root 209328 Apr 13 17:50 sa13
[root@itc-test9 sa]# sar -W -f sa13
Linux 2.6.9-5.ELsmp (itc-test9) 04/13/2009 12:00:01 AM pswpin/s pswpout/s
12:10:01 AM 0.00 0.00
12:20:01 AM 0.00 0.00
12:30:01 AM 0.00 0.00
12:40:01 AM 0.00 0.00
12:50:01 AM 0.00 0.00
01:00:01 AM 0.00 0.00
01:10:01 AM 0.00 0.00
01:20:01 AM 0.00 0.00
......(中間略去)...... (中間略去)03:50:01 PM 0.00 0.00
04:00:01 PM 0.00 0.00
04:10:01 PM 0.00 0.00
04:20:01 PM 0.00 0.00
04:30:01 PM 0.00 0.00
04:40:01 PM 0.00 0.00
04:50:01 PM 0.00 0.00
05:00:01 PM 0.00 0.00
05:10:01 PM 0.00 0.00
05:20:01 PM 0.00 0.00
05:30:01 PM 0.00 0.00
05:40:01 PM 0.00 0.00
05:50:01 PM 0.00 0.00
Average: 0.00 0.00
顯示從今天0點到當前的所有Swap 頁面交換的數量
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/11411056/viewspace-733489/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Linux 下判斷Server 記憶體是否不足LinuxServer記憶體
- Linux 下判斷Server 記憶體是否不足(原創)LinuxServer記憶體
- 記憶體管理:判斷物件是否存活記憶體物件
- Linux記憶體不足的處理方法Linux記憶體
- 增加一個判斷記憶體變數存在的函式 (轉)記憶體變數函式
- SQL SERVER的記憶體會不斷增加,問題分析(轉)SQLServer記憶體
- golang中判斷兩個slice是否相等與判斷值下的 陣列是否相等Golang陣列
- 判斷字串是否是合法的EMail (轉)字串AI
- SQL Server出現虛擬記憶體不足的解決方法SQLServer記憶體
- 提示“虛擬記憶體”不足的怎麼辦(轉)記憶體
- 判斷Linux系統是否被黑的方法Linux
- jQuery判斷按下的是否是enterEnter鍵jQuery
- js系列文章之 : 判斷 object 物件是否為空JSObject物件
- [轉帖]Solaris記憶體管理以及判定記憶體是否夠用的方法記憶體
- 電腦記憶體不足怎麼辦? 虛擬記憶體不足的解決辦法記憶體
- 改善SQL Server記憶體管理(轉)SQLServer記憶體
- Allowed memory size 記憶體不足記憶體
- 如何在 Linux 系統中判斷安裝、使用了多少記憶體Linux記憶體
- windows下提示虛擬記憶體不足如何解決?Windows記憶體
- vertica記憶體不足的解決方案記憶體
- 記憶體不足(OutOfMemory)的除錯分析記憶體除錯
- Sql Server中判斷表或者資料庫是否存在SQLServer資料庫
- Linux判斷URL是否存在,並返回IPLinux
- 怎麼判斷Linux是否適合你?Linux
- Linux記憶體使用的體會(轉)Linux記憶體
- Windows下bat指令碼判斷埠是否可用WindowsBAT指令碼
- oracle sqr之不同判斷寫入不同的.LIS檔案Oracle
- 解決ORACLE共享記憶體不足的方法Oracle記憶體
- 求助:關於linux下共享記憶體的問題(轉)Linux記憶體
- win10記憶體不足怎麼解決_win10記憶體不足怎麼辦Win10記憶體
- Linux Shell 判斷環境變數 是否存在Linux變數
- 如何判斷 Linux 伺服器是否被入侵?Linux伺服器
- 判斷字串是否為空字串
- 判斷URL字串是否合法字串
- 41:判斷元素是否存在
- 判斷oracle是否啟動Oracle
- Javascript 判斷物件是否相等JavaScript物件
- 判斷SD卡是否可用SD卡