proc_nice
(PHP 5, PHP 7, PHP 8)
proc_nice — 現在のプロセスの優先度を変更する
説明
proc_nice() は、現在のプロセスの優先度を
priority
で指定された値に変更します。
priority
が正数の場合、
現在のプロセスの優先度をより低くし、priority
が負数の場合は優先度が上がります。
proc_nice() は、proc_open() やそれに関連する関数とは関係ありません。
パラメータ
priority
-
新しい優先度の値。この値はプラットフォームによっては異なるかもしれません。
Unix 上では、
-20
のように低い値が高い優先度である一方で、 正の値は低い優先度として扱われます。Windows では、
priority
パラメータは次のような意味があります:優先度クラス 取りうる値 優先度高 priority
< -9
通常より高い優先度 priority
< -4
通常の優先度 priority
< 5
&priority
> -5
通常より低い優先度 priority
> 5
アイドルな優先度 priority
> 9
戻り値
成功した場合に true
を、失敗した場合に false
を返します。
ユーザーが優先度を変更する権限を持っていないなど、
エラーが発生した場合は E_WARNING
レベルのエラーも発行されます。
変更履歴
バージョン | 説明 |
---|---|
7.2.0 | この関数は、Windows で利用できるようになりました。 |
例
例1 proc_nice() 関数を使い、プロセスの優先度を高に設定する
<?php
// Highest priority
proc_nice(-20);
?>
注意
注意: 可用性
proc_nice() は、使用しているシステムが 'nice' の機能を持っている場合のみ利用可能です。 'nice' は次のシステムに準拠しています: SVr4, SVID EXT, AT&T, X/OPEN, BSD 4.3 。
注意: Windows のみ
proc_nice() 関数は、 PHP がたとえスレッドセーフを有効にしてコンパイルされていたとしても、 現在の プロセス の優先度を変更します。
参考
- pcntl_setpriority() - プロセスの優先度を変更する
User Contributed Notes 5 notes
On a Linux system, running apache2 as a non-privileged user you can not increase the niceness of the process after decreasing it. Also, you can not use the apache_child_ terminate either. I found the following does work though:
<?php
//decrease niceness
proc_nice(19);
//kill child process to "reset" niceness
posix_kill( getmypid(), 28 );
?>
If a process is reniced, then all its children inherit that niceness. So a PHP script can call proc_nice on itself, then invoke system(), and the command executed via system() will also be niced.
Also worth making a note of ionice. There's no PHP function for this, but it's important. A nice'd program will happily try to chew up all i/o bandwidth with very little CPU usage, it can therefore make the entire computer non-responsive despite the programmer's intention. Use "ionice -c3" or see "man ionice"
Regarding ionice - on linux the impact of the ionice -c3 class is similar to that of nice, because the CPU "niceness" is taken into account when calculating the io niceness.
It is important to note that this is a relative change. I didn't read the description properly and couldn't figure out why setting proc_nice(0) didn't take the forked children back to 0!
For example if you run:
<?php
proc_nice(-5);
proc_nice(0); // will have no effect
proc_nice(5); // will take the niceness back to 0
?>
In PHP CLI under Debian (and probably many other Linux flavours) you can read the 'niceness' from the proc filesystem. (There may be a PHP command that gives this info but there doesn't seem to be a link to it on this page.)
E.g
<?php
$Current_Niceness_Value = intval(explode(" ",file_get_contents("/proc/".getmypid()."/stat"))[18]);
// Note: Older versions of Linux return an unsigned integer which has to be converted to a signed integer.
$Current_Niceness_Value = unpack("l",pack("L",intval(explode(" ",file_get_contents("/proc/".getmypid()."/stat"))[18])))[1];
?>
Simple function for check process nice, by default returns nice of current process:
<?php
public static function getProcessNice ($pid = null) {
if (!$pid) {
$pid = getmypid ();
}
$res = `ps -p $pid -o "%p %n"`;
preg_match ('/^\s*\w+\s+\w+\s*(\d+)\s+(\d+)/m', $res, $matches);
return array ('pid' => (isset ($matches[1]) ? $matches[1] : null), 'nice' => (isset ($matches[2]) ? $matches[2] : null));
}
?>