1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。

Who | cut -d" " -f1 | sort -u

查找、过滤及用户和组管理_过滤

 

sort用法

参 数:

-b 忽略每行前面开始出的空格字符。

-c 检查文件是否已经按照顺序排序。

-f 排序时,忽略大小写字母。

-M 将前面3个字母依照月份的缩写进行排序。

-n 依照数值的大小排序。

-o<输出文件> 将排序后的结果存入指定的文件。

-r 以相反的顺序来排序。

-t<分隔字符> 指定排序时所用的栏位分隔字符。

-k 选择以哪个区间进行排序。

 

 

2、取出最后登录到当前系统的用户的相关信息。

 

Id $(who | tail -1 | cut -d ' ' -f1)

查找、过滤及用户和组管理_用户组_02

tail用法

参 数:

默认示文件的末尾行,缺省显示最后10行

-n参数可以设定显示的行数,

-f参数当文件内容发生增加时自动显示。

 

 

3、取出当前系统上被用户当做其默认shell的最多的那个shell

 cut -d : -f7 /etc/passwd | uniq -c | sort -n | tail -1

 

查找、过滤及用户和组管理_用户组_03

 

uniq用法

参 数:

-c: 在每列旁边显示该行重复出现的次数。

-d: 仅显示重复出现的行列。

-f: 忽略比较指定的栏位。

-s: 忽略比较指定的字符。

-u: 仅显示出一次的行列。

-w: 指定要比较的字符。

-n:前n个字段和每个字段前的空白一起被忽略

+n:前n个字符被忽略

 

 

4、将/etc/passwd中的第三个字段数值最大的后10个用户的信息全部改为大写后保存至/tmp/maxusers.txt文件中。

 

sort -n -t: -k3 /etc/passwd | tail -10 | tr [a-z] [A-Z] &>/tmp/maxusers.txt

查找、过滤及用户和组管理_查找_04

 

 

5、取出当前主机的ip地址,提示:对ifconfig命令的结果进行切分

 

Ifconfig | grep -o "inet .*" |cut -d" " -f2

查找、过滤及用户和组管理_查找_05

 

6、列出/etc目录下所有以.conf结尾的文件的文件名,并将其名字转化为大写后保存至/tmp/etc.conf文件中。

 

Ls /etc/*.conf | tr 'a-z' 'A-Z' > /tmp/etc.conf

查找、过滤及用户和组管理_查找_06

 

 

 

7、显示/var目录下一级目录或文件的总个数

 

Ls /var |wc -l

查找、过滤及用户和组管理_用户组_07

 

 

 

 

8、取出/etc/group文件中第三个字段数值最小的10个组的名字

 

第3字段按数值排序,取前10行

查找、过滤及用户和组管理_查找_08

通过管道送给“cut”,取组名

查找、过滤及用户和组管理_用户组_09

 

 

 

9、将/etc/fstab和/etc/issue文件的内容合并为同一个内容后保存至/tmp/etc.test文件中。

Cat /etc/fstab /etc/issue > /tmp/etc.test

查找、过滤及用户和组管理_过滤_10

 

 

 

10.请总结描述用户和组管理类命令的使用方法并完成以下练习:

 

1.创建组distro,其GID为2016

groupadd –g 2016 distro

 

2.创建用户mandriva,其ID为1005;基本组为distro

useradd –u 1005 –g distro mandriva

 

3.创建用户mageia,其ID 为1100,家目录为/home/linux

useradd –u 1100 –d /home/linux mageia

 

4.给用户mageia添加密码,密码为mageedu

echo mageedu | passwd --stdin mageia

 

5.删除mandriva,但保留其家目录

userdel mandriva

 

6.创建用户slackware,其ID号为2002,基本组为distro,附加组peguin

useradd –u 2002 –g distro –G peguin slackware

 

7.修改slackware的默认shell为/bin/tcsh

usermod –s /bin/tcsh slackware

 

8.为用户slackware新增附加组admins

usermod –G admins –a slackware

 

9.为slackware添加密码,且要求密码最短使用期限为3天,最长为180天,警告为3天

echo redhat | passwd –n 3 –x 180 –w 3 --stdin slackware

 

10.添加用户openstack,其ID号为3003,基本组为clouds,附加组为peguin和nova

useradd –u 3003 –g clouds –G peguin,nova openstack

 

11.添加系统用户mysql,要求其shell为/sbin/nologin

useradd –r mysql –s /sbin/nologin

 

12.使用echo命令,非交互式为openstack添加密码

echo redhat | passwd --stdin openstack