grep
grep
grep -E = egrep
grep 格式
grep 匹配条件 处理文件
grep root passwd 过滤root关键字
grep ^root passwd 以root开头
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切换的用户的名称!!
测试结果如下!
sed
sed命令主要的格式
sed 参数 命令 处理对象
对字符的处理
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到最后以行
sed -n ‘/^#/p’ fstab 显示以#开头的行
sed -n '/^s/p passwd 找到以s开头的行!!
d 删除
sed 5d passwd 删除第五行
sed ‘/^#/d’ passwd 把#开头的行删除
sed ‘/^halt/!d’ passwd 除了UUID以外的行都删除
sed -e ‘5,$d’ passwd
-e 表示 : 多行策略
a 添加
sed -e ‘
a
h
e
l
l
o
w
o
r
l
d
′
p
a
s
s
w
d
表
示
最
后
添
加
h
e
l
l
o
w
o
r
l
d
s
e
d
−
e
′
a hello world' passwd 表示最后添加hello world sed -e '
ahelloworld′passwd表示最后添加helloworldsed−e′a hello\nworld’ passwd 表示最后添加: 一行hello 一行world
sed -e ‘/^mail/a hello world’ passwd 表示添加在以mail开头的一行下面!
c 替换
sed -e ‘/^mail/c hello world’ passwd mail 开头的行换为hello world
sed ‘5chello world’ passwd 表示第五行换为hello world
w 把符合的行写到指定文件中
sed ‘/^mail/w westosfile’ passwd 把passwd中开头的行写入westosfile
i 插入
sed ‘5ihello westos’ passwd
r 整合文件
sed ‘5r haha’ passwd
以上都是替换关键行 或者某一行!!
下面替换 关键字
sed 字符替换
sed ‘s/😕###/g’ passwd
sed ‘s/😕###/’ passwd
sed ‘1,5s/😕###/g’ passwd
sed ‘1s/😕###/g’ passwd
sed ‘1s/😕###/g;5s/😕###/g’ passwd
sed ‘/lp/,/shutdown/s/😕###/g’ passwd
sed ‘s///####/g’ passwd
sed ‘s@/@####@g’ passwd
不加g之替换一列
替换1,5行
替换以字母开头两行之间的所有行!
sed ‘s@/@####@g’ -i westos 把sed处理的内容保存到westos文件中
加上-i就会更改文件的内容并保存!
练习!
Apache_port.sh
此脚本后介入数字
http的端口就改为此数字
假设selinux为关闭状态
思路!!!
先判断脚本执行的时候 后面有没有写端口数字!
然后判断服务安了没!
然后判断是否是root用户 不然不能改端口
然后抓出想要设置的端口号,让系统检测是否设置了 如果设置了就报错!
如果以上都成功就修改/etc/httpd/conf/httpd.conf的Listen/cListen行并 -i 修改文件的内容!
重启服务即可!!!!
测试
刚开始没有安装服务 都会报错
awk
wk:报告生成器
处理机制:awk会逐行处理文本,支持在处理第一行之前做一些准备工作,以及在处理完最后一行做一些总结性质的工作,在命令格式上分别体现如下
BEGIN{}:读入第一行文本
END{}:处理完最后一行文本之后执行,一般用来输出处理结果
awk -F 分隔符 BEGIN{}{}END{} FILENAME
比如:
awk -F : ‘BEGIN{print “userlist:”}{print $1}END{print “end”}’ passwd
NR #行数
NF #列数
FILENAME #文件名称本身
westos #westos变量值
“westos” #westos字符串
/bash$/ #条件
/条件1|条件2/ #条件1或者条件2
/条件1/||/条件2/ #条件1或者条件2
/条件1/&&/条件2/ #条件1并且条件2
$0 #所有的列
$1 #第一列
$2 #第二列
$3 #第三列
awk -F : ‘/root/{print $1}’ passwd
##含root关键字
awk -F : ‘!/root/{print $1}’ passwd
##不含root关键字
测试
统计在系统中能su切换的并且用户家目录不在/home下的用户数量
如超级用户root,pwd-/root
方法!::
awk -F : ‘BEGIN{n=0}KaTeX parse error: Undefined control sequence: \/ at position 6: 6!~/^\̲/̲home/&&/bash|sh$/{n++}END{print n}’ /etc/passwd
##以bash和sh结尾的用户---->登陆系统
实验
要求:过滤网卡ens3的IP
ifconfig ens3 | awk ‘/inet>/{print $2}’
实验
awk统计/etc/passwd的行数
awk抓取最后一行所用的shell
思路!
awk -F : ‘END{print NR}’ /etc/passwd
awk -F : ‘END{print $NF}’ /etc/passwd