以下からインポートしたスクリプトを使用してください。場所
#!/usr/bin/ksh
# Available memory
memory=`prtconf | grep Memory | head -1 | awk 'BEGIN {FS=" "} {print $3}'`
gb_memory=`echo "scale=2; $memory/1024" | bc -l`
# Free memory
pagesize=`pagesize`
kb_pagesize=`echo "scale=2; $pagesize/1024" | bc -l`
sar_freemem=`sar -r 1 1 | tail -1 | awk 'BEGIN {FS=" "} {print $2}'`
gb_freemem=`echo "scale=2; $kb_pagesize*$sar_freemem/1024/1024" | bc -l`
# Used Memory
gb_usedmem=`echo "scale=2; $gb_memory-$gb_freemem" | bc -l`
# Conclusion
echo "Avai Mem: $gb_memory GB"
echo "Free Mem: $gb_freemem GB"
echo "Used Mem: $gb_usedmem GB"
メモリをたくさん使うのを見たら
Avai Mem: 7.25 GB
Free Mem: .62 GB
Used Mem: 6.63 GB
topコマンドを使用すると、ほとんどの「ram eat」プロセスは144MのRAMを使用しますが、690MのRAMのみが使用可能であることがわかります。これは少し奇妙です。他のRSSプロセスを数えても、システムがより多くのRAMを使用する方法を理解することはできません。 4GB以上のRAM。
last pid: 15109; load avg: 0.08, 0.08, 0.07; up 2+00:33:21 15:25:40
88 processes: 87 sleeping, 1 on cpu
CPU states: 94.4% idle, 1.3% user, 4.3% kernel, 0.0% stolen, 0.0% swap
Kernel: 1031 ctxsw, 633 trap, 769 intr, 2053 syscall, 617 flt
Memory: 7430M phys mem, 690M free mem, 1024M total swap, 1024M free swap
PID USERNAME NLWP PRI NICE SIZE RES STATE TIME CPU COMMAND
879 root 17 59 0 209M 142M sleep 8:11 0.32% sstored
1267 root 43 59 0 129M 30M sleep 0:04 0.01% fmd
14774 root 64 59 0 90M 64M sleep 0:04 0.24% pkg.depotd
14810 root 64 59 0 90M 63M sleep 0:04 0.25% pkg.depotd
14792 root 64 59 0 87M 60M sleep 0:04 0.24% pkg.depotd
15 root 36 59 0 80M 47M sleep 1:23 0.67% svc.configd
13 root 14 59 0 39M 7272K sleep 0:07 0.01% svc.startd
1448 root 12 59 0 28M 7152K sleep 0:14 0.01% sysstatd
1483 _polkitd 6 59 0 25M 196K sleep 0:00 0.00% polkitd
1465 pkg5srv 27 59 0 24M 2228K sleep 0:00 0.00% httpd
4962 pkg5srv 27 59 0 24M 4672K sleep 0:00 0.00% httpd
1461 pkg5srv 27 59 0 24M 4032K sleep 0:00 0.00% httpd
1464 pkg5srv 27 59 0 24M 3516K sleep 0:00 0.00% httpd
1032 webservd 27 59 0 24M 3668K sleep 0:00 0.00% httpd
1045 webservd 27 59 0 24M 3484K sleep 0:00 0.00% httpd
1041 webservd 27 59 0 24M 3480K sleep 0:00 0.00% httpd
1458 pkg5srv 24 59 0 24M 4656K sleep 0:04 0.00% httpd
1012 webservd 18 59 0 23M 7620K sleep 0:04 0.00% httpd
280 root 11 59 0 23M 8360K sleep 0:00 0.00% rad
658 root 31 59 0 23M 5168K sleep 0:07 0.04% nscd
359 daemon 3 59 0 21M 4K sleep 0:00 0.00% colord
560 netadm 8 59 0 18M 4352K sleep 0:02 0.00% nwamd
838 root 3 59 0 18M 3064K sleep 0:00 0.00% zoneadmd
338 root 7 59 0 17M 10M sleep 0:02 0.00% devfsadm
4350 root 1 59 0 17M 4972K sleep 0:01 0.00% sendmail
1469 root 3 59 0 16M 3776K sleep 0:00 0.00% accounts-daemon
ps=アクティブ領域がありますが…実行されません。
答え1
@Foxがコメントで指摘したように、ZFSはデフォルトでIOをキャッシュするために空きメモリを使用します。さまざまな調整がありますが、Solaris 11 で ZFS のパフォーマンスを向上させる機能を追加するので、Solaris をアップグレードするだけで役に立ちます。 MOSのマニュアルを参照してください。Oracle Solaris 11.xでのZFSとアプリケーション間のメモリ管理(文書ID 1663862.1)情報と指示を入手してください。
Oracle外の一部のZFS Recoについては、次を参照してください。 https://constantin.glez.de/2010/04/28/ten-ways-to-easily-improve-oracle-solaris-zfs-filesystem-performance/#ssdread
また、データセットに重複排除を使用すると、かなりの量のメモリが使用されます。