第二周作业

1、显示/etc目录下,以非字母开头,后面跟了一个字母以及其它任意长度任意字符的文件或目录

ls -d [^[:alpha:]][[:alpha:]]*

[root@cenos8 ~]#  ls -d /etc/[^[:alpha:]][[:alpha:]]*
/etc/1atest  /etc/2btest

2、复制/etc目录下所有以p开头,以非数字结尾的文件或目录到/tmp/mytest1目录中

cp -r /etc/p*[^[:digit:]] /tmp/mytest1

[root@cenos8 ~]# mkdir /tmp/mytest1;cp -a /etc/p*[^[:digit:]] /tmp/mytest1
[root@cenos8 ~]# 
[root@cenos8 ~]# ls /tmp/mytest1
pam.d      passwd   pbm2ppa.conf  pipewire  plymouth  pnm2ppa.conf  postfix         printcap  profile.d  pulse
papersize  passwd-  pinforc       pki       pm        popt.d        prelink.conf.d  profile   protocols

3、将/etc/issue文件中的内容转换为大写后保存至/tmp/issueout文件中

tr [[:lower:]] [[:upper:]] < /etc/issue > /tmp/issue.out

[root@cenos8 ~]# tr [[:lower:]] [[:upper:]] < /etc/issue > /tmp/issue.out
[root@cenos8 ~]# cat /tmp/issue.out
\S
KERNEL \R ON AN \M

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

useradd:添加用户,常用选项-u设置uid,-g设置主要组,-G设置附加组,-s指定shell类型,-d指定home目录等

usermod:修改用户的属性

userdel:删除用户

groupadd:添加组,-g设置gid

groupmod:修改组属性

groupdel:删除组

chattr:设置文件的特殊属性,可以限制root用户,使用操作符+,-;+i文件不能被修改、删除、重命名、或链接;+a,文件只能追加,不能修改或删除;

lsattr:查看文件的特殊属性

(1)、创建组distro,其GID为2019;
groupadd distro -g 2019

(2)、创建用户mandriva, 其ID号为1005;基本组为distro;

useradd mandriva -u 1005 -g distro

(3)、创建用户mageia,其ID号为1100,家目录为/home/linux;

useradd mageia -u 1100 -d /home/linux

(4)、给用户mageia添加密码,密码为mageedu,并设置用户密码7天后过期

echo mageedu | passwd -x 7 --stdin mageia

(5)、删除mandriva,但保留其家目录;

userdel mandriva

(6)、创建用户slackware,其ID号为2002,基本组为distro,附加组peguin;

groupadd peguin -g 1011

useradd slackware -u 2002 -g distro -G peguin

(7)、修改slackware的默认shell为/bin/tcsh;

usermod slackware -s /bin/tcsh

(8)、为用户slackware新增附加组admins,并设置不可登陆。

  • 创建组

groupadd admins -g 1012

  • 为用户增加附加组,并设置为不可登录

usermod slackware -G admins -s /sbin/nologin

5、创建用户user1、user2、user3。在/data/下创建目录test

  • 创建用户

echo user{1,2,3} | xargs -n 1 useradd

  • 创建目录

mkdir /data/test

(1)、目录/data/test属主、属组为user1

chown user1:user1 /data/test

(2)、在目录属主、属组不变的情况下,user2对文件有读写权限

setfacl -m u:user2:rw /data/test

(3)、user1在/data/test目录下创建文件a1.sh, a2.sh, a3.sh, a4.sh,设置所有用户都不可删除1.sh,2.sh文件、除了user1及root之外,所有用户都不可删除a3.sh, a4.sh

  • 使用user1创建文件

su user1 -c "echo /data/test/a{1,2,3,4}.sh | xargs touch"

  • 不允许所有用户删除

chattr +i /data/test/a{1,2}.sh

  • 除了user1(拥有者)及root外不允许删除

chmod o+t /data/test

(4)、user3增加附加组user1,同时要求user1不能访问/data/test目录及其下所有文件

  • user3增加附加组

usermod user3 -G user1

  • user1组(还是user1用户?)不能访问目录及其所有文件

setfacl -R -m g:user1:0 /data/test

setfacl -R -m u:user1:0 /data/test

(5)、清理/data/test目录及其下所有文件的acl权限

setfacl -R -b /data/test

你可能感兴趣的:(第二周作业)