Retrieving PID running time

P

Philip Rhoades

People,

I have found how to get PIDs etc but how can I find the running time of
a particular PID without messing around with a system call to ps etc

Thanks,

Phil.
--
Philip Rhoades

Pricom Pty Limited (ACN 003 252 275 ABN 91 003 252 275)
GPO Box 3411
Sydney NSW 2001
Australia
Mobile: +61:(0)411-185-652
Fax: +61:(0)2-8221-9599
E-mail: (e-mail address removed)
 
J

Joe Van Dyk

People,

I have found how to get PIDs etc but how can I find the running time of
a particular PID without messing around with a system call to ps etc

That information should be in /proc/<pid>/stat. Look at the man page
for proc for more details.
 
P

Philip Rhoades

That information should be in /proc/<pid>/stat. Look at the man page
for proc for more details.

Yes, but what I want (in Ruby) is something like:

ptime = Process.pid.time

How can I do that?

Thanks,

Phil.
--
Philip Rhoades

Pricom Pty Limited (ACN 003 252 275 ABN 91 003 252 275)
GPO Box 3411
Sydney NSW 2001
Australia
Mobile: +61:(0)411-185-652
Fax: +61:(0)2-8221-9599
E-mail: (e-mail address removed)
 
G

gwtmp01

Yes, but what I want (in Ruby) is something like:

ptime = Process.pid.time

How can I do that?

This sort of thing is very platform specific. I'm assuming
a unix/linux/macosx environment. I can't answer for Windows.

For your own process you can use Process::times, which
probably ends up calling getrusage(), a kernel system
call. See the Ruby doc for Process::times, and your system
docs for getrusage.

For the general problem of finding the information for
an arbitrary process it becomes more difficult. Some unix
systems make that sort of information available via the
/proc file system. Some make it available via the sysctl
system calls.

In either case, I don't think there is a standard Ruby library
for parsing /proc or for extracting sysctl values. You would
have to role your own.

Another hurdle is /proc and sysctl often restrict access to
programs with root privileges. So you would have to create
a setuid root ruby script to be able to read /proc or sysctl
information directly.

So if you want to get the information for an arbitrary process,
I think the quick and dirty solution is to capture the output of
ps and parse it yourself. You can use

text = `ps -l -p1234`

to get the data and then string juggling to extract the time info.
 
D

Daniel Berger

This sort of thing is very platform specific. I'm assuming
a unix/linux/macosx environment. I can't answer for Windows.

For your own process you can use Process::times, which
probably ends up calling getrusage(), a kernel system
call. See the Ruby doc for Process::times, and your system
docs for getrusage.

For the general problem of finding the information for
an arbitrary process it becomes more difficult. Some unix
systems make that sort of information available via the
/proc file system. Some make it available via the sysctl
system calls.

In either case, I don't think there is a standard Ruby library
for parsing /proc or for extracting sysctl values. You would
have to role your own.

<snip>

It's not in the standard library, but there is sys-proctable, available on the RAA.

Regards,

Dan
 
J

Joe Van Dyk

This sort of thing is very platform specific. I'm assuming
a unix/linux/macosx environment. I can't answer for Windows.

For your own process you can use Process::times, which
probably ends up calling getrusage(), a kernel system
call. See the Ruby doc for Process::times, and your system
docs for getrusage.

I thought Process::times just returned the system and user cpu time,
not the total real time since the application was started.
 
J

Joe Van Dyk

Yes, but what I want (in Ruby) is something like:

ptime =3D Process.pid.time

untested:

class Process
def meth_missing pid, *args
get_process_info(pid)[args.first]
end

def get_process_info pid
# parse /proc/<pid>/stat, put values you want into some struct and retu=
rn it
end
end
 
G

gwtmp01

I thought Process::times just returned the system and user cpu time,
not the total real time since the application was started.


I assumed the OP was looking for the system/user time not the clock
time.

In any case I think you'd have to go through /proc, sysctl, or
parse the output of ps to get the starting time of a process.

I only have quick access to Mac OSX where the start time is available
via the 'lstart' keyword using ps:

$ps -p3357 -o lstart
STARTED
Thu Dec 8 00:58:42 2005
$
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Members online

Forum statistics

Threads
473,981
Messages
2,570,188
Members
46,731
Latest member
MarcyGipso

Latest Threads

Top