Получение времени безотказной работы SunOS UNIX в считанные секунды - PullRequest
6 голосов
/ 02 ноября 2009

Как определить время безотказной работы на SunOS UNIX только в секундах?

В Linux я мог просто cat / proc / uptime и принять первый аргумент:

cat /proc/uptime | awk '{print $1}'

Я пытаюсь сделать то же самое в SunOS UNIX, но нет / proc / uptime. Существует команда uptime, которая представляет следующий вывод:

$ uptime
12:13pm  up 227 day(s), 15:14,  1 user,  load average: 0.05, 0.05, 0.05

На самом деле я не хочу писать код для преобразования даты в секунды, и я уверен, что кто-то уже имел это требование раньше, но я не смог ничего найти в Интернете.

Может кто-нибудь сказать мне, как получить время безотказной работы в считанные секунды?

ТИА

Ответы [ 9 ]

5 голосов
/ 02 ноября 2009

Если вы не против собрать небольшую программу на C, вы можете использовать

#include <utmpx.h>
int main ( )
{
  int nBootTime = 0;
  int nCurrentTime = time ( NULL );   
  struct utmpx * ent;

  while ( ( ent = getutxent ( ) ) ) {
    if ( !strcmp ( "system boot", ent->ut_line ) ) {
      nBootTime = ent->ut_tv.tv_sec;
    }      
  }   
  printf ( "System was booted %d seconds ago\n", nCurrentTime - nBootTime );    
}

Источник: http://xaxxon.slackworks.com/rsapi/

3 голосов
/ 26 марта 2010

Может быть довольно неортодоксальный метод (выручил меня, так как kstat дал некоторые извращенные результаты, которые не проходили через cron:

RunTime=""
RunTime=`kstat -p unix:0:system_misc:snaptime | awk '{print $2}' | cut -d "." -f1`
echo $RunTime
RunTime=`expr $RunTime / 1`
RunDays=`expr $RunTime / 86400`
RunHours=`expr $RunTime % 86400 / 3600`
RunMinutes=`expr $RunTime % 3600 / 60`
RunSeconds=`expr $RunTime % 60`

Надеюсь, это поможет вам - Хороший побочный эффект: у вас есть биты времени, доступные для расчетов.

2 голосов
/ 04 сентября 2014

Это смесь некоторых ответов, которые уже даны. Выводит время работы в секундах только с двумя командами. Протестировано на Solaris 9 и 10.

kstat -p unix:0:system_misc:boot_time | nawk '{printf "%d\n", srand()-$2}'
1 голос
/ 03 ноября 2009

Спасибо Андре за решение, которое обеспечит секунды. Если кто-то ищет ответ без компиляции, этот скрипт можно использовать. Обратите внимание, поскольку команда «uptime» не предоставляет секунд, решение имеет значение от 0 до 59 секунд при запуске:

days=`uptime | awk '{print \$3}'`
hrs=`uptime | awk '{print \$5}' | sed 's/[:,]/ /g' | awk '{print \$1}'`
mins=`uptime | awk '{print \$5}' | sed 's/[:,]/ /g' | awk '{print \$2}'`
uptimesecs=$(($mins*60))
uptimesecs=$(($hrs*3600+$uptimesecs))
uptimesecs=$(($days*86400+$uptimesecs))
echo "$uptimesecs seconds uptime (to within 59 secs)."

Надеюсь, это кому-нибудь пригодится: -)

0 голосов
/ 05 октября 2016

Используйте ферму в команде date, чтобы получить время эпохи и вычесть время загрузки, полученное из kstat.

expr `truss date 2>&1 |grep '^time()' |tr -cd "[0-9]"` - `kstat -p unix:0:system_misc:boot_time|cut -f2`
0 голосов
/ 06 мая 2013

Используйте ферму для извлечения времени создания каталога / proc / 0. (Должен запускаться от имени пользователя root.)

#!/bin/bash

btime=$(truss -v lstat -t lstat ls -ld /proc/0 2>&1 | awk '/ct = /{print $9}' | cut -d. -f1)
0 голосов
/ 20 ноября 2009

Вы можете использовать kstat для поиска времени работы системы.

$kstat -p unix:0:system_misc:boot_time

Это вернет значения в формате Unix. Ниже приведен код, который был очень полезен для меня, чтобы получить значения в сек.

#!/usr/bin/perl -w
use strict;

my $KSTAT = '/usr/bin/kstat -p';
my $STATISTIC = 'unix:0:system_misc:boot_time';

my $uptime = `$KSTAT $STATISTIC | awk '{print \$2}'`;
sprintf "%0.2f\n", (time() - $uptime);
0 голосов
/ 16 ноября 2009

Вот сценарий оболочки, который обеспечивает второе разрешение. Обратите внимание, что вам нужно быть пользователем root для его работы.

#!/bin/ksh
now=$(nawk 'BEGIN{print srand()}')
i=$(apptrace -fv 'getutxent' uptime 2>&1 | grep time_t | tail +2 | head -1 | nawk '{print $3}')
ut=$(bc <<-%EOF%
ibase=16
$(print $i | sed 's/0x//' | tr "[a-f]" "[A-F]")
%EOF%
)
s=$((now-ut))
h=$((s/3600))
s=$((s-(h*3600)))
m=$((s/60))
s=$((s-(m*60)))
d=$((h/24))
h=$((h-(d*24)))
printf "%d seconds - %d day(s) %02d:%02d:%02d\n" $((now - ut)) $d $h $m $s
0 голосов
/ 11 ноября 2009

Perl: CPAN обеспечивает unix :: uptime - однако в настоящее время он не совместим с SunOS, но может быть в будущем.

...