awk工作流程是这样的:读入有'\n'换行符分割的一条记录,然后将记录按指定的域分隔符划分域,填充域,$0则表示所有域,$1表示第一个域,$n表示第n个域。默认域分隔符是"空白键" 或 "[tab]键",所以$1表示登录用户,$3表示登录用户ip,以此类推。
awk应用实例:
(1)查找指定进程PID,并kill进程。
# ps | awk '{ if($4 == "/usr/plugins/bin/centerd"){pid=$1; print pid; system("kill -9 "pid)}}'
(2)格式话显示系统运行时间。
cat /proc/uptime| awk -F. '{run_days=$1 / 86400;run_hour=($1 % 86400)/3600;run_minute=($1 % 3600)/60;run_second=$1 % 60;printf("%d Days %d Hours %d Minutes %d Seconds",run_days,run_hour,run_minute,run_second)}'
(3)指定分割符-F ':'来划分域。
cat /etc/passwd | awk -F ':' '{print $1}'
(4)指定分割符-F ':'来划分域,且包含指定字符串。
#awk -F: '/root/' /etc/passwd
(5)取文件总的大小。
ls -l |awk 'BEGIN {size=0;} {size=size+$5;} END{print "[end]size is ", size/1024/1024,"M"}'(6)求用户个数。
awk -F ':' 'BEGIN {count=0;} {name[count] = $1;count++;}; END{for (i = 0; i < NR; i++) print i, name[i]}' /etc/passwd