手册页部分 1: 用户命令

退出打印视图

更新时间: 2014 年 7 月
 
 

pmadvise(1)

名称

pmadvise - 将关于内存的建议应用于某个进程

用法概要

pmadvise -o option[,option] [-F] [-l] [-v] pid...

描述

pmadvise 使用 madvise(3C) 在指定的进程中应用有关如何使用内存的建议。

pmadvise 允许用户在一个特定时刻向一个子范围应用建议。pmadvisemadv.so.1(1) 的区别在于,madv.so.1(1) 在目标程序的整个执行过程中将建议应用于指定类型的所有段。

选项

支持以下选项:

–F

通过抓取目标进程来强制执行,即使另一进程已掌握了控制权。

您应当慎用 –F 选项。请参见 proc(1)

–l

显示未解析的动态链接程序映射名称。

–o

以下面的格式指定要应用的建议:


private=advice
shared=advice
heap=advice
stack=advice
address[:length]=advice

其中,advice 可以是下列值之一:


normal
random
sequential
willneed
dontneed
free
access_lwp
access_many
access_many_pset
access_default

可以提供 addresslength 来指定应用建议的子范围。缺省情况下,address 应该为十六进制,并且 length 应以字节计。

如果未指定 length,且起始地址引用了某个段的开头,则会将建议应用于该段。length 可使用 KMGTPE 加以限定,以分别指定千字节、兆字节、千兆字节、兆兆字节或艾字节作为度量单位。

–v

显示详细输出。像 pmap(1) 一样显示输出,显示哪个建议应用于何处。当建议应用于某个指定区域(例如专用的、共享的,等等)时,要精确获取关于建议应用于何处的反馈时,这可能比较有用。

pmadvise 尝试处理所有合法选项。如果指定了非法的地址范围,则会输出一条错误消息,且跳过违规选项。当存在语法错误时,pmadvise 将不处理任何选项而退出,并且会输出用法消息。

如果在某个区域上给定了冲突的建议,则优先顺序是从针对性最强的建议到针对性最弱的(即最通用的)建议。换句话说,为特定地址范围指定的建议优先于为堆和栈指定的建议,其次,为堆和栈指定的建议优先于为专用和共享内存指定的建议。

此外,下列每个组中的建议与同一组中的其他建议是互斥的:


MADV_NORMAL, MADV_RANDOM, MADV_SEQUENTIAL
MADV_WILLNEED, MADV_DONTNEED, MADV_FREE
MADV_ACCESS_DEFAULT, MADV_ACCESS_LWP, MADV_ACCESS_MANY

操作数

支持下列操作数:

pid

进程 ID.

示例

示例 1 将建议应用于位于指定地址的段

以下示例将建议应用于位于指定地址的段:


% pmap $$
100666: tcsh
00010000     312K r-x--  /usr/bin/tcsh
0006C000      48K rwx--  /usr/bin/tcsh
00078000     536K rwx--    [ heap ]
FF100000     856K r-x--  /lib/libc.so.1
FF1E6000      32K rwx--  /lib/libc.so.1
FF1EE000       8K rwx--  /lib/libc.so.1
FF230000     168K r-x--  /lib/libcurses.so.1
FF26A000      32K rwx--  /lib/libcurses.so.1
FF272000       8K rwx--  /lib/libcurses.so.1
FF280000     576K r-x--  /lib/libnsl.so.1
FF310000      40K rwx--  /lib/libnsl.so.1
FF31A000      24K rwx--  /lib/libnsl.so.1
FF364000       8K rwxs-    [ anon ]
FF370000      48K r-x--  /lib/libsocket.so.1
FF38C000       8K rwx--  /lib/libsocket.so.1
FF3B0000     176K r-x--  /lib/ld.so.1
FF3EC000       8K rwx--  /lib/ld.so.1
FF3EE000       8K rwx--  /lib/ld.so.1
FFBE6000     104K rw---    [ stack ]
%
% pmadvise -o 78000=access_lwp $$

%
示例 2 使用 –v 选项

以下示例显示了来自 pmadvise 的详细输出:

 
% pmadvise -o heap=access_lwp,stack=access_default -v $$
1720:   -sh
00010000      88K r-x--  /usr/sbin/sh
00036000       8K rwx--  /usr/sbin/sh
00038000      16K rwx--    [ heap ]           <= access_lwp
FF250000      24K r-x--  /lib/libgen.so.1
FF266000       8K rwx--  /lib/libgen.so.1
FF272000       8K rwxs-    [ anon ]
FF280000     840K r-x--  /lib/libc.so.1
FF362000      32K rwx--  /lib/libc.so.1
FF36A000      16K rwx--  /lib/libc.so.1
FF390000      64K rwx--    [ anon ]
FF3B0000     168K r-x--  /lib/ld.so.1
FF3EA000       8K rwx--  /lib/ld.so.1
FF3EC000       8K rwx--  /lib/ld.so.1
FFBFE000       8K rw---    [ stack ]          <= access_default

退出状态

将返回以下退出值:

0

成功完成。

非零值

出现错误。

文件

/proc/*

进程文件

/usr/prob/lib/*

proc 工具支持文件

属性

有关下列属性的说明,请参见 attributes(5)

属性类型
属性值
可用性
system/core-os
接口稳定性
请参见下文。

命令语法是 "Committed"(已确定)。输出格式是 "Uncommitted"(未确定)。

另请参见

madv.so.1(1)pmap(1)proc(1)madvise(3C)attributes(5)