所有操作对development.yaml
[root@kube-node3 ~]# cat development.yaml
apiVersion: v1
kind: Namespace
metadata:
name: development
labels:
name: development
打印硬盘设备名称,默认以空格分割
df -h | awk '{print $1}'
以冒号作为分割符
awk -F '[:]' '{print $1}' development.yaml 或者 cat /etc/passwd | awk -F: '{print $NF}'
以空格作为分隔符
awk -F ' ' '{print $1}' development.yaml 或者 awk '{print $1}' development.yaml
以制表符作为分隔符
awk -F '[ ]' '{print $1}' development.yaml
以分号作为分隔符
awk -F '[;]' '{print $1}' development.yaml
以冒号为分割,打印第一列,然后追加到/tmp/log
awk -F: '{print $1>> "/tmp/awk.log"}' development.yaml
打印第三行到第五行,NR表示行
awk 'NR==3,NR==5 {print}' development.yaml
打印文件所有域
awk 'NR==3,NR==5 {print $0}' development.yaml
打印第三行到第五行的第一列和最后一列
awk -F: 'NR==3,NR==5 {print $1,$NF}' /etc/passwd
打印最后一列
cat /etc/passwd | awk -F ':' '{print $NF}' 或者 cat /etc/passwd | awk -F: '{print $NF}'
打印字符串长度大于10的行号
awk 'length($0)>10 {print NR}' development.yaml
引用shell变量,使用-v或者双引号+单引号
awk -v STR=hello '{print STR,$NF}' development.yaml
以冒号为分隔符,打印第一列同时打印前5行
awk -F: 'NR>=1 && NR<=5 {print $1}' development.yaml
cat /etc/passwd | head -5 | awk -F: '{print $1}' development.yaml
打印第一列和所有行号
awk -F: '{print NR,$1}' development.yaml
NR除以2等于0则跳过该行继续执行下一行,打印出来
awk -F: 'NR%2==0{next} {print NR,$1}' development.yaml
awk添加自定义字符
ifconfig ens33 | grep broad | awk '{print "ip_"$2}'
awk格式化输出password内容,printf打印字符串,% 格式化输出分隔符,s表示字符串类型,-12 表示12个字符,-6表示6个字符
awk -F: '{printf "% - 12s % - 6s % -8s
", $1,$2,$NF}' /etc/passwd
awk OFS输出格式化
netstat -an | awk '$6 ~ /LISTENING/$$NR>=1&&NR<=10 {print $NR, $4, $5, $6}' 没做成
awk和if组合使用
echo 3 2 1 | awk '{ if(($1>$2 && $1>$3)) {print $2} else {print $3}}'
awk与数组结合统计passwod文件用户数
awk -F":" '{print $7}' /etc/passwd | uniq -c
awk分析nginx的日志状态码 404 503 等次数 统计次数大于20的
awk '{if ($9~/502|499|500|503|404/) print $1,$9}' access.log|sort|uniq –c|sort –nr | awk '{if($1>20) print $2}'
awk统计服务器连接状态数
netstat -an | awk '/tcp/{s[$NF]++}END{for(i in s) print s[i] i}'
netstat -an | awk '/tcp/{print $NF}' | sort | uniq
grep -c "404" access.log 统计nginx日志中404的行数
grep -i "404" access.log 不区分大小写 查找404所在的行
grep -n "404" access.log 打印404的行以及行号
grep -v "404" access.log 不打印404所在的行
grep "api[Vv]" development.yaml 以字符api开头,接V或v 的行
grep "^[^api]" development.yaml 显示输出不是api的行
grep "[Aa]p" development.yaml 匹配 A或a开头,后接p的行
awk提取信息并保持到文件
cat /etc/passwd | awk -F: '{ print $1 }' | tail -10 > output.txt && cat output.txt
为文件的每一行后面添加特定字符串
awk '{print $0" &&"}'
打印第一列到最后一列,默认以空格分割
awk '{for (i=1;i<=NF;i++)printf("%s ", $i);print ""}'
打印第三列到最后一列,默认以空格分割
awk '{for (i=3;i<=NF;i++)printf("%s ", $i);print ""}'
打印第一列至倒数第二列,默认以空格分割
awk '{for (i=1;i<=NF-1;i++)printf("%s ", $i);print ""}'
提取yum的软件包个数
yum repolist | sed -n '/repolist/p' | awk -F ':' '{print $2}'