1、获取根分区剩余大小
查看剩余多大内存空间
[root@William test]# df -h /
文件系统 容量 已用 可用 已用% 挂载点
/dev/mapper/rhel-root 28G 4.8G 24G 18% /
#使用awk命令获取剩余大小
[root@William test]# df -h / | awk 'NR==2 {print $4}'
24G
2、获取当前机器ip地址
[root@William test]# hostname -I | awk '{print $1}'
192.168.76.129
3、统计出apache的access.log中访问量最多的5个IP
[root@William test]# awk '{ip[$1]++} END{ for (a in ip ) print a,ip[a] }' /var/log/httpd/access_log
4、打印/etc/passwd中UID大于500的用户名和uid
[root@William test]# awk -F: '$3>500{print $1,$3}' /etc/passwd
nobody 65534
systemd-coredump 999
polkitd 998
colord 997
clevis 996
sssd 995
libstoragemgmt 994
setroubleshoot 993
pipewire 992
geoclue 991
flatpak 990
cockpit-ws 989
cockpit-wsinstance 988
gnome-initial-setup 987
chrony 986
dnsmasq 985
systemd-oom 978
william 1000
xiaohei 1003
nginx 977
5、/etc/passwd 中匹配包含root或net或ucp的任意行
[root@William test]# awk -F: '/root|net|ucp/ {print $0}' /etc/passwd
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin
6、处理以下文件内容,将域名取出并根据域名进行计数排序处理(百度搜狐面试题)
test.txt
http://www.baidu.com/index.html
http://www.baidu.com/1.html
http://post.baidu.com/index.html
http://mp3.baidu.com/index.html
http://www.baidu.com/3.html
http://post.baidu.com/2.html
[root@William test]# awk -F/ '{name[$3]++} END{for (i in name) print i ,name[i]} ' test.txt
1
post.baidu.com 2
www.baidu.com 3
mp3.baidu.com 1
7、请打印出/etc/passwd 第一个域,并且在第一个域所有的内容前面加上“用户帐号:”
[root@William test]# awk -F: '{print "用户账号:",$1}' /etc/passwd
用户账号: root
用户账号: bin
用户账号: daemon
用户账号: adm
用户账号: lp
用户账号: sync
用户账号: shutdown
用户账号: halt
用户账号: mail
用户账号: operator
用户账号: games
用户账号: ftp
用户账号: nobody
用户账号: systemd-coredump
用户账号: dbus
用户账号: polkitd
用户账号: tss
用户账号: colord
用户账号: clevis
用户账号: rtkit
用户账号: sssd
用户账号: libstoragemgmt
用户账号: setroubleshoot
用户账号: pipewire
用户账号: avahi
用户账号: geoclue
用户账号: flatpak
用户账号: gdm
用户账号: cockpit-ws
用户账号: cockpit-wsinstance
用户账号: gnome-initial-setup
用户账号: sshd
用户账号: chrony
用户账号: dnsmasq
用户账号: tcpdump
用户账号: systemd-oom
用户账号: william
用户账号: xiaohei
用户账号: apache
用户账号: nginx
用户账号: mysql
用户账号: rpc
用户账号: rpcuser
用户账号: named
用户账号: postfix
8、请打印出/etc/passwd 第三个域和第四个域
[root@William test]# awk -F: 'NR<=10 {print $3,$4}' /etc/passwd
0 0
1 1
2 2
3 4
4 7
5 0
6 0
7 0
8 12
11 0
9、请打印第一域,并且打印头部信息为:这个是系统用户,打印尾部信息为:“================”
[root@William test]# awk -F: 'BEGIN{print "这个是系统账号"} {print $1} END{print "================"} ' /etc/passwd
这个是系统账号
root
bin
daemon
adm
lp
sync
shutdown
halt
mail
operator
games
ftp
nobody
systemd-coredump
dbus
polkitd
tss
colord
clevis
rtkit
sssd
libstoragemgmt
setroubleshoot
pipewire
avahi
geoclue
flatpak
gdm
cockpit-ws
cockpit-wsinstance
gnome-initial-setup
sshd
chrony
dnsmasq
tcpdump
systemd-oom
william
xiaohei
apache
nginx
mysql
rpc
rpcuser
named
postfix
================
10、请打印出第一域匹配daemon的信息.
[root@William test]# awk -F: '$1~/daemon/ {print $0}' /etc/passwd
daemon:x:2:2:daemon:/sbin:/sbin/nologin
11、请将/etc/passwd 中的root替换成gongda,记住是临时替换输出屏幕看到效果即可.
[root@William test]# sed -n 's/root/gongda/p' /etc/passwd
gongda:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/gongda:/sbin/nologin
12、请匹配passwd最后一段域bash结尾的信息,有多少条
#未统计前符合条件的信息内容
[root@William test]# awk -F: '$NF~/bash$/ {print }' /etc/passwd
root:x:0:0:root:/root:/bin/bash
william:x:1000:1000:william:/home/william:/bin/bash
xiaohei:x:1003:1006::/home/xiaohei:/bin/bash
#统计后
[root@William test]# awk -F: '$NF~/bash$/ {sum++} END{print sum}' /etc/passwd
3
[root@William test]# awk -F: '$NF~/bash$/ {print }' /etc/passwd | wc -l
3
13、请同时匹配passwd文件中,带mail或bash的关键字的信息
[root@William test]# awk '/mail|bash/ {print}' /etc/passwd
root:x:0:0:root:/root:/bin/bash
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
william:x:1000:1000:william:/home/william:/bin/bash
xiaohei:x:1003:1006::/home/xiaohei:/bin/bash
[root@William test]# grep -E "bash|mail" /etc/passwd
root:x:0:0:root:/root:/bin/bash
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
william:x:1000:1000:william:/home/william:/bin/bash
xiaohei:x:1003:1006::/home/xiaohei:/bin/bash