1、显示/etc目录下,以非字母开头,后面跟了一个字母以及其他任意长度任意字符的文件或目录
[root@centos7]# ls /etc/|grep "^[^[:alpha:]][[:alpha:]].*"
2、复制/etc目录下所有以p开头,以非数字结尾的文件或目录到/tmp/mytest1目录中。
[root@centos7]# mkdir -p /tmp/mytest1
[root@centos7]# ls | grep '^p.*[^[:digit:]]$' | xargs -i cp -a {} /tmp/mytest1/
3、将/etc/issue文件中的内容转换为大写后保存值/tmp/issue.out文件中
[root@centos7]# cat /etc/issue | tr 'a-z' 'A-Z' > /tmp/issue.out
4、请总结描述用户和组管理类命令的使用方法并完成以下练习
4.1 用户和组管理类命令的使用方法:
4.1.1 用户的增删改命令
1)增加永固命令
useradd [option] LOGIN
2)删除用户命令
userdel [option] LOGIN
3)更改用户属性命令
usermod [option] LOGIN
4.1.2 组的增删改命令
1)增加组命令
groupadd [options] GROUP
2)删除组命令
groupdel [option] GROUP
3)修改组命令
groupmod [option] GROUP
4.1.3 其他用户管理命令
1)修改用户密码类策略
chage [options] LOGIN
2)指定个人信息
chfn [options] [username]
3)指定用户shell类型
chsh [options] [username]
4)切换用户身份
su [options] [-] [USER [arg]...]
(1)、创建组distro,其GID为2019;
[root@centos7]# groupadd -g 2019 distro
[root@centos7]# getent group distro
distro:x:2019:
(2)、创建用户mandriva,其ID号为1005;基本组为distro;
[root@centos7]# useradd -u 1005 -g distro mandriva
[root@centos7]# id mandriva
uid=1005(mandriva) gid=2019(distro) groups=2019(distro)
(3)、创建用户mageia,其ID为1100.家目录为/home/linux;
[root@centos7]# useradd -u 1100 -d /home/linux mageia
[root@centos7]# ls /home | grep linux
linux
[root@centos7]#id mageia
uid=1100(mageia) gid=1100(mageia) groups=1100(mageia)
(4)、给用户mageia添加密码,密码为mageedu,并设置用户密码7天后过期
[root@centos7]# useradd mageia
[root@centos7]# echo "mageedu" | passwd --stdin mageia
Changing password for user mageia.
passwd: all authentication tokens updated successfully.
[root@centos7]# chage -E 7 mageia
[root@centos7]# cat /etc/shadow | grep mageia
mageia:$6$icm2RmLB$npbF.KDu3wgbMezW3Nyj33CxakYkgmRO3NE0LaB365KhBna52GmymqlsSbX/zEEffET1JwfY23OwYtBPSIlwM0:18686:0:99999:7::7:
(5)、删除mandriva,但保留其家目录;
[root@centos7]# userdel mandriva
[root@centos7]# ls /home/ | grep linux
linux
(6)、创建用户slackware,其ID号为2002,基本组为distro,附加组peguin;
[root@centos7]# groupadd peguin
[root@centos7]# useradd -u 2002 -g distro -G peguin slackware
[root@centos7]# id slackware
uid=2002(slackware) gid=2019(distro) groups=2019(distro),2020(peguin)
(7)、修改slackware的默认shell为/bin/tcsh;
[root@centos7]# usermod -s /bin/tcsh slackware
[root@centos7]# getent passwd slackware
slackware:x:2002:2019::/home/slackware:/bin/tcsh
(8)、为用户slackware新增加附加组admins,并设置不可登录;
[root@centos7]# groupadd admins
[root@centos7]# getent group admins
admins:x:2021:
[root@centos7]# usermod -G peguin,admins slackware
[root@centos7]# id slackware
uid=2002(slackware) gid=2019(distro) groups=2019(distro),2020(peguin),2021(admins)
[root@centos7]# chsh slackware -s /sbin/nologin
Changing shell for slackware.
Shell changed.
[root@centos7]# getent passwd slackware
slackware:x:2002:2019::/home/slackware:/sbin/nologin
5、创建用户user1、user2、user3,在/data/下创建目录test
[root@centos7]# useradd user1
[root@centos7]# useradd user2
[root@centos7]# useradd user3
[root@centos7]# mkdir -p /data/test
(1)、目录/data/test属主、属组为user1
[root@centos7]# chown user1.user1 /data/test/
[root@centos7]# ll /data
total 0
drwxr-xr-x. 2 user1 user1 6 Feb 28 22:03 test
(2)、在目录属主、属组不变的情况下,user2对文件有读写权限
[root@centos7]# setfacl -m u:user2:rw /data/test/
[root@centos7]# getfacl /data/test/
getfacl: Removing leading '/' from absolute path names
# file: data/test/
# owner: user1
# group: user1
user::rwx
user:user2:rw-
group::r-x
mask::rwx
other::r-x
(3)、user1在/data/test目录下创建文件a1.sh,a2.sh,a3.sh,a4.sh,设置所有用户都不可删除a1.sh,a2.sh文件、除了user1及root之外,所有用户都不可删除a3.sh,a4.sh
[root@centos7]# su - user1
[root@centos7]# touch /data/test/a{1..4}.sh
[root@centos7]# ls /data/test/
a1.sh a2.sh a3.sh a4.sh
[root@centos7]# chattr +i /data/test/a1.sh /data/test/a2.sh
chattr: Operation not permitted while setting flags on /data/test/a1.sh
chattr: Operation not permitted while setting flags on /data/test/a2.sh
[root@centos7]# chmod o+t /data/test/a3.sh /data/test/a4.sh
(4)、user3增加附加组user1,同时要求user1不能访问/data/test目录及其下所有文件
[root@centos7]# usermod user3 -a -G user1
[root@centos7]# id user3
uid=2005(user3) gid=2005(user3) groups=2005(user3),2003(user1)
[root@centos7]# setfacl -m u:user1:- /data/test/
(5)、清理/data/test目录下及其下所有文件的acl权限
[root@centos7]# setfacl -R -b /data/test/
[root@centos7]# 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