一、shell命令应用练习
1、简述以下文件的用途
① /etc/passwd passwd为密码文件,用来管理用户的密码。普通用户通常只能修改自己的密码信息
② /etc/shadow shadow是一个影子化的密码文件,它包含系统账户的密码信息和可选的年龄信息。只有管理员能查看修改
③ /etc/group
group文件是用户组的配置文件,内容包括用户和用户组,并且能显示出用户是归属哪个用户组或哪几个用户组,因为一个用户可以归属一个或多个不同的用户组;同一用户组的用户之间具有相似的特征
④ /etc/gshadow
/etc/gshadow是/etc/group的加密资讯文件,比如用户组(Group)管理密码就是存放在这个文件。/etc/gshadow和/etc/group是互补的两个文件;对于大型服务器,针对很多用户和组,定制一些关系结构比较复杂的权限模型,设置用户组密码是极有必要的
2、依次输入如下命令,观察运行结果,指出每一条命令功能
id:id命令可以显示真实有效的用户ID(UID)和组ID(GID)
id -u:只显示用户ID
id -u root: 即查看root的用户ID,为0
id -u liuli: 查看liuli这个用户的ID,为1000
3、在shell命令终端依次输入以下命令,观察执行结果,理解每条命令实现的具体功能
which python:查找系统PATH目录下名为python的可执行文件
whereis python:whereis命令可以用来查找二进制(命令)、源文件、man文件。与which不同的是这条命令可以是通过文件索引数据库而非PATH来查找的,所以查找的面比which要广
locate python:通过数据库查找文件。这个命令可以找到任意你指定要找的文件,并且可以只输入部分文件名。
find /usr/bin -name python:通过直接搜索硬盘的方式查找/usr/bin目录下名为python的文件。
② grep -n -E 'root|jsj|^user*' /etc/passwd (提示:扩展正则表达式)
grep -n -E ' [[:digit:]] ' /etc/passwd
grep -n -E ' [[:alpha:]] ' /etc/passwd
grep -n '[0-9]\{4,\}' /etc/group (提示: 在用户组文件中查找 GID 是 4 位数及以上的组信息记录)
grep -n -E ‘root|cy|^user*‘:/etc/passwd -n为显示行号,该指令作用是在/etc/passwd文件中查找以root或cy为行首的行,其中*表示重复零次以上,^表示必须出现在行首。
grep -n -E ‘ [[:digit:]] ‘ /etc/passwd:在 /etc/passwd文件中查找含有纯数字的行。
grep -n -E ‘ [[:alpha:]] ‘ /etc/passwd:在 /etc/passwd文件中查找含有纯字母的行。
grep -n ‘[0-9]\{4,\}‘ /etc/group 因为不加-E,所以使用花括号加转义符\{\} ,[0-9]等价于[[:digit:]],找出纯数字,4代表4位以上。
③ sudo apt install gimp
which gimp
sudo apt remove gimp
which gimp
sudo apt install gimp:安装软件gimp。
which gimp:查询gimp的位置。
sudo apt remove gimp:卸载gimp。
which gimp:查询gimp的位置,此时已经没有查询结果。
④ ls -dl /root --time-style=long-iso:/root下显示文件目录信息,详细信息,时间按完整的IOS时间格式显示
ls -dl /root --time-style=long-iso | cut -d' ' -f1,8:以空格为分隔符,截取上一条指令中的第一和第八个域
⑤ ls -l --time-style=long-iso,:ls -l 是列出文件的详细信息,时间设置为long-iso格式,默认排序
ls -l --time-style=long-iso -t:在前一条命令的基础上按时间由近到远排序
ls -l --time-style=long-iso -t -r:在前一条命令的基础上按时间排序,但变为由远到近排序
⑥ ls /usr/share/man:显示/usr/share/man下的目录
ls /usr/share/man | grep man[1-8]:在上一条命令的基础上搜索man1~man8
ls /usr/share/man/man1:显示/usr/share/man/man1下的目录
file /usr/share/man/man1/ls.1.gz (结合执行结果,review2.8.1 节 gzip命令内容)
mkdir ~/temp; cp /usr/share/man/man1/ls.1.gz ~/temp:根目录下创建temp文件夹,把ls.1.gz复制到temp下
cd ~/temp; ls:转到temp目录下,查看所有文件目录,此时有后缀.gz
sudo gzip -d ls.1.gz; ls:解压并查看目录,此时.gz消失,说明已经解压并删除了压缩包
⑦ ls –l /home | grep "^d" | wc –l:在home目录下查找以d开头的行,并统计行数
⑧ sudo adduser user7
ls /home | tee users | wc -l (提示:输入 cat users 观察该文件内容)
sudo adduser user7:创建用户user7。
ls /home | tee users | wc -l:在home目录下查找用户名,并统计行数
(4) 根据要求写出相应的 shell 命令
① 在目录/usr/include 下搜索文件 signal.h 是否存在 (提示: find 命令)
② 在/usr/include 目录下的所有文件中查找包含 BUFSIZ 的行,并显示所在行号。要求:屏幕上只显示查找到的结果,过滤错误信息。
(提示:① 利用 grep 和通配符*;②利用错误信息重定向和特殊设备文件/dev/null)
③ 在用户名密码文件/etc/passwd 中查找登录 shell 为 bash 的用户信息记录,并显
示行号
(提示:使用 grep 和正则表达式中的$)
④ 从/etc/group 文件中截取第 1 列(组名)和第 3 列(组 id),并按照组 id 号的数值大小由小到大排序。(提示:综合使用 cut, 管道线及 sort 命令)
(提交文档时,写出其实现的功能的命令及截图,包括命令和结果在内的截图)
3、(1)
(2)
实验总结:
本次实验对命令的使用比较多,把前两次实验的零碎指令综合运用了,其中犯了很多输入命令格式的错误,比如ls /。。。。中ls后面要空格,一开始未发现,编辑了很长时间都未解决实际问题,对本次实验做的磕磕盼盼,在网上搜索了很多的资料才最终完成了实验,最后要用四种方法来运行脚本,目前刚刚会两种(汗颜),实验中也只是截图了其中一种,而且输出的格式没弄好,还需要练习。