2017-05-09 1 views
1

Mon but est de créer un script qui liste les 5 premiers processus les plus gourmands en mémoire avec leurs PIDs, Mem ifnos et Swap consommés. Partiellement, je l'ai fait. Mais maintenant, je voudrais le faire dans une sortie dans bash/awk. Awk ne voit pas le tableau bash passé. Voici mon approche:Comment passer un tableau de bash pour se tromper correctement

echo -e "PID\t%CPU\t%MEM\tMEM\tSWAP\tPROCESS" 
pids=($(ps aux | awk 'BEGIN { FS = "[ \t]+" } ; {pid[$11]+=$2}; {mem[$11]+=int($6/1024)}; {cpuper[$11]+=$3};{memper[$11]+=$4}; END {for (i in mem) {print " "pid[i]"\t",cpuper[i]"%\t",memper[i]"%\t",mem[i],i}}' | sort -k4nr | head -n 5|awk '{print $1}')) 

swap=() 
j=0 
for i in "${pids[@]}" 
do 
    : 
     if [ -f "/proc/$i/status" ] 
     then 
       swap[j]=$(awk '/Tgid|VmSwap|Name/{printf $2" "}END{ print ""}' < /proc/$i/status|awk '{print int($3/1024)}') 
     else 
       swap[j]=0 
     fi 
     j+=1 
done 

echo ${swap[@]} 

ps aux | awk -v sw="${swap[*]}" -v sep="[:]" 'BEGIN { n = split(sw, a, sep); FS = "[ \t]+" } ; {pid[$11]+=$2}; {mem[$11]+=int($6/1024)}; {cpuper[$11]+=$3};{memper[$11]+=$4}; END {for (i in mem) {print " "pid[i]"\t",cpuper[i]"%\t",memper[i]"%\t",mem[i]" MB\t",a[i]" MB",i}}' | sort -k4nr | head -n 5 

La sortie est

PID  %CPU %MEM MEM  SWAP PROCESS 
57551 6.3% 4.7% 9076 MB   MB java 
478839 1.2% 0%  657 MB MB /usr/sbin/httpd 
54418 1.6% 0.2% 524 MB MB /usr/lib/jvm/java-1.8.0-openjdk-1.8.0.121-0.b13.el7_3.x86_64/jre/bin/java 
63047 0.1% 0%  47 MB MB /usr/sbin/mysqld 
237334 0%  0%  22 MB MB sshd: 

Nous voyons qu'il ya un manque d'information de la table swap qui semble être dans var sw var a à fente.

+0

essayer 'échange [j] .... awk ... <(/ proc/$ i/statut | awk '{print int ($ 3/1024)}')) '. Bonne chance. – shellter

+0

Que voulez-vous dire qu'il ne voit pas le tableau bash passé? Quel résultat obtenez-vous? Qu'attendez-vous? – 123

+0

Je ne vois rien, l'empressement :) –

Répondre

1

Ici,

awk -v sw="${swap[*]}" -v sep="[:]" 'BEGIN { n = split(sw, a, sep); ... } 

Vous semblez essayer de diviser sw sur deux points. Mais "${swap[*]}" produira une chaîne avec les éléments du tableau swap joint au premier caractère de IFS, un espace par défaut.

Vous devez donc soit modifier IFS en deux points avant d'utiliser "${swap[*]}", soit définir le séparateur sur un espace du côté awk.

$ arr=(foo bar) ; IFS=: 
$ awk -v par="${arr[*]}" 'BEGIN{ n = split(par, a, ":"); 
    for (x in a) {printf "%s %s\n", x, a[x]}; exit }' 
1 foo 
2 bar 
+1

'awk -v par =" $ (IFS = :; echo "$ {arr [*]}") "..." pour éviter de modifier IFS pour shell actuel –

2

Pour plus d'informations ps avec certaines options peut donner le résultat

ps -eo pid,%cpu,%mem,vsz,sz,cmd --sort -vsz | head 

également

j=0 
j+=1 

Fonctionne uniquement avec typeset -i j