JavaScript is required to for searching.
跳过导航链接
退出打印视图
手册页第 1 部分:用户命令     Oracle Solaris 11 Information Library (简体中文)
search filter icon
search icon

文档信息

前言

简介

用户命令

acctcom(1)

adb(1)

addbib(1)

admin(1)

alias(1)

allocate(1)

amt(1)

appcert(1)

apptrace(1)

apropos(1)

ar(1)

arch(1)

as(1)

asa(1)

at(1)

atq(1)

atrm(1)

audioconvert(1)

audioctl(1)

audioplay(1)

audiorecord(1)

audiotest(1)

auths(1)

auto_ef(1)

awk(1)

banner(1)

basename(1)

basename(1B)

batch(1)

bc(1)

bdiff(1)

bfs(1)

bg(1)

biff(1B)

break(1)

builtin(1)

cal(1)

calendar(1)

case(1)

cat(1)

cd(1)

cdc(1)

cdrw(1)

chdir(1)

checkeq(1)

checknr(1)

chgrp(1)

chkey(1)

chmod(1)

chown(1)

chown(1B)

ckdate(1)

ckgid(1)

ckint(1)

ckitem(1)

ckkeywd(1)

ckpath(1)

ckrange(1)

ckstr(1)

cksum(1)

cktime(1)

ckuid(1)

ckyorn(1)

clear(1)

cmp(1)

col(1)

comb(1)

comm(1)

command(1)

compress(1)

continue(1)

cp(1)

cpio(1)

cpp(1)

cputrack(1)

crle(1)

crontab(1)

csh(1)

csplit(1)

ct(1C)

ctags(1)

ctrun(1)

ctstat(1)

ctwatch(1)

cu(1C)

cut(1)

date(1)

dc(1)

deallocate(1)

decrypt(1)

delta(1)

deroff(1)

df(1B)

dhcpinfo(1)

diff(1)

diff3(1)

diffmk(1)

digest(1)

digestp(1)

dircmp(1)

dirname(1)

dirs(1)

dis(1)

disown(1)

dispgid(1)

dispuid(1)

dos2unix(1)

dpost(1)

du(1)

du(1B)

dump(1)

dumpcs(1)

dumpkeys(1)

echo(1)

echo(1B)

ed(1)

edit(1)

egrep(1)

eject(1)

elfdump(1)

elfedit(1)

elffile(1)

elfsign(1)

elfwrap(1)

encrypt(1)

enhance(1)

env(1)

eqn(1)

errange(1)

errdate(1)

errgid(1)

errint(1)

erritem(1)

error(1)

errpath(1)

errstr(1)

errtime(1)

erruid(1)

erryorn(1)

eval(1)

ex(1)

exec(1)

exit(1)

expand(1)

export(1)

exportfs(1B)

expr(1)

expr(1B)

exstr(1)

factor(1)

false(1)

fastboot(1B)

fasthalt(1B)

fc(1)

fg(1)

fgrep(1)

file(1)

file(1B)

filebench(1)

filep(1)

filesync(1)

filofaxp(1)

find(1)

finger(1)

fmt(1)

fmtmsg(1)

fold(1)

for(1)

foreach(1)

franklinp(1)

from(1B)

ftp(1)

function(1)

gcore(1)

gencat(1)

geniconvtbl(1)

genmsg(1)

get(1)

getconf(1)

getfacl(1)

getlabel(1)

getopt(1)

getoptcvt(1)

getopts(1)

gettext(1)

gettxt(1)

getzonepath(1)

glob(1)

goto(1)

gprof(1)

grep(1)

groups(1)

groups(1B)

grpck(1B)

hash(1)

hashcheck(1)

hashmake(1)

hashstat(1)

head(1)

helpdate(1)

helpgid(1)

helpint(1)

helpitem(1)

helppath(1)

helprange(1)

helpstr(1)

helptime(1)

helpuid(1)

helpyorn(1)

hist(1)

history(1)

hostid(1)

hostname(1)

i386(1)

i486(1)

iconv(1)

idnconv(1)

if(1)

indxbib(1)

install(1B)

ipcrm(1)

ipcs(1)

isainfo(1)

isalist(1)

jobs(1)

join(1)

jsh(1)

kbd(1)

kdestroy(1)

keylogin(1)

keylogout(1)

kill(1)

kinit(1)

klist(1)

kmdb(1)

kmfcfg(1)

kpasswd(1)

krb5-config(1)

ksh(1)

ksh88(1)

ksh93(1)

ktutil(1)

lari(1)

last(1)

lastcomm(1)

ld(1)

ldapadd(1)

ldapdelete(1)

ldaplist(1)

ldapmodify(1)

ldapmodrdn(1)

ldapsearch(1)

ldd(1)

ld.so.1(1)

let(1)

lex(1)

lgrpinfo(1)

limit(1)

line(1)

list_devices(1)

listusers(1)

llc2_autoconfig(1)

llc2_config(1)

llc2_stats(1)

ln(1)

ln(1B)

loadkeys(1)

locale(1)

localedef(1)

logger(1)

logger(1B)

login(1)

logname(1)

logout(1)

look(1)

lookbib(1)

lorder(1)

ls(1)

ls(1B)

m4(1)

mac(1)

mach(1)

machid(1)

madv.so.1(1)

mail(1)

Mail(1B)

mail(1B)

mailcompat(1)

mailp(1)

mailq(1)

mailstats(1)

mailx(1)

make(1S)

makekey(1)

man(1)

mconnect(1)

mcs(1)

mdb(1)

mesg(1)

mkdir(1)

mkmsgs(1)

mkstr(1B)

mktemp(1)

moe(1)

more(1)

mp(1)

mpss.so.1(1)

msgcc(1)

msgcpp(1)

msgcvt(1)

msgfmt(1)

msggen(1)

msgget(1)

mt(1)

mv(1)

nawk(1)

nc(1)

ncab2clf(1)

ncakmod(1)

neqn(1)

netcat(1)

newform(1)

newgrp(1)

newsp(1)

newtask(1)

nice(1)

nl(1)

nm(1)

nohup(1)

notify(1)

nroff(1)

od(1)

on(1)

onintr(1)

optisa(1)

pack(1)

page(1)

pagesize(1)

pam_tty_tickets.so(1)

pargs(1)

passwd(1)

paste(1)

patch(1)

pathchk(1)

pax(1)

pcat(1)

pcred(1)

perl(1)

pfbash(1)

pfcsh(1)

pfexec(1)

pfiles(1)

pfksh(1)

pflags(1)

pfsh(1)

pftcsh(1)

pfzsh(1)

pg(1)

pgrep(1)

pkcs11_inspect(1)

pkginfo(1)

pkgmk(1)

pkgparam(1)

pkgproto(1)

pkgtrans(1)

pkill(1)

pklogin_finder(1)

pktool(1)

plabel(1)

pldd(1)

plgrp(1)

plimit(1)

pmadvise(1)

pmap(1)

popd(1)

ppgsz(1)

ppriv(1)

pr(1)

praliases(1)

prctl(1)

preap(1)

print(1)

printenv(1B)

printf(1)

priocntl(1)

proc(1)

prof(1)

profiles(1)

projects(1)

prs(1)

prt(1)

prun(1)

ps(1)

ps(1B)

psig(1)

pstack(1)

pstop(1)

ptime(1)

ptree(1)

pushd(1)

pvs(1)

pwait(1)

pwd(1)

pwdx(1)

ranlib(1)

rcapstat(1)

rcp(1)

read(1)

readonly(1)

red(1)

refer(1)

regcmp(1)

rehash(1)

remote_shell(1)

remsh(1)

renice(1)

repeat(1)

reset(1B)

return(1)

rksh(1)

rksh88(1)

rlogin(1)

rm(1)

rmail(1)

rmdel(1)

rmdir(1)

rmformat(1)

rmmount(1)

rmumount(1)

roffbib(1)

roles(1)

rpcgen(1)

rpm2cpio(1)

rsh(1)

runat(1)

rup(1)

rup(1C)

ruptime(1)

rusage(1B)

rusers(1)

rwho(1)

sact(1)

sar(1)

sccs(1)

sccs-admin(1)

sccs-cdc(1)

sccs-comb(1)

sccs-delta(1)

sccsdiff(1)

sccs-get(1)

sccs-help(1)

sccshelp(1)

sccs-prs(1)

sccs-prt(1)

sccs-rmdel(1)

sccs-sact(1)

sccs-sccsdiff(1)

sccs-unget(1)

sccs-val(1)

scp(1)

script(1)

sdiff(1)

sed(1)

sed(1B)

select(1)

set(1)

setenv(1)

setfacl(1)

setlabel(1)

setpgrp(1)

settime(1)

sftp(1)

sh(1)

shcomp(1)

shell_builtins(1)

shift(1)

shutdown(1B)

size(1)

sleep(1)

soelim(1)

sort(1)

sortbib(1)

sotruss(1)

source(1)

sparc(1)

spell(1)

spellin(1)

split(1)

srchtxt(1)

ssh(1)

ssh-add(1)

ssh-agent(1)

ssh-http-proxy-connect(1)

ssh-keygen(1)

ssh-keyscan(1)

ssh-socks5-proxy-connect(1)

stop(1)

strchg(1)

strconf(1)

strings(1)

strip(1)

stty(1)

stty(1B)

sum(1)

sum(1B)

sun(1)

suspend(1)

svcprop(1)

svcs(1)

switch(1)

symorder(1)

sys-suspend(1)

sysV-make(1)

t300(1)

t300s(1)

t4014(1)

t450(1)

tabs(1)

tail(1)

talk(1)

tar(1)

tbl(1)

tcopy(1)

tee(1)

tek(1)

telnet(1)

test(1)

test(1B)

tftp(1)

time(1)

timemanp(1)

times(1)

timesysp(1)

timex(1)

tip(1)

touch(1)

touch(1B)

tplot(1)

tput(1)

tr(1)

tr(1B)

trap(1)

troff(1)

true(1)

truss(1)

tset(1B)

tsort(1)

tty(1)

type(1)

typeset(1)

ul(1)

ulimit(1)

umask(1)

unalias(1)

uname(1)

uncompress(1)

unexpand(1)

unget(1)

unhash(1)

unifdef(1)

uniq(1)

units(1)

unix2dos(1)

unlimit(1)

unpack(1)

unset(1)

unsetenv(1)

until(1)

updatehome(1)

uptime(1)

userattr(1)

users(1B)

uucp(1C)

uudecode(1C)

uuencode(1C)

uuglist(1C)

uulog(1C)

uuname(1C)

uupick(1C)

uustat(1C)

uuto(1C)

uux(1C)

vacation(1)

val(1)

valdate(1)

valgid(1)

valint(1)

valpath(1)

valrange(1)

valstr(1)

valtime(1)

valuid(1)

valyorn(1)

vc(1)

vedit(1)

ver(1)

vgrind(1)

vi(1)

view(1)

vipw(1B)

volcheck(1)

volrmmount(1)

w(1)

wait(1)

wc(1)

what(1)

whatis(1)

whence(1)

whereis(1B)

which(1)

while(1)

who(1)

whoami(1B)

whocalls(1)

whois(1)

write(1)

xargs(1)

xgettext(1)

xstr(1)

yacc(1)

yes(1)

ypcat(1)

ypmatch(1)

yppasswd(1)

ypwhich(1)

zcat(1)

zlogin(1)

zonename(1)

zonestat(1)

prctl

- 获取或设置正在运行的进程、任务和项目的资源控制

用法概要

prctl [-P] [-t [basic | privileged | system]] 
     [-n name [-srx] [-v value] [-e | -d action] [-p pid]] 
     [-i idtype] id...

描述

使用 prctl 实用程序,可以检查和修改与系统中的活动进程、任务或项目相关联的资源控制。它允许访问基本限制和特权限制以及当前在指定实体上使用的限制。

有关当前发行版的 Solaris 操作系统中支持的资源控制的说明,请参见 resource_controls(5)

选项

如果未指定 -s-r-x-v-d-e 选项中的任何一个,则调用被视为获取操作。否则,它被视为修改操作。

支持下列选项:

-d | -e action

-v-t-p 指定的资源控制值禁用 (-d) 或启用 (-e) 指定的 action。如果未指定 -v-t-p 选项中的任何一个,则它们与任何值、特权或接收者 pid 都匹配。例如,仅指定 -v 将修改具有匹配的值且与任意特权和接收者 pid 匹配的第一个资源控制。如果未找到匹配的资源控制值,则按指定了 -s 时的方式添加新值。

操作:

all

此操作仅适用于 -d。它将禁用所有操作。对于具有 deny 全局标志的资源控制值,此操作将失败。

deny

表示资源控制尝试拒绝向所请求的资源超出了资源控制值的请求上的进程、任务、项目或区域授予资源。如果资源控制具有 no-deny 全局标志,则无法启用 deny 操作。如果资源控制具有 deny 全局标志,则无法禁用 deny 操作。

signal

此操作仅适用于 -d。它将停用 signal 操作。

signal=signum

signal=signum 操作中,signum 是一个信号编号(或信号的字符串表示形式)。对具有 no-local-action 全局标志的资源控制设置 signal 操作会失败。可以发送一组有限的信号。有关其他详细信息,请参见

-i idtype

指定 id 操作数的类型。有效的 idtypeprocesstaskprojectzone。还可以为 pidtaskidprojidzoneid。如果省略了 -i 选项,则缺省 id 类型为 process

对于修改操作,id 操作数归属的实体是目标实体。例如,在 -i process 上设置一个项目资源控制将会在每个给定进程参数归属的项目上设置该资源控制。

对于获取操作,将为 id 操作数归属的所有实体列出资源控制。例如,-i task taskid 将为任务以及该任务归属的项目和区域列出任务、项目和区域资源控制。

-n name

指定要获取或设置的资源控制的名称。如果未指定 name,将检索所有资源控制。

-p pid

处理基本任务项目或区域资源控制值时(使用 -s-r-x-d-e),可使用 -p 指定接收者 pid。在任务、项目或区域上设置一个或多个新的基本资源控制时,如果 -i idtype 选项参数不是 process,则 -p 选项是必需的。

-P

以空格分隔形式显示资源控制值。

-r

使用通过 -v 选项指定的新值替换第一个资源控制值(与 -t privilege 相匹配的)。

-s

设置一个新的资源控制值。

此选项需要 -v 选项。

如果未指定 -t 选项,则使用基本特权。如果要设置基本任务、进程或区域资源控制,则需要 -p。如果还指定了 -e-d,则也将设置对新的资源控制的操作。

为了与早期版本兼容,如果指定了 -v 且未指定 -e-d-r-x 中的任何一个,则会隐式包含此选项。

有关设置资源控制值时可用于表示大值的单位修饰符和比例因子的说明,请参见 resource_controls(5)

-t [ basic | privileged | system ]

指定要设置的资源控制类型。除非为资源控制设置了 "lowerable" 标志,否则只有其特权等效于 root 的用户(或 setuid 程序)执行的调用可修改特权资源控制。有关 RCTL_GLOBAL_LOWERABLE 标志的说明,请参见 rctlblk_set_value(3C)。如果未指定类型,则采用 basic。对于获取操作,如果未指定类型,则将显示所有资源控制类型的值,包括 system

-v value

为设置操作指定资源控制值。如果未指定 value,则将在给定类型的具有最低值的资源控制上执行修改(删除、启用或禁用操作)。

有关设置资源控制值时可用于表示大值的单位修饰符和比例因子的说明,请参见 resource_controls(5)

-x

删除指定的资源控制值。如果未提供删除选项,则 prctl 的缺省操作是修改具有匹配的值和特权的资源控制值,或插入具有给定特权的新值。setrctl(2) 中更完整地讨论了匹配条件。

如果未指定 -d-e-v-x 选项中的任何一个,则调用被认为是获取操作。

操作数

支持以下操作数:

id

要查询的实体(processtaskprojectzone)的 ID。如果调用方用户的凭证没有特权,且正被查询的实体拥有不同的凭证,则操作将失败。如果未指定 id,则将返回一条错误消息。

示例

示例 1 显示当前的资源控制设置

以下示例显示当前 shell 所属任务的当前资源控制设置:

 example$ ps -o taskid -p $$
TASKID
8
example$ prctl -i task 8
136150: /bin/ksh
NAME    PRIVILEGE       VALUE    FLAG   ACTION             RECIPIENT
task.max-cpu-time
        usage            8s
        system          18.4Es    inf   none                -
task.max-lwps
        usage              39
        system          2.15G     max   deny                -
project.max-contracts
        privileged      10.0K       -   deny                -
project.max-locked-memory
        usage               0B
        privileged       508MB      -   deny                -
project.max-port-ids
        privileged      8.19K       -   deny                -
project.max-shm-memory
        privileged       508MB      -   deny                -
project.max-shm-ids
        privileged        128       -   deny                -
project.max-msg-ids
        privileged        128       -   deny                -
project.max-sem-ids
        privileged        128       -   deny                -
project.max-crypto-memory
         usage            0B
privileged       508MB      -   deny                -
project.max-tasks
        usage               2
        system          2.15G     max   deny                -
project.max-lwps
         usage             39
        system          2.15G     max   deny                -
project.cpu-shares
        usage               1
        privileged          1       -   none                -
zone.max-shm-memory
        system          16.0EB    max   deny                -
zone.max-shm-ids
        system          16.8M     max   deny                -
zone.max-sem-ids
        system          16.8M     max   deny                -
zone.max-msg-ids
        system          16.8M     max   deny                -
zone.max-lwps
        system          2.15G     max   deny                -
zone.cpu-shares
        privileged          1       -   none                -
zone.max-locked-memory
        usage               0B
        privileged       508MB      -   deny                -

示例 2 显示、替换和验证特定控制的值

以下示例显示、替换和验证某个现有项目上的特定控制的值:

example# prctl -n project.cpu-shares -i project group.staff
project: 10: group.staff
NAME    PRIVILEGE       VALUE    FLAG   ACTION               RECIPIENT
project.cpu-shares
        usage               1
        privileged          1       -   none                         -
        system          65.5K     max   none                         -

example# prctl -n project.cpu-shares -v 10 -r -i project group.staff
example# prctl -n project.cpu-shares -i project group.staff
project: 10: group.staff
NAME    PRIVILEGE       VALUE    FLAG   ACTION               RECIPIENT
project.cpu-shares
        usage              10
        privileged         10       -   none                         -
        system          65.5K     max   none                         -

示例 3 调整资源

以下示例使用了 project.max-locked-memory 资源。

首先,使用 id -p 找出当前 shell 是哪个项目的成员:

/home/garfield> id -p
          uid=77880(garfield) gid=10(staff) projid=10(group.staff)

使用目标项目,确定更改前的资源限制值:

/home/garfield> prctl -n project.max-locked-memory -i project \
                      group.staff
    project 10: group.staff
    project.max-locked-memory
            privileged         256MB       -    deny                  -
              system            16.0EB     max    deny                  -

current limit is 256 Megabytes.

然后,将目标项目的 project.max-locked-memory 限制调整为 300M 字节:

# prctl -n project.max-locked-memory -v 300M -r -i project group.staff

更改后的资源限制值将显示新值 300M 字节:

# prctl -n project.max-locked-memory -i project group.staff
    project 10:group.staff
    project.max-locked-memory
        usage              200MG
     privileged         300MB       -    deny                           -
       system            16.0EB     max    deny                           -

示例 4 修改项目的 CPU 上限

prctl 命令可使用 project.cpu-cap 资源控制(请参见 resource_controls(5))设置和修改项目的 CPU 上限。(可在 /etc/project 文件中使用相同的资源控制。请参见 project(4))。以下命令将修改 CPU 上限,将 user.smith 限制到三个 CPU:

# prctl -r -t privileged -n project.cpu-cap -v 300 -i project user.smith

上面所使用的 prctl -r 选项用来动态更改项目或区域的 CPU 上限。例如,以下命令将上述命令中的上限设置更改为 80%:

# prctl -r -t privileged -n project.cpu-cap -v 80 -i project user.smith

要删除 CPU 上限,请输入:

# prctl -x -n project.cpu-cap $$

示例 5 修改区域的 CPU 上限

prctl 命令可使用 zone.cpu-cap 资源控制(请参见 resource_controls(5))设置和修改区域的 CPU 上限。(可使用 zonecfg(1M) 命令操控相同的资源控制。)以下命令将修改 CPU 上限,将全局区域限制到 CPU 的 80%:

# prctl -t privileged -n zone.cpu-cap -v 80 -i zone global

可使用以下命令将上限降低至 50%:

# prctl -r -t privileged -n zone.cpu-cap -v 50 -i zone global

退出状态

将返回以下退出值:

0

成功。

1

遇到致命错误。

2

指定的命令行选项无效。

文件

/proc/pid/*

进程信息和控制文件

属性

有关下列属性的描述,请参见 attributes(5)

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

命令行语法是 "Committed"(已确定)。人可阅读的输出是 "Uncommitted"(未确定)。可解析的输出是 "Committed"(已确定)。

另请参见

rctladm(1M)zonecfg(1M)setrctl(2)rctlblk_get_local_action(3C)project(4)attributes(5)resource_controls(5)

附注

可在允许本地操作的资源控制块上设置的有效信号有 SIGABRTSIGXRESSIGHUPSIGSTOPSIGTERMSIGKILL。此外,CPU 时间相关控制可发出 SIGXCPU 信号,文件大小相关控制可发送 SIGXFSZ 信号。