1、显示/etc目录下,以非字母开头,后面跟了一个字母以及其它任意长度任意字符的文件或目录
[12:01:24 root@centos8 etc]#touch 1{a..c}.txt
[12:01:24 root@centos8 etc]#ls /etc/ | egrep "^[^[:alpha:]][[:alpha:]].*"
1a.txt
1b.txt
1c.txt
[12:17:55 root@centos8 etc]#ls /etc/ | egrep "^[^a-zA-Z][a-zA-Z].*"
1a.txt
1b.txt
1c.txt
^[^[:alpha:]]:以非字母开头的行
[[:alpha:]]:匹配一个字母
.*:任意长度的字符
2、复制/etc目录下所有以p开头,以非数字结尾的文件或目录到/tmp/mytest1目录中。
[20:41:18 root@centos8 ~]#mkdir /tmp/mytest1
[20:41:18 root@centos8 ~]#cd /etc/
[20:41:24 root@centos8 etc]#ls /etc/ | egrep "^p.*[^0-9]$" | xargs -i cp -r {} /tmp/mytest1
[20:41:26 root@centos8 etc]#cd /tmp/mytest1/
[20:41:41 root@centos8 mytest1]#ls
pam.d passwd passwd- pki plymouth pm popt.d prelink.conf.d printcap profile profile.d protocols
3、将/etc/issue文件中的内容转换为大写后保存至/tmp/issue.out文件中
[20:48:34 root@centos8 ~]#cat /etc/issue | tr -s '[a-z]' '[A-Z]' > /tmp/issue.out
[20:48:51 root@centos8 ~]#cat /tmp/issue.out
\S
KERNEL \R ON AN \M
4、请总结描述用户和组管理类命令的使用方法并完成以下练习:
(1)、创建组distro,其GID为2019;
[09:36:27 root@centos8 ~]#groupadd -g 2019 distro
[09:36:50 root@centos8 ~]#getent group distro
distro:x:2019:
(2)、创建用户mandriva, 其ID号为1005;基本组为distro;
[09:37:14 root@centos8 ~]#useradd -u 1005 mandriva -g distro
[09:39:13 root@centos8 ~]#id mandriva
uid=1005(mandriva) gid=2019(distro) groups=2019(distro)
(3)、创建用户mageia,其ID号为1100,家目录为/home/linux;
[09:51:30 root@centos8 ~]#useradd -u 1100 -d /home/linux mageia
[09:55:53 root@centos8 ~]#getent passwd mageia
mageia:x:1100:1100::/home/linux:/bin/bash
(4)、给用户mageia添加密码,密码为mageedu,并设置用户密码7天后过期
[09:56:00 root@centos8 ~]#echo mageedu | passwd --stdin -x 7 mageia
Adjusting aging data for user mageia.
passwd: Success
[10:03:39 root@centos8 ~]#getent shadow mageia
mageia:!!:18609:0:7:7:::
(5)、删除mandriva,但保留其家目录;
[10:04:09 root@centos8 ~]#userdel mandriva
[10:08:23 root@centos8 ~]#ls /home/
linux mandriva zf
(6)、创建用户slackware,其ID号为2002,基本组为distro,附加组peguin;
[10:09:59 root@centos8 ~]#useradd -u 2002 -g distro -G peguin slackware
[10:10:17 root@centos8 ~]#id slackware
uid=2002(slackware) gid=2019(distro) groups=2019(distro),2020(peguin)
(7)、修改slackware的默认shell为/bin/tcsh;
[10:10:21 root@centos8 ~]#getent passwd slackware
slackware:x:2002:2019::/home/slackware:/bin/bash
[10:11:17 root@centos8 ~]#usermod -s /bin/tcsh slackware
[10:11:42 root@centos8 ~]#getent passwd slackware
slackware:x:2002:2019::/home/slackware:/bin/tcsh
(8)、为用户slackware新增附加组admins,并设置不可登陆。
[10:21:50 root@centos8 ~]#usermod -a -G peguin -s /sbin/nologin slackware
[10:22:31 root@centos8 ~]#id slackware
uid=2002(slackware) gid=2019(distro) groups=2019(distro),2020(peguin),2021(admins)
[10:22:42 root@centos8 ~]#getent passwd slackware
slackware:x:2002:2019::/home/slackware:/sbin/nologin
5、创建用户user1、user2、user3。在/data/下创建目录test
(1)、目录/data/test属主、属组为user1
[10:29:54 root@centos8 ~]#useradd user1
[10:30:02 root@centos8 ~]#useradd user2
[10:30:05 root@centos8 ~]#useradd user3
[10:30:07 root@centos8 ~]#mkdir /data/test
[10:31:30 root@centos8 ~]#ll -d /data/test/
drwxr-xr-x 2 root root 6 Dec 13 10:30 /data/test/
[10:31:35 root@centos8 ~]#chown user1. /data/test/
[10:31:56 root@centos8 ~]#!ll
ll -d /data/test/
drwxr-xr-x 2 user1 user1 6 Dec 13 10:30 /data/test/
[10:32:01 root@centos8 ~]#
(2)、在目录属主、属组不变的情况下,user2对文件有读写权限
[10:32:01 root@centos8 ~]#chmod o=rwx /data/test/
[10:34:22 root@centos8 ~]#ll -d /data/test/
drwxr-xrwx 2 user1 user1 6 Dec 13 10:30 /data/test/
(3)、user1在/data/test目录下创建文件a1.sh, a2.sh, a3.sh, a4.sh,设置所有用户都不可删除1.sh,2.sh文件、除了user1及root之外,所有用户都不可删除a3.sh, a4.sh
[10:39:45 user1@centos8 test]$touch a{1..4}.sh
[10:43:48 root@centos8 test]#ll
[10:43:49 root@centos8 test]#chattr +i a1.sh
[10:44:01 root@centos8 test]#chattr +i a2.sh
[10:50:56 root@centos8 ~]#ll -d /data/test/
drwxr-xrwx 2 user1 user1 58 Dec 13 10:50 /data/test/
[10:51:39 root@centos8 ~]#chmod o-w /data/test/
(4)、user3增加附加组user1,同时要求user1不能访问/data/test目录及其下所有文件
[10:55:38 root@centos8 ~]#usermod -G user1 user3
[10:56:09 root@centos8 ~]#id user3
uid=2005(user3) gid=2005(user3) groups=2005(user3),2003(user1)
[10:56:13 root@centos8 ~]#setfacl -m u:user1:- /data/test/
(5)、清理/data/test目录及其下所有文件的acl权限
[11:03:35 root@centos8 ~]#setfacl -b /data/test/
[11:03:51 root@centos8 ~]#getfacl /data/test/
getfacl: Removing leading '/' from absolute path names
# file: data/test/
# owner: user1
# group: user1
user::rwx
group::r-x
other::r-x