1、显示/etc目录下,以非字母开头,后面跟了一个字母以及其它任意长度任意字符的文件或目录。
[root@centos8 ~]# ls /etc | grep '^[^[:alpha:]][[:alpha:]]\{,1\}.*'
[root@centos8 ~]#
2、复制/etc目录下所有以p开头,以非数字结尾的文件或目录到/tmp/mytest1目录中。
[root@centos8 ~]# cd /etc
[root@centos8 etc]# cp -rf p*[^0-9] /tmp/mytest1
[root@centos8 ~]# cp -a /etc/p*[^[:digit:]] /tmp/mytest1/
3、将/etc/issue文件中的内容转换为大写后保存至/tmp/issue.out文件中
[root@centos8 etc]# cat /etc/issue | tr [:lower:] [:upper:] > /tmp/issue.out
[root@centos8 etc]# cat /tmp/issue.out
\S
KERNEL \R ON AN \M
4、请总结描述用户和组管理类命令的使用方法并完成以下练习:
(1)、创建组distro,其GID为2019;
[root@centos8 ~]# groupadd -g 2019 distro
[root@centos8 ~]# cat /etc/group
root:x:0:
bin:x:1:
daemon:x:2:
sys:x:3:
......
screen:x:84:
distro:x:2019:
(2)、创建用户mandriva, 其ID号为1005;基本组为distro;
[root@centos8 ~]# useradd -u 1005 -g distro mandriva
[root@centos8 ~]# id mandriva
uid=1005(mandriva) gid=2019(distro) groups=2019(distro)
[root@centos8 ~]#
(3)、创建用户mageia,其ID号为1100,家目录为/home/linux;
[root@centos8 ~]# useradd -u 1100 -d /home/linux mageia
[root@centos8 ~]# id mageia
uid=1100(mageia) gid=1100(mageia) groups=1100(mageia)
(4)、给用户mageia添加密码,密码为mageedu,并设置用户密码7天后过期
[root@centos8 ~]# echo 'mageedu' | passwd mageia -n 7
Adjusting aging data for user mageia.
passwd: Success
(5)、删除mandriva,但保留其家目录;
[root@centos8 ~]# id mandriva
uid=1005(mandriva) gid=2019(distro) groups=2019(distro)
[root@centos8 ~]# userdel mandriva
[root@centos8 ~]# id mandriva
id: ‘mandriva’: no such user
(6)、创建用户slackware,其ID号为2002,基本组为distro,附加组peguin;
[root@centos8 ~]# groupadd peguin
[root@centos8 ~]# useradd slackware -u 2002 -g distro -G peguin
[root@centos8 ~]# id slackware
uid=2002(slackware) gid=2019(distro) groups=2019(distro),2020(peguin)
(7)、修改slackware的默认shell为/bin/tcsh;
[root@centos8 ~]# usermod slackware -s /bin/tcsh
(8)、为用户slackware新增附加组admins,并设置不可登陆。
[root@centos8 ~]# groupadd admins
[root@centos8 ~]# usermod -aG admins -s /sbin/nologin slackware
[root@centos8 ~]# id slackware
uid=2002(slackware) gid=2019(distro) groups=2019(distro),2020(peguin),2021(admins)
[root@centos8 ~]# su slackware
This account is currently not available.
5、创建用户user1、user2、user3。在/data/下创建目录test
[root@centos8 ~]# useradd user1
[root@centos8 ~]# useradd user2
[root@centos8 ~]# useradd user3
[root@centos8 ~]# mkdir -p /data/test
[root@centos8 ~]# ll /data
total 0
drwxr-xr-x 2 root root 6 Jan 1 00:18 test
(1)、目录/data/test属主、属组为user1
[root@centos8 data]# ll
total 0
drwxr-xr-x 2 root root 6 Jan 1 00:18 test
[root@centos8 data]# chown -R user1.user1 test
[root@centos8 data]# ll
total 0
drwxr-xr-x 2 user1 user1 6 Jan 1 00:18 test
(2)、在目录属主、属组不变的情况下,user2对文件有读写权限
[root@centos8 test]# ll
total 0
-rw-r--r-- 1 root root 0 Jan 2 21:19 a.txt
[root@centos8 test]# setfacl -m u:user2:rw a.txt
[root@centos8 test]# ll
total 0
-rw-rw-r--+ 1 root root 0 Jan 2 21:19 a.txt
(3)、user1在/data/test目录下创建文件a1.sh, a2.sh, a3.sh, a4.sh,设置所有用户都不可删除1.sh,2.sh文件、除了user1及root之外,所有用户都不可删除a3.sh, a4.sh
[root@centos8 ~]# chattr +i /data/test/a{1..2}.sh
[root@centos8 ~]# lsattr
-------------------- ./anaconda-ks.cfg
-------------------- ./test
-------------------- ./abc.txt
-------------------- ./err.txt
[root@centos8 ~]# lsattr /data/test
----i--------------- /data/test/a1.sh
----i--------------- /data/test/a2.sh
-------------------- /data/test/a3.sh
-------------------- /data/test/a4.sh
[root@centos8 ~]# chmod o+t /data/test/a{3..4}.sh
drwxr-xr-x 2 user1 user1 58 Jan 2 23:08 /data/test/
[root@centos8 ~]# ll -d /data/test/*
-rw-rw-r-- 1 user1 user1 0 Jan 2 22:12 /data/test/a1.sh
-rw-rw-r-- 1 user1 user1 0 Jan 2 22:12 /data/test/a2.sh
-rw-rw-r-T 1 user1 user1 0 Jan 2 22:12 /data/test/a3.sh
-rw-rw-r-T 1 user1 user1 0 Jan 2 22:12 /data/test/a4.sh
(4)、user3增加附加组user1,同时要求user1不能访问/data/test目录及其下所有文件
[root@centos8 ~]# id user3
uid=2005(user3) gid=2005(user3) groups=2005(user3)
[root@centos8 ~]# usermod user3 -a -G user1
[root@centos8 ~]# id user3
uid=2005(user3) gid=2005(user3) groups=2005(user3),2003(user1)
[root@centos8 ~]# setfacl -m u:user1:- /data/test/
(5)、清理/data/test目录及其下所有文件的acl权限
[root@centos8 ~]# setfacl -b -R /data/test/