Monitora o processo único para logfile perodicly

2

Com base em this pergunta, gostaria de registrar o desempenho de um processo específico, com uma frequência de um segundo, em um arquivo de log csv (valor separado por vírgulas).

Algo como:

timestamp(unix),cpu_activity(%),mem_usage(B),network_activity(B)
1355407327,24.6,7451518,345
1355407328,27.6,7451535,12
1355407329,31.6,7451789,467
...
    
por Theodor 13.12.2012 / 15:08

2 respostas

1

eu tentei obter rx_bytes e tx_bytes, mas sem sorte, outras coisas estão funcionando .. Então você pode usar abaixo script para o mesmo

#!/bin/bash

# /sys/class/net/eth0/statistics/rx_bytes
# /sys/class/net/eth0/statistics/tx_bytes

Process="$1"

[[ -z $2 ]] && InterVal=1 || InterVal=$2

show_help() {
cat <<_EOF
Usage :
        $0  <ProcessName>  <Interval (Default 1s)>
_EOF
}

Show_Process_Stats() {
pgrep "${Process}" >/dev/null 2>&1 || { echo "Error: Process($1) it not Running.."; exit 1;};
while :
do
    # timestamp(unix),cpu_activity(%),mem_usage(B),network_activity(B)
    timestamp=$(date +%s)
    read cpu_activty mem_usage < <( ps --no-headers -o %cpu,rssize  -C "${Process}" )   
    echo "${timestamp}","${cpu_activty}","${mem_usage}"
    sleep $InterVal
done
}


Main() {
case $1 in
        ""|-h|--help)
                      show_help
                      ;;
                     *)
                      Show_Process_Stats
                      ;;
esac                      
}


Main $*
    
por 14.12.2012 / 14:04
0

qual cálculo deve ser feito com rx e tx? Eu tentei abaixo das coisas, por favor, verifique e deixe-nos saber o que você quer realizar.

#!/bin/bash

# /sys/class/net/eth0/statistics/rx_bytes
# /sys/class/net/eth0/statistics/tx_bytes

Process="$1"

[[ -z $2 ]] && InterVal=1 || InterVal=$2

show_help() {
cat <<_EOF
Usage :
                $0  <ProcessName>  <Interval (Default 1s)>
_EOF
}

Show_Process_Stats() {
pgrep "${Process}" >/dev/null 2>&1 || { echo "Error: Process($1) it not Running.."; exit 1;};
old_rx=0
old_tx=0
echo "timestamp,cpu_activty,mem_usage,rx_bytes,tx_bytes"
while :
do
        # timestamp(unix),cpu_activity(%),mem_usage(B),network_activity(B)
        timestamp=$(date +%s)
        raw_rx_bytes=$(< /sys/class/net/eth0/statistics/rx_bytes )
        raw_tx_bytes=$(< /sys/class/net/eth0/statistics/tx_bytes )
        rx_bytes=$(( $raw_rx_bytes - $old_rx ))
        tx_bytes=$(( $raw_tx_bytes - $old_tx ))
        read cpu_activty mem_usage < <( ps --no-headers -o %cpu,rssize  -C "${Process}" )
        echo "${timestamp}","${cpu_activty}","${mem_usage}","${rx_bytes}","${tx_bytes}"
        old_rx=${raw_rx_bytes}
        old_tx=${raw_tx_bytes}
        sleep $InterVal
done
}


Main() {
case $1 in
                ""|-h|--help)
                                          show_help
                                          ;;
                                         *)
                                          Show_Process_Stats
                                          ;;
esac
}


Main $*
    
por 15.12.2012 / 12:40