O comando ps (pelo menos a versão procps usada por muitas distribuições Linux) possui vários campos de formato relacionados à hora de início do processo, incluindo os lstart
que sempre fornecem a data e a hora completas do processo:
# ps -p 1 -wo pid,lstart,cmd
PID STARTED CMD
1 Mon Dec 23 00:31:43 2013 /sbin/init
# ps -p 1 -p $$ -wo user,pid,%cpu,%mem,vsz,rss,tty,stat,lstart,cmd
USER PID %CPU %MEM VSZ RSS TT STAT STARTED CMD
root 1 0.0 0.1 2800 1152 ? Ss Mon Dec 23 00:31:44 2013 /sbin/init
root 5151 0.3 0.1 4732 1980 pts/2 S Sat Mar 8 16:50:47 2014 bash
Para uma discussão sobre como as informações são publicadas no sistema de arquivos / proc, consulte
/unix/7870/how-to-check-how-long-a-process-has-been-running
(Na minha experiência no Linux, o registro de data e hora nos diretórios / proc / parece estar relacionado a um momento em que o diretório virtual foi acessado recentemente, em vez da hora de início dos processos:
# date; ls -ld /proc/1 /proc/$$
Sat Mar 8 17:14:21 EST 2014
dr-xr-xr-x 7 root root 0 2014-03-08 16:50 /proc/1
dr-xr-xr-x 7 root root 0 2014-03-08 16:51 /proc/5151
Observe que, neste caso, executei um comando "ps -p 1" por volta das 16:50, depois gerei um novo shell bash e, em seguida, executei o comando "ps -p 1 -p $$" dentro desse shell logo depois ... .)
ps -p <pid> -o lstart
? Parece que funciona, mas não sei por que não é a resposta óbvia imediata pelas muitas vezes em que essa pergunta surge.