完成以下操作:
修改主机配置文件
修改hosts文件,添加两条映射记录
192.168.1.2 www.aaa.com
192.168.1.3 www.bbb.com
多文本处理操作:
i:在指定的行之前插入文本
a:在指定的行之后插入文本
c:替换指定的行
语法结构:
#sed '2a xx' a.txt //在第2行后面,追加xx
#sed '2i xx' a.txt //在第二行前面,插入xx
#sed '2c xx' a.txt //将第二行替换为xx
修改主机名配置文件:
#sed /1c hhhh.com.cn’ /etc/hostname
修改hosts文件,添加两条映射记录
192.168.1.2 www.aaa.com
192.168.1.3 www.bbb.com
#sed '$a 192.168.12 www.aaa.com' /etc/hosts
总结:
#sed 选项 ‘条件指令’ 文件
选项:
-n :屏蔽默认输出
-r :支持扩展正则
-i :修改源文件
条件:
行号:4 4,5 4~2 4+10
/正则/
指令:
p :打印s
d :删除
s :替换 s/旧/新/g
a :追加
i :插入
c :替换行
实例:
编写一个getupwd.sh,实现以下需求:
1.找到使用bash作为登录shell的本的用户
2.列出这些用户的shadow密码记录
3.按照每行“用户名—>密码记录”格式保存都getupwd.log
实现思路:
1.先从/etc/ passwd中取出以bash结尾的行的用户名
2.结合循环遍历取出来的用户名,对/etc/shadow 进行处理
3.采用掐头去尾方式,获得密码字符串
4.按照指定格式进行追加
#! /bin/bash
username= `sed -n ' /bash$/s/: . *//p' /etc/pas swd`
for i in $username
do
pass1=`grep $i /etc/ shadow
pass2=$ {pass1#*: }
pass3=${pass2%%: *}
echo " $i --> $pass3" >> getupws . log
done