GNU/Linux >> Znalost Linux >  >> Linux

Jak zjistím celkové využití procesoru aplikace z /proc/pid/stat?

Příprava

Pro výpočet využití CPU pro konkrétní proces budete potřebovat následující:

  1. /proc/uptime
    • #1 doby provozuschopnosti systému (v sekundách)
  2. /proc/[PID]/stat
    • #14 utime - Čas CPU strávený v uživatelském kódu, měřený v taktech
    • #15 stime - Čas CPU strávený v kódu jádra, měřený v taktech
    • #16 cutime - Dětské na počkání Čas CPU strávený v uživatelském kódu (v tikání hodin )
    • #17 cstime - Dětské na počkání Čas CPU strávený v kódu jádra (v tikání hodin )
    • #22 starttime – Čas, kdy proces začal, měřený v tikání hodin
  3. Hertz (počet taktů za sekundu) vašeho systému.
    • Ve většině případů getconf CLK_TCK lze použít k vrácení počtu tiků hodin.
    • sysconf(_SC_CLK_TCK) Volání funkce C lze také použít k vrácení hodnoty hertz.

Výpočet

Nejprve určíme celkový čas strávený procesem:

total_time = utime + stime

Musíme se také rozhodnout, zda chceme zahrnout čas z dětských procesů. Pokud ano, pak tyto hodnoty přidáme do total_time :

total_time = total_time + cutime + cstime

Dále získáme celkový uplynulý čas v sekundách od začátku procesu:

seconds = uptime - (starttime / Hertz)

Nakonec vypočítáme procento využití CPU:

cpu_usage = 100 * ((total_time / Hertz) / seconds)

Viz také

Top a ps nezobrazují stejný výsledek CPU

Jak získat celkové využití procesoru v Linuxu (c++)

Výpočet využití procesoru procesem v Linuxu


Pokud potřebujete vypočítat, kolik cpu % spotřeboval proces za posledních 10 sekund

  1. gettotal_time (13+14) za okamžiky => t1starttime(22) za okamžiky => s1

--zpoždění 10 sekund

celkový_čas (13+14) za okamžiky => t2starttime(22) za okamžiky => s2

t2-t1 *100 / s2 – s1 by nedal % ??


Ano, dá se to tak říct. Tyto hodnoty můžete převést na sekundy pomocí vzorce:

      sec = jiffies / HZ ; here - HZ = number of ticks per second

Hodnota HZ je konfigurovatelná – provádí se v době konfigurace jádra.


Zde je moje jednoduché řešení napsané v BASH . Jedná se o linux/unix systémový monitor a správce procesů prostřednictvím procfs, jako je "top “ nebo „ps ". Existují dvě verze jednoduchá monochromatická (rychlá) a barevná verze (trochu pomalá, ale užitečná zejména pro sledování stavu procesů). Udělal jsem třídění podle využití procesoru.

https://github.com/AraKhachatryan/top

  • doba provozu , čas , cutime , cstime , čas zahájení používá se pro získání využití procesoru a získané z /proc/[pid]/stat soubor.

  • stát , ppid , priorita , pěkné , počet_vláknů parametry získané také z /proc/[pid]/stat soubor.

  • rezident a data_and_stack parametry používané pro získání využití paměti a získané z /proc/[pid]/statm soubor.


    function my_ps
    {
        pid_array=`ls /proc | grep -E '^[0-9]+$'`
        clock_ticks=$(getconf CLK_TCK)
        total_memory=$( grep -Po '(?<=MemTotal:\s{8})(\d+)' /proc/meminfo )

        cat /dev/null > .data.ps

        for pid in $pid_array
        do
            if [ -r /proc/$pid/stat ]
            then
                stat_array=( `sed -E 's/(\([^\s)]+)\s([^)]+\))/\1_\2/g' /proc/$pid/stat` )
                uptime_array=( `cat /proc/uptime` )
                statm_array=( `cat /proc/$pid/statm` )
                comm=( `grep -Po '^[^\s\/]+' /proc/$pid/comm` )
                user_id=$( grep -Po '(?<=Uid:\s)(\d+)' /proc/$pid/status )

                user=$( id -nu $user_id )
                uptime=${uptime_array[0]}

                state=${stat_array[2]}
                ppid=${stat_array[3]}
                priority=${stat_array[17]}
                nice=${stat_array[18]}

                utime=${stat_array[13]}
                stime=${stat_array[14]}
                cutime=${stat_array[15]}
                cstime=${stat_array[16]}
                num_threads=${stat_array[19]}
                starttime=${stat_array[21]}

                total_time=$(( $utime + $stime ))
                #add $cstime - CPU time spent in user and kernel code ( can olso add $cutime - CPU time spent in user code )
                total_time=$(( $total_time + $cstime ))
                seconds=$( awk 'BEGIN {print ( '$uptime' - ('$starttime' / '$clock_ticks') )}' )
                cpu_usage=$( awk 'BEGIN {print ( 100 * (('$total_time' / '$clock_ticks') / '$seconds') )}' )

                resident=${statm_array[1]}
                data_and_stack=${statm_array[5]}
                memory_usage=$( awk 'BEGIN {print( (('$resident' + '$data_and_stack' ) * 100) / '$total_memory'  )}' )

                printf "%-6d %-6d %-10s %-4d %-5d %-4s %-4u %-7.2f %-7.2f %-18s\n" $pid $ppid $user $priority $nice $state $num_threads $memory_usage $cpu_usage $comm >> .data.ps

            fi
        done

        clear
        printf "\e[30;107m%-6s %-6s %-10s %-4s %-3s %-6s %-4s %-7s %-7s %-18s\e[0m\n" "PID" "PPID" "USER" "PR" "NI" "STATE" "THR" "%MEM" "%CPU" "COMMAND"
        sort -nr -k9 .data.ps | head -$1
        read_options
    }


Linux
  1. Jak Linux zpracovává více po sobě jdoucích oddělovačů cest (/home////username///soubor)?

  2. Jak omezit využití CPU ve fondu aplikací ve službě IIS

  3. Jak získám cestu k procesu v Unixu / Linuxu

  1. Jak vypočítat využití CPU procesu pomocí PID v Linuxu z C?

  2. Jak získat celkové využití CPU v Linuxu pomocí C++

  3. Jak zjistit využití CPU

  1. Jak získat ID procesu pro ukončení procesu nohup?

  2. Jak zjistit, ze které složky běží proces?

  3. Jak získám svou IP adresu z příkazového řádku?