Analisando a saída de “uptime” com o bash

2

Eu gostaria de salvar a saída do comando uptime em um arquivo csv em um script Bash. Como o comando uptime tem formatos de saída diferentes com base no tempo desde a última reinicialização, criei uma solução bem pesada baseada em case , mas certamente há uma maneira mais elegante de fazer isso.

saída de tempo de atividade:

 8:58AM  up 15:12, 1 user, load averages: 0.01, 0.02, 0.00

resultado desejado:

15:12,1 user,0.00 0.02 0.00,

código atual:

case "'uptime | wc -w | awk '{print $1}''" in
#Count the number of words in the uptime output

10)
    #e.g.:  8:16PM  up  2:30, 1 user, load averages: 0.09, 0.05, 0.02
    echo -n 'uptime | awk '{ print $3 }' | awk '{gsub ( ",","" ) ; print $0 }''","'uptime | awk '{ print $4,$5 }' | awk '{gsub ( ",","" ) ; print $0 }''","'uptime | awk '{ print $8,$9,$10 }' | awk '{gsub ( ",","" ) ; print $0 }''","
    ;;

12)
    #e.g.: 1:41pm  up 105 days, 21:46,  2 users,  load average: 0.28, 0.28, 0.27
    echo -n 'uptime | awk '{ print $3,$4,$5 }' | awk '{gsub ( ",","" ) ; print $0 }''","'uptime | awk '{ print $6,$7 }' | awk '{gsub ( ",","" ) ; print $0 }''","'uptime | awk '{ print $10,$11,$12 }' | awk '{gsub ( ",","" ) ; print $0 }''","
    ;;

13)
    #e.g.: 12:55pm  up 105 days, 21 hrs,  2 users,  load average: 0.26, 0.26, 0.26
    echo -n 'uptime | awk '{ print $3,$4,$5,$6 }' | awk '{gsub ( ",","" ) ; print $0 }''","'uptime | awk '{ print $7,$8 }' | awk '{gsub ( ",","" ) ; print $0 }''","'uptime | awk '{ print $11,$12,$13 }' | awk '{gsub ( ",","" ) ; print $0 }''","
    ;;
esac
    
por Keek 23.08.2014 / 08:57

3 respostas

7

Sugiro que você vá diretamente para a fonte em vez de analisar a saída do tempo de atividade (1).

  • O tempo de atividade está em /proc/uptime
  • A média de carga está em /proc/loadavg
  • O número de usuários está um pouco mais envolvido, consulte Wikipedia: utmp , mas o w(1) ou who(1) comandos irão ajudá-lo.

O seguinte não é exatamente o resultado desejado que você pediu, mas você tem a ideia:

$ echo $(cut -d ' ' -f 1 </proc/uptime),$(w -h | wc -l),$(cut -d ' ' -f 1-3 </proc/loadavg),
8545883.49,4,0.00 0.01 0.05

Isso significa 8.55e6 segundos (quase 99 dias), 4 usuários, média de carregamento.

    
por 23.08.2014 / 09:48
1

O código a seguir serve para todos os tipos de saídas de tempo de atividade. Espero que isso ajude você,

uptime='uptime'
upt='echo $uptime | grep -ohe 'up .*user*' | awk '{gsub ( "user*","" ); print $0 }' | sed 's/,//g' | sed -r 's/(\S+\s+){1}//' | awk '{$NF=""}1''
usrs='echo $uptime | grep -ohe '[0-9.*] user[s,]'| sed 's/,//g''
ldt='echo $uptime | grep -ohe 'load average[s:][: ].*' | sed 's/,//g' | awk '{ print $3" "$4" "$5"," }''
echo $upt, $usrs, $ldt
    
por 23.08.2014 / 10:37
0

FWIW:

$ echo -e "\n$(uptime)\n" ; uptime \
| sed -nre 's/.+up +([\:0-9]+), +([^ ] [^,]+), +.*: +([^ ]+), +([^ ]+), +([^ ]+)$/, ,   /p'

 12:58:47 up  5:53,  2 users,  load average: 0,21, 0,09, 0,10

5:53, 2 users, 0,21 0,09 0,10

Observe que o separador decimal para números depende das configurações de localidade.

    
por 23.08.2014 / 13:16