1.grep
grep = [Globally search a Regular Expression and Print]
grep -E = egrep
1.grep 格式##
grep 匹配条件 处理文件 | |
---|---|
grep root passwd | 过滤root关键字 |
grep -i root passwd | 后略大小写 |
grep -E “<root” passwd | root字符之前不能有字符 |
grep -E “root>” passwd | root字符之后不能有字符 |
grep -数字 | 显示过滤行以及上面几行和下面几行 |
grep -n | 显示匹配的行所在行号 |
grep -A | 显示过滤行以及下面几行 |
grep -B | 显示过滤行以及上面几行 |
grep -v | 反向过滤 |
grep字符数量匹配规则 | |
---|---|
^westos | 以westos开有 |
westos$ | 以westos结尾 |
w…s | w开头s结尾中间4个任意字符 |
…s | s结尾前面5个任意字符 |
* | 字符出现任意 |
? | 0到1次 |
+ | 1次到任意次 |
{n} | n次 |
{m,n} | m到n次 |
{0,n} | 0-n次 |
{,n} | 0-n次 |
{m,} | 最少m次 |
(lee){2} | lee字符串出现2次 |
练习脚本:
请显示系统中能被su命令切换的用户名称
grep -E “bash
∣
s
h
|sh
∣sh” /etc/passwd | cut -d : -f 1
2.sed
命令格式:
sed 参数 命令 处理对象
sed 参数 处理对象 -f 处理规则文件
对字符的处理
p | 显示 |
---|---|
sed -n 5p westos | 显示第五行 |
sed -n 3,5p westos | 显示3到5行 |
sed -ne "3p;5p westos | 显示3和5行 |
sed -ne 1,5p westos | 显示1-5行 |
sed -ne ‘5,$p’ westos | 显示5到最后1行 |
sed -n ‘/^#/p’ fstab | 显示以#开头的行 |
d | 删除 |
---|---|
sed 5d westos | 删除第五行 |
sed ‘/^#/d’ fstab | 把#开头的行删除 |
sed ‘/^UUID/!d’ fstab | 除了UUID以外的行都删除 |
sed -e ‘5,$d’ westos | 五行以后都删掉 |
a | 添加 |
---|---|
sed -e ‘$a hello world’ fstab | 末尾添加hello world |
sed -e ‘$a hello\nworld’ fstab | 末尾添加hello后换行添加world |
sed -e ‘/^#/a hello world’ fstab | 所有#开头的行后添加一行hello world |
c | 替换 |
---|---|
sed -e ‘/^#/c hello world’ fstab## | 开头的行换为hello world |
sed ‘5chello world’ westos | 第五行替换为hello world |
w | 把符合的行写到指定文件中 |
---|---|
sed ‘/^UUID/w westofile’ westos | 把westos中UUID开头的行写入westosfile中 |
i | 插入 |
---|---|
sed ‘5ihello westos’ westos |
r | 整合文件 |
---|---|
sed ‘5r haha’ westos |
sed 字符替换
sed ‘s/😕###/g’ westos
sed ‘s/😕###/’ westos
sed ‘s/😕###/g’ westos
sed ‘1,5s/😕###/g’ westos
sed ‘1s/😕###/g’ westos
sed ‘1s/😕###/g;5s/😕###/g’ westos
sed ‘/lp/,/shutdown/s/😕###/g’ westos
sed ‘s///####/g’ westos
sed ‘s@/@####@g’ westos
sed ‘s@/@####@g’ -i westos 把sed处理的内容保存到westos文件中
练习及脚本
Apache_port.sh
此脚本接入数字
http的端口就改为此数字
假设selinux为关闭状态
例如:
sh Apache_port.sh
ERROR: Pleaase input port number following script !!
sh Apache_port.sh 8080
apache的端口会被修改为8080
#/bin/bash
setenforce 0
[ -z $1 ] && {
echo -e "请写上端口号"
exit
}
rpm -q httpd &> /dev/null &&{
echo "服务已安装"
} || {
echo -e "请安装httpd服务"
}
sed " /^Listen/c Listen $1 " -i /etc/httpd/conf/httpd.conf
firewall-cmd --permanent --add-port=$1/tcp
firewall-cmd --reload
systemctl restart httpd
echo "设置成功!!!"
3.awk
awk -F 分隔符 BEGIN{ } { }END{ } FILENAME
NR | 行数 |
NF | 列数 |
FILENAME | 文件名称本身 |
westos | westos变量值 |
“westos” | westos字符串 |
— | — |
/bash$/ | 条件 |
/条件1 | 条件2/ |
/条件1/ | |
/条件1/&&/条件2/ | 条件1并且条件2 |
— | — |
$0 | 所有的列 |
$1 | 第一列 |
$2 | 第二列 |
$3 | 第三列 |
/etc/passwd文件的第六列没有home关键字并且以bash结尾的行
awk -F : ‘KaTeX parse error: Expected 'EOF', got '&' at position 10: 6!~/home/&̲&/bash/{print}’ /etc/passwd
4测试
1.统计在系统中能su切换的并且用户加目录不在/home下的用户数量
awk -F : ‘BEGIN{n=0}KaTeX parse error: Undefined control sequence: \/ at position 6: 6!~/^\̲/̲home/&&/bash|sh$/{print $0;n++}END{print n}’ passwd
2.过滤ens3的ip
ifconfig ens3 | awk ‘/inet>/{print $2}’
172.25.254.118
3.查找访问apache最多的ip
awk ‘{print $1}’ /etc/httpd/logs/access_log | sort -n | uniq -c | sort -t " " -k 2 -rn | head -n 1 | awk ‘{print $2}’