Linux实验三: shell 编程(1)

  1. hell 命令应用练习

①    /etc/passwd  ‘

etc/passwd 为每个用户账户包含一行,包含使用冒号 (“:”)分隔的七个字段,分别是:登录名,选的加密后的密码,字用户ID ,字组 ID ,户名和注释字段,  用户主目录,可选的用户命令解释器

② /etc/shadow

shadow是一个文件,它包含系统账户的密码信息和可选的年龄信息。   如果没有维护好密码安全,此文件绝对不能让普通用户可读。

③ /etc/group 

  文件是用户组的配置文件,内容包括用户和用户组,并且能显示出用户是归属哪个用户组或哪几个用户组,因为一个用户可以归属一个或多个不同的用户组;同一用户组的用户之间具有相似的特征。

④ /etc/gshadow 、

/etc/gshadow 包含影子化了的组账户信息。如果没有维护好密码安全,此文件绝对不能让普通用户可读。

(2)依次输入如下命令,观察运行结果。结合 man id 查看到的帮助信息,指出每一条 命令功能

①     Id  显示真实有效的用户ID(UID)和组ID(GID)

②        id -u  显示用户id

③ id -u root  显示root用户id

④ id -u Jiang 显示jiang的id

 

(3)在 shell 命令终端依次输入以下命令,观察执行结果,理解每条命令实现的具体功能

① which python   which命令的作用是,在PATH变量指定的路径中,搜索某个系统命令的位置,并且返回第一个搜索结果。

       whereis python查看文件的位置

locate python  配合数据库查看文件位置

find/usr/bin -name python        实际搜寻硬盘查询文件名称

 

 

 

 

③     grep  -n  -E  'root|jiang|^user*'  /etc/passwd 

在/etc/passwd  中查找以root或者jiang开头的行

 

 

 grep  -n  -E  ' [[:digit:]] '  /etc/passwd

在/etc/passwd  中查找含有的数字

 

 

grep  -n  -E  ' [[:alpha:]] '  /etc/passwd

在/etc/passwd  中查找含有的字母

 

 

grep  -n  '[0-9]\{4,\}'  /etc/group (提示: 在用户组文件中查找 GID 是 4

 

       sudo apt install gimp:安装gimp软件

 

 

which gimp查找gimp 的位置

 

sudo apt remove gimp 卸载gimp

 

which gimp 再查找gimp的位置,找不到

④     ls -dl /root --time-style=long-iso

 

ls -dl /root --time-style=long-iso | cut -d' ' -f1,8

 

 

⑤     ls -l --time-style=long-iso

将文件的时间按long-ios的形式进行列出

 

 

 

 

ls -l --time-style=long-iso -t 

将文件按时间的修改时间顺序列出

 

 

 

 ls -l --time-style=long-iso -t -r

  按上面的时间逆序排列

⑥         ls /usr/share/man  查看该目录

ls /usr/share/man | grep man[1-8]  搜索该目录下是否有man1-8

ls /usr/share/man/man1  查看man1目录

file /usr/share/man/man1/ls.1.gz 查看该文件信息

mkdir ~/temp; cp /usr/share/man/man1/ls.1.gz ~/temp  创建一个temp的目录,将ls.1.gz复制到该目录下

cd ~/temp; ls  转到temp目录下并查看

sudo gzip -d ls.1.gz; ls   解压并查看文件目录

 

 

⑦     ls –l /home  | grep  "^d"  |  wc –l

 

 

⑧      sudo adduser user7    创建user用户

 ls /home | tee users | wc –l  查找用户并统计数目

 

 

(4)根据要求写出相应的 shell 命令 ① 在目录/usr/include 下搜索文件 signal.h 是否存在

 

 

② 在/usr/include 目录下的所有文件中查找包含 BUFSIZ 的行,并显示所在行号。 要求:屏幕上只显示查找到的结果,过滤错误信息。

 

 

 ③ 在用户名密码文件/etc/passwd 中查找登录 shell 为 bash 的用户信息记录,并显 示行号

 

 

④ 从/etc/group 文件中截取第 1 列(组名)和第 3 列(组 id),并按照组 id 号的数 值大小由小到大排序。(提示:综合使用 cut, 管道线及 sort 命令)

 

 

 

 (5)体验 awk, sed 用法:依次执行命令,观察执行结果

① cp /etc/apt/sources.list  t1;  less t1

 

 

 

② sed -e "s/#.*//g"  t1

 

 

③ sed -e "s/#.*//g"  t1 | awk '{if (length != 0) print $0}'

 

 

④ tail -5 /etc/passwd | awk -F: '{print $1}'

 

 

⑤ tail -5 /etc/group | tee t2  

 awk 'BEGIN{print "file t2"} {print "line" NR ":" $0} END {print "over"}' t2

 

 

(6)查阅网络或帮助,体验命令 curl 和 wget 用法。

① 命令工具 curl 功能,截图显示自己尝试的练习,并作必要陈述说明   

 

 

 

② 命令工具 wget 功能,截图显示自己尝试的练习,并作必要陈述说明

 

 

(1)      练习 1

 

 

(2)      练习2

 

 

转载于:https://www.cnblogs.com/nullno/p/8983012.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值