2002-02-01 22:47:29 +00:00
|
|
|
.\" Manual page for pgrep / pkill.
|
|
|
|
.\" Licensed under version 2 of the GNU General Public License.
|
|
|
|
.\" Copyright 2000 Kjetil Torgrim Homme
|
|
|
|
.\"
|
2011-02-23 09:17:54 +01:00
|
|
|
.TH PGREP 1 "October 5, 2007" "Linux" "Linux User's Manual"
|
2002-02-01 22:47:29 +00:00
|
|
|
.SH NAME
|
|
|
|
pgrep, pkill \- look up or signal processes based on name and other attributes
|
|
|
|
|
|
|
|
.SH SYNOPSIS
|
2011-02-23 09:17:54 +01:00
|
|
|
.na
|
|
|
|
\fBpgrep\fR [\fB\-flvx\fR] [\fB\-d\ \fIdelimiter\fR] [\fB\-n\fR|\fB\-o\fR] \
|
|
|
|
[\fB\-P\ \fIppid\fR,...] [\fB\-g\ \fIpgrp\fR,...] [\fB\-s\ \fIsid\fR,...] \
|
|
|
|
[\fB\-u\ \fIeuid\fR,...] [\fB\-U\ \fIuid\fR,...] [\fB\-G\ \fIgid\fR,...] \
|
|
|
|
[\fB\-t\ \fIterm\fR,...] [\fIpattern\fR]
|
|
|
|
|
|
|
|
.HP
|
|
|
|
\fBpkill\fR [\fB\-\fIsignal\fR] [\fB\-fvx\fR] [\fB\-n\fR|\fB\-o\fR] \
|
|
|
|
[\fB\-P\ \fIppid\fR,...] [\fB\-g\ \fIpgrp\fR,...] [\fB\-s\ \fIsid\fR,...] \
|
|
|
|
[\fB\-u\ \fIeuid\fR,...] [\fB\-U\ \fIuid\fR,...] [\fB\-G\ \fIgid\fR,...] \
|
|
|
|
[\fB\-t\ \fIterm\fR,...] [\fIpattern\fR]
|
2002-02-01 22:47:29 +00:00
|
|
|
|
|
|
|
.SH DESCRIPTION
|
|
|
|
\fBpgrep\fP looks through the currently running processes and lists the
|
|
|
|
process IDs which matches the selection criteria to stdout. All
|
|
|
|
the criteria have to match. For example,
|
|
|
|
|
2011-02-23 09:17:54 +01:00
|
|
|
.IP
|
|
|
|
$ pgrep \-u root sshd
|
2002-02-01 22:47:29 +00:00
|
|
|
|
2011-02-23 09:17:54 +01:00
|
|
|
.PP
|
2002-02-01 22:47:29 +00:00
|
|
|
will only list the processes called \fBsshd\fP AND owned by \fBroot\fP.
|
|
|
|
On the other hand,
|
|
|
|
|
2011-02-23 09:17:54 +01:00
|
|
|
.IP
|
|
|
|
$ pgrep \-u root,daemon
|
2002-02-01 22:47:29 +00:00
|
|
|
|
2011-02-23 09:17:54 +01:00
|
|
|
.PP
|
2002-02-01 22:47:29 +00:00
|
|
|
will list the processes owned by \fBroot\fP OR \fBdaemon\fP.
|
|
|
|
|
|
|
|
\fBpkill\fP will send the specified signal (by default \fBSIGTERM\fP)
|
|
|
|
to each process instead of listing them on stdout.
|
|
|
|
|
|
|
|
.SH OPTIONS
|
|
|
|
.TP
|
2011-02-23 09:17:54 +01:00
|
|
|
\fB\-d \fIdelimiter\fP
|
2002-02-01 22:47:29 +00:00
|
|
|
Sets the string used to delimit each process ID in the output (by
|
|
|
|
default a newline). (\fBpgrep\fP only.)
|
|
|
|
.TP
|
2011-02-23 09:17:54 +01:00
|
|
|
\fB\-f\fR
|
2002-02-01 22:47:29 +00:00
|
|
|
The \fIpattern\fP is normally only matched against the process name.
|
2011-02-23 09:17:54 +01:00
|
|
|
When \fB\-f\fR is set, the full command line is used.
|
2002-02-01 22:47:29 +00:00
|
|
|
.TP
|
2011-02-23 09:17:54 +01:00
|
|
|
\fB\-g \fIpgrp\fP,...
|
2002-02-01 22:47:29 +00:00
|
|
|
Only match processes in the process group IDs listed. Process group 0
|
|
|
|
is translated into \fBpgrep\fP's or \fBpkill\fP's own process group.
|
|
|
|
.TP
|
|
|
|
\-G \fIgid\fP,...
|
|
|
|
Only match processes whose real group ID is listed. Either the
|
|
|
|
numerical or symbolical value may be used.
|
|
|
|
.TP
|
2011-02-23 09:17:54 +01:00
|
|
|
\fB\-l\fR
|
2002-02-01 22:47:29 +00:00
|
|
|
List the process name as well as the process ID. (\fBpgrep\fP only.)
|
|
|
|
.TP
|
2011-02-23 09:17:54 +01:00
|
|
|
\fB\-n\fR
|
2002-02-01 22:47:29 +00:00
|
|
|
Select only the newest (most recently started) of the matching
|
|
|
|
processes.
|
|
|
|
.TP
|
2011-02-23 09:17:54 +01:00
|
|
|
\fB\-o\fR
|
2002-10-23 07:53:16 +00:00
|
|
|
Select only the oldest (least recently started) of the matching
|
|
|
|
processes.
|
|
|
|
.TP
|
2011-02-23 09:17:54 +01:00
|
|
|
\fB\-P \fIppid\fP,...
|
2002-02-01 22:47:29 +00:00
|
|
|
Only match processes whose parent process ID is listed.
|
|
|
|
.TP
|
2011-02-23 09:17:54 +01:00
|
|
|
\fB\-s \fIsid\fP,...
|
2002-02-01 22:47:29 +00:00
|
|
|
Only match processes whose process session ID is listed. Session ID 0
|
|
|
|
is translated into \fBpgrep\fP's or \fBpkill\fP's own session ID.
|
|
|
|
.TP
|
2011-02-23 09:17:54 +01:00
|
|
|
\fB\-t \fIterm\fP,...
|
2002-02-01 22:47:29 +00:00
|
|
|
Only match processes whose controlling terminal is listed. The
|
|
|
|
terminal name should be specified without the "/dev/" prefix.
|
|
|
|
.TP
|
2011-02-23 09:17:54 +01:00
|
|
|
\fB\-u \fIeuid\fP,...
|
2002-02-01 22:47:29 +00:00
|
|
|
Only match processes whose effective user ID is listed. Either the
|
|
|
|
numerical or symbolical value may be used.
|
|
|
|
.TP
|
2011-02-23 09:17:54 +01:00
|
|
|
\fB\-U \fIuid\fP,...
|
2002-02-01 22:47:29 +00:00
|
|
|
Only match processes whose real user ID is listed. Either the
|
|
|
|
numerical or symbolical value may be used.
|
|
|
|
.TP
|
2011-02-23 09:17:54 +01:00
|
|
|
\fB\-v\fR
|
2002-02-01 22:47:29 +00:00
|
|
|
Negates the matching.
|
|
|
|
.TP
|
2011-02-23 09:17:54 +01:00
|
|
|
\fB\-x\fR
|
2002-02-01 22:47:29 +00:00
|
|
|
Only match processes whose name (or command line if \-f is specified)
|
|
|
|
\fBexactly\fP match the \fIpattern\fP.
|
|
|
|
.TP
|
|
|
|
\-\fIsignal\fP
|
|
|
|
Defines the signal to send to each matched process. Either the
|
|
|
|
numeric or the symbolic signal name can be used. (\fBpkill\fP only.)
|
|
|
|
|
|
|
|
.SH OPERANDS
|
|
|
|
.TP
|
|
|
|
\fIpattern\fP
|
|
|
|
Specifies an Extended Regular Expression for matching against the
|
|
|
|
process names or command lines.
|
|
|
|
|
|
|
|
.SH EXAMPLES
|
|
|
|
Example 1: Find the process ID of the \fBnamed\fP daemon:
|
|
|
|
|
2011-02-23 09:17:54 +01:00
|
|
|
.IP
|
|
|
|
$ pgrep \-u root named
|
2002-02-01 22:47:29 +00:00
|
|
|
|
2011-02-23 09:17:54 +01:00
|
|
|
.PP
|
2002-02-01 22:47:29 +00:00
|
|
|
Example 2: Make \fBsyslog\fP reread its configuration file:
|
|
|
|
|
2011-02-23 09:17:54 +01:00
|
|
|
.IP
|
|
|
|
$ pkill \-HUP syslogd
|
2002-02-01 22:47:29 +00:00
|
|
|
|
2011-02-23 09:17:54 +01:00
|
|
|
.PP
|
2002-02-01 22:47:29 +00:00
|
|
|
Example 3: Give detailed information on all \fBxterm\fP processes:
|
|
|
|
|
2011-02-23 09:17:54 +01:00
|
|
|
.IP
|
|
|
|
$ ps \-fp $(pgrep \-d, \-x xterm)
|
2002-02-01 22:47:29 +00:00
|
|
|
|
2011-02-23 09:17:54 +01:00
|
|
|
.PP
|
2002-02-01 22:47:29 +00:00
|
|
|
Example 4: Make all \fBnetscape\fP processes run nicer:
|
|
|
|
|
2011-02-23 09:17:54 +01:00
|
|
|
.IP
|
|
|
|
$ renice +4 `pgrep netscape`
|
2002-02-01 22:47:29 +00:00
|
|
|
|
|
|
|
.SH "EXIT STATUS"
|
2011-02-23 09:17:54 +01:00
|
|
|
.PD 0
|
2002-02-01 22:47:29 +00:00
|
|
|
.TP
|
2011-02-23 09:17:54 +01:00
|
|
|
.I 0
|
2002-02-01 22:47:29 +00:00
|
|
|
One or more processes matched the criteria.
|
|
|
|
.TP
|
2011-02-23 09:17:54 +01:00
|
|
|
.I 1
|
2002-02-01 22:47:29 +00:00
|
|
|
No processes matched.
|
|
|
|
.TP
|
2011-02-23 09:17:54 +01:00
|
|
|
.I 2
|
2002-02-01 22:47:29 +00:00
|
|
|
Syntax error in the command line.
|
|
|
|
.TP
|
2011-02-23 09:17:54 +01:00
|
|
|
.I 3
|
2002-02-01 22:47:29 +00:00
|
|
|
Fatal error: out of memory etc.
|
|
|
|
|
|
|
|
.SH NOTES
|
|
|
|
The process name used for matching is limited to the 15 characters
|
|
|
|
present in the output of /proc/\fIpid\fP/stat. Use the \-f option to
|
|
|
|
match against the complete command line, /proc/\fIpid\fP/cmdline.
|
|
|
|
|
|
|
|
The running \fBpgrep\fP or \fBpkill\fP process will never report
|
|
|
|
itself as a match.
|
|
|
|
|
|
|
|
.SH BUGS
|
2011-02-23 09:17:54 +01:00
|
|
|
The options \fB\-n\fP and \fB\-o\fP and \fB\-v\fP can not be combined.
|
|
|
|
Let me know if you need to do this.
|
2002-02-01 22:47:29 +00:00
|
|
|
|
|
|
|
Defunct processes are reported.
|
|
|
|
|
|
|
|
.SH "SEE ALSO"
|
2011-02-23 09:17:54 +01:00
|
|
|
.BR ps (1),
|
|
|
|
.BR regex (7),
|
|
|
|
.BR signal (7),
|
|
|
|
.BR killall (1),
|
|
|
|
.BR skill (1),
|
|
|
|
.BR kill (1),
|
|
|
|
.BR kill (2)
|
2002-02-01 22:47:29 +00:00
|
|
|
|
|
|
|
.SH STANDARDS
|
|
|
|
\fBpkill\fP and \fBpgrep\fP were introduced in Sun's Solaris 7. This
|
|
|
|
implementation is fully compatible.
|
|
|
|
|
|
|
|
.SH AUTHOR
|
|
|
|
Kjetil Torgrim Homme <kjetilho@ifi.uio.no>
|
|
|
|
|
2011-06-04 19:40:29 +02:00
|
|
|
Please send bug reports to <procps@freelists.org>
|