Linux下查看某一个程序所使用的内存方法

嵌入式操作系统

54人已加入

描述

  Linux

  Linux的基本思想有两点:第一,一切都是文件;第二,每个软件都有确定的用途。其中第一条详细来讲就是系统中的所有都归结为一个文件,包括命令、硬件和软件设备、操作系统、进程等等对于操作系统内核而言,都被视为拥有各自特性或类型的文件。至于说Linux是基于Unix的,很大程度上也是因为这两者的基本思想十分相近。

  Linux是一款免费的操作系统,用户可以通过网络或其他途径免费获得,并可以任意修改其源代码。这是其他的操作系统所做不到的。正是由于这一点,来自全世界的无数程序员参与了Linux的修改、编写工作,程序员可以根据自己的兴趣和灵感对其进行改变,这让Linux吸收了无数程序员的精华,不断壮大。

  这使得可以在Linux下通过相应的模拟器运行常见的DOS、Windows的程序。这为用户从Windows转到Linux奠定了基础。许多用户在考虑使用Linux时,就想到以前在Windows下常见的程序是否能正常运行,这一点就消除了他们的疑虑。

  Linux支持多用户,各个用户对于自己的文件设备有自己特殊的权利,保证了各用户之间互不影响。多任务则是现在电脑最主要的一个特点,Linux可以使多个程序同时并独立地运行。

  Linux同时具有字符界面和图形界面。在字符界面用户可以通过键盘输入相应的指令来进行操作。它同时也提供了类似Windows图形界面的X-Window系统,用户可以使用鼠标对其进行操作。在X-Window环境中就和在Windows中相似,可以说是一个Linux版的Windows。

  Linux可以运行在多种硬件平台上,如具有x86、680x0、SPARC、Alpha等处理器的平台。此外Linux还是一种嵌入式操作系统,可以运行在掌上电脑、机顶盒或游戏机上。2001年1月份发布的Linux 2.4版内核已经能够完全支持Intel 64位芯片架构。同时Linux也支持多处理器技术。多个处理器同时工作,使系统性能大大提高。

  Linux

  linux常用命令及技巧

  通用命令:

  1. date :print or set the system date and time

  2. stty -a: 可以查看或者打印控制字符(Ctrl-C, Ctrl-D, Ctrl-Z等)

  3. passwd: print or set the system date and time (用passwd -h查看)

  4. logout, login: 登录shell的登录和注销命令

  5. pwd: print or set the system date and time

  6. more, less, head tail: 显示或部分显示文件内容。

  7. lp/lpstat/cancel, lpr/lpq/lprm: 打印文件。

  8. 更改文件权限: chmod u+x.。。

  9. 删除非空目录:rm -fr dir

  10.拷贝目录: cp -R dir

  11. fg jobid :可以将一个后台进程放到前台。

  Ctrl-z 可以将前台进程挂起(suspend), 然后可以用bg jobid 让其到后台运行。

  job & 可以直接让job直接在后台运行。

  12. kill 的作用: send a signal to a process. eg: kill -9 发送的是SIG_KILL信号。。。 具体发送什么信号 可以通过 man kill 查看。

  13. ps 的用法, ps -e 或 ps -o pid,ppid,session,tpgid, comm (其中session显示的sessionid, tpgid显示前台进程组id, comm显示命令名称。)

  Linux下查看某一个程序所使用的内存方法

  第一种方式

  top -p 进程号1

  [yzy@node3 micro-service]$ top -p 20490

  top - 16:50:32 up 6 days, 2:18, 1 user, load average: 0.00, 0.01, 0.05

  Tasks: 1 total, 0 running, 1 sleeping, 0 stopped, 0 zombie

  %Cpu(s): 0.1 us, 0.1 sy, 0.0 ni, 99.8 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st

  KiB Mem : 65876972 total, 51899292 free, 9988408 used, 3989272 buff/cache

  KiB Swap: 32964604 total, 32964604 free, 0 used. 55522228 avail Mem

  PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND

  20490 yzy 20 0 113252 1632 1272 S 0.0 0.0 0:35.50 sh 123456789

  第二种方式

  Linux

  ps -aux | grep 进程名1

  [zhoulu@node3 micro-service]$ ps -aux | grep eureka-auto.sh

  zhoulu 3716 0.0 0.0 112640 972 pts/0 S+ 16:49 0:00 grep --color=auto eureka-auto.sh

  zhoulu 20490 0.0 0.0 113252 1632 ? S Apr14 0:35 /bin/sh 。/eureka-auto.sh123

  第三种方式

  cat /proc/进程号/status1

  [zhoulu@node3 micro-service]$ cat /proc/20490/status

  Name: sh

  State: S (sleeping)

  Tgid: 20490

  Ngid: 0

  Pid: 20490

  PPid: 1

  TracerPid: 0

  Uid: 1019 1019 1019 1019

  Gid: 1019 1019 1019 1019

  FDSize: 256

  Groups: 1019

  VmPeak: 113256 kB

  VmSize: 113252 kB

  VmLck: 0 kB

  VmPin: 0 kB

  VmHWM: 1632 kB

  VmRSS: 1632 kB

  VmData: 340 kB

  VmStk: 136 kB

  VmExe: 884 kB

  VmLib: 2044 kB

  VmPTE: 52 kB

  VmSwap: 0 kB

  Threads: 1

  SigQ: 0/257254

  SigPnd: 0000000000000000

  ShdPnd: 0000000000000000

  SigBlk: 0000000000010000

  SigIgn: 0000000000000005

  SigCgt: 0000000000010002

  CapInh: 0000000000000000

  CapPrm: 0000000000000000

  CapEff: 0000000000000000

  CapBnd: 0000001fffffffff

  Seccomp: 0

  Cpus_allowed: ffff

  Cpus_allowed_list: 0-15

  Mems_allowed: 00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000001

  Mems_allowed_list: 0

  voluntary_ctxt_switches: 102189

  nonvoluntary_ctxt_switches: 170123456789101112131415161718192021222324252627282930313233343536373839404142

  VmSize(KB) 任务虚拟地址空间的大小 (total_vm-reserved_vm),其中total_vm为进程的地址空间的大小,reserved_vm:进程在预留或特殊的内存间的物理页

  VmLck(KB) 任务已经锁住的物理内存的大小。锁住的物理内存不能交换到硬盘 (locked_vm)

  VmRSS(KB) 应用程序正在使用的物理内存的大小,就是用ps命令的参数rss的值 (rss)

  VmData(KB) 程序数据段的大小(所占虚拟内存的大小),存放初始化了的数据; (total_vm-shared_vm-stack_vm)

  VmStk(KB) 任务在用户态的栈的大小 (stack_vm)

  VmExe(KB) 程序所拥有的可执行虚拟内存的大小,代码段,不包括任务使用的库 (end_code-start_code)

  VmLib(KB) 被映像到任务的虚拟内存空间的库的大小 (exec_lib)

  VmPTE 该进程的所有页表的大小,单位:kb

  Threads 共享使用该信号描述符的任务的个数,在POSIX多线程序应用程序中,线程组中的所有线程使用同一个信号描述符

  1、VmRSS是真实正在占用的内存,而VmData是虚拟内存,大小差异大并没有什么问题。

  2、VmData是指数据段的内存大小,存放初始化了的数据; (total_vm-shared_vm-stack_vm)

  3、不调动态库的时候是不计算的(dlopen方式)

  4、静态库会编译为程序本身的一部分,不在VmLib的统计之内。

  5、参考上面的说明

  6、除非有非常明显的内存泄露,如内存一直大幅度增长并长时间不释放,否则单纯以来这些值是很判断真正的内在泄露。

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分