Query on awk


 
Thread Tools Search this Thread
Top Forums UNIX for Beginners Questions & Answers Query on awk
# 1  
Old 03-30-2018
Query on awk

Hello,


I am trying to find the RAM usage for one of the process from a group of servers.

xx-Process name

The command i used by logging to the individual server is as below

Code:
ps aux | grep xx | awk '{sum=sum+$6}; END {print sum/1024 " MB"}'

And the result is
Code:
0.824219 MB

This seems to be correct as per the ps command on the server.

Code:
ps aux | grep xx
16777248 26166  0.0  0.0 103324   844 pts/0    R+   10:20   0:00 grep xx


Now i implemented via shell script and is giving me a different result.


Code:
RAMUsage=$(ssh $i "ps aux | grep xx| awk '{sum+=\$6};END {print sum/1024" MB"}'")
echo "the ramusage is " $RAMUsage

the ramusage is 2.1875

Please help me where it went wrong.

Last edited by RudiC; 03-30-2018 at 06:48 PM..
# 2  
Old 03-30-2018
Code:
RAMUsage=$(ssh $i "ps aux | grep xx| awk '{sum+=\$6};END {print sum/1024" MB"}'")

what's the \ for?
also:
Code:
ps aux | grep xx
16777248 26166  0.0  0.0 103324   844 pts/0    R+   10:20   0:00 grep xx

this is 'grep' from the 'ps' itself - not the process 'xx' you're looking for.
This User Gave Thanks to vgersh99 For This Post:
# 3  
Old 03-30-2018
I put the backslash to escape the dollar sign.

---------- Post updated at 11:57 AM ---------- Previous update was at 09:59 AM ----------



I understood by comparing with ps aux | grep xx is wrong .

Further to this gave ps aux command in the terminal and found the process am looking has occupied around 218 MB.

Code:
USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root      2282  0.2  1.3 2411400 218888 ?      Sl   Mar14  54:45 /opt/xx/desktop/xx

But the shell script was giving 2.18359. May be the formula used in script is wrong.Please advise.




Moderator's Comments:
Mod Comment Please use CODE tags CORRECTLY as required by forum rules!
Don't tag your entire text / post!

Last edited by RudiC; 03-30-2018 at 06:46 PM.. Reason: Changed (moved) CODE tags.
# 4  
Old 03-30-2018
Instead of:
Code:
ps aux | grep xx

try:
Code:
ps aux | grep '[x]x'

To ensure the grep process itself isn't one of the processes being matched.
This User Gave Thanks to Scrutinizer For This Post:
# 5  
Old 03-31-2018
Quote:
Originally Posted by nextStep
I am trying to find the RAM usage for one of the process from a group of servers.
This is less trivial than it seems to be. A process can have several types of memory allocated:

1) real memory
This is real RAM the process uses.

2) virtual memory
This is real memory as above plus allocated but swapped out memory. This actually is what the vsz metric in the ps output shows.

3) shared memory segments
Sometimes several processes use some memory segment collectively. I.e. database software Oracle, DB/2) makes extensive use of this feature. Use the ipcs command to find out if the process owns shared memory segments.

I hope this helps.

bakunin
This User Gave Thanks to bakunin For This Post:
Login or Register to Ask a Question

Previous Thread | Next Thread

10 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

awk query

Hi, I have a sample file in the following format. 000013560240|000013560240|001|P|155|99396|0||SS00325665| 000013560240|000013560240|002|P|17|99000|0||SS00325665| 000013560240|000013560240|002|F|-17|99000|0|R|SS00325665| 000013560240|000013560240|003|P|20|82270|0||SS00325665|... (3 Replies)
Discussion started by: nua7
3 Replies

2. UNIX for Dummies Questions & Answers

Awk - query about arrays

Hello again, I have example config file with two arrays: tab1="name1 surname1" tab1="name2 surname2" tab1="name3 surname3" tab2="First" tab2="Second"and csv file: "aaaaa","surname1","name1","ddddd,eeeee","ffffff","ggggg","3","2012/02/22 12:25:21","2012/02/22... (7 Replies)
Discussion started by: haczyk
7 Replies

3. Shell Programming and Scripting

awk query

Dear all, I find a shell script about awk command in the forum regarding "Find and replace duplicate column values in a row" In this thread, there is a command line as shown below to replace duplicate awk -F, '{for (i=1;i<=NF;i++){if (v++){b=$i;$i=""}};print $0} END { print "dups are"... (1 Reply)
Discussion started by: eldonlck
1 Replies

4. Shell Programming and Scripting

AWK Query

i have a log file where in i have 3 columns a 11 test1 b 22 test2 in a script, i want to pass first column as an argument to awk so that i can get the second and third column respectively Example : If i pass ($1 i.e 'a' to an awk, the result should be 11 test1) i tried different awk... (2 Replies)
Discussion started by: vkca
2 Replies

5. Shell Programming and Scripting

sed or awk query

I have a set of multiple files out of which one i am showing below : A0120110124102329 BED. B01***DETALLADA 43984 The BO1 is the starting pattern of the second line. In the 2nd line in position 30,31,32 i need to replace 111, instead of 3... (2 Replies)
Discussion started by: dazdseg
2 Replies

6. Solaris

awk output query

Hi Everyone, When i issue command like ls -l | awk '/udtts/ {print $9}' =============================== I am getting output as udttsGEHLNAR.6864 udttsGEHLNAR.7921 udttsNARALAX.15415 udttsNARALAX.18016 But I want output after dot i.e like 6864 7921 15415 18016 (3 Replies)
Discussion started by: gehlnar
3 Replies

7. Shell Programming and Scripting

Awk Gsub Query

Hi, Can some one please explain the following line please throw some light on the ones marked in red awk '{print $9}' ${FTP_LOG} | awk -v start=${START_DATE} 'BEGIN { FS = "." } { old_line1=$0; gsub(/\-/,""); if ( $3 >= start ) print old_line1 }' | awk -v end=${END_DATE} 'BEGIN { FS="." } {... (3 Replies)
Discussion started by: crosairs
3 Replies

8. UNIX for Dummies Questions & Answers

some query in awk

Hi , I want to assign a value to variable which will have size of the file that is we have following files for eg: ls -ltr -rw-rw-r-- 1 dsadmin dstage 34 Oct 29 12:14 some.txt -rw-rw-r-- 1 dsadmin dstage 0 Oct 29 14:52 eg.txt -rwxrwxr-x 1 dsadmin dstage 1453 Oct... (2 Replies)
Discussion started by: Amey Joshi
2 Replies

9. UNIX for Dummies Questions & Answers

Query in awk

file "batsmen" contains Bradman;Australia;52;6996 Gavaskar;India;124;10122 Sobers;West;Indies;93;8032 Border;Australia;109;8075 Miandad;Pakistan;97;7121 Gower;England;94;7023 Boycott;England;108;8114 My awk script contains awk '{FS=";"} {len=length($1)}; ... (1 Reply)
Discussion started by: raguramtgr
1 Replies

10. UNIX for Dummies Questions & Answers

Query In awk

Is it possible to have a pattern as RS in awk. For Example pl. go through the statement; " Account Serial Number: 88888888 TT00X000000XXXXXXXXXXXXX SS00X000000XX.000,XXXXXXXXXXXXXXXXXX0000XXXXXXX0000000000 WW00X0000000XX000000000000MMMMMMM MMMMMMM0000AA11110000000000000000000000000... (1 Reply)
Discussion started by: raguramtgr
1 Replies
Login or Register to Ask a Question