文件管理以及IO重定向及用户组权限管理
1、显示/etc目录下,以非字母开头,后面跟了一个字母以及其它任意长度任意字符的文件或目录
ls -d /etc [^[:alpha:]][[:alpha:]]*
[:alpha:]=任意大小写字母,[[:appha:]]=[任意大小写字母],^表示取反,不匹配列表中的所包含的字符信息,*表示匹配列表中零个或多个字符。
2、复制/etc目录下所有以p开头,以非数字结尾的文件或目录到/tmp/mytest1目录中。
- 在/tmp目录下创建一个mytest1目录
mkdir /tmp/mytest1
- 复制/etc目录下所有以p开头,以非数字结尾的文件或目录到/tmp/mytest1目录中
cp -a -r /etc/p*[^[:digit:]] /tmp/mytest1
cp -a 备份;-r 递归。
- 验证
ls -a /tmp/mytest1/p*[^[:digit:]]
3、将/etc/issue文件中的内容转换为大写后保存至/tmp/issue.out文件中
- 在/tmp 目录下创建issue.out文件
[root@CentOS8 tmp]#touch issue.out
- 利用输入重定向<,从/tmp/issue文件内容导入STDIN,代替当前终端的输入设备,tr ‘[:lower:]’ ‘[:upper:]’ < /etc/issue;再利用输出重定向,将转换结果存至指定的/tmp/issue.out文件中。
tr '[:lower:]' '[:upper:]' < /etc/issue > /tmp/issue.out
4、总结描述用户和组管理类命令的使用方法
(1)创建组distro,其GID为2019
[root@CentOS8 ~]#groupadd -g 2109 distro
[root@CentOS8 ~]#cat /etc/group
(2)创建用户mandriva, 其ID号为1005;基本组为distro;
[root@CentOS8 ~]#useradd -u 1005 -g distro mandriva
(3)创建用户mageia,其ID号为1100,家目录为/home/linux;
[root@CentOS8 ~]#useradd -u 1100 -d /home/linux mageia
(4) 给用户mageia添加密码,密码为mageedu,并设置用户密码7天后过期
echo 'mageedu' | passwd --stdin mageia
–stdin:从标准输入通过管接受用户密码,Ubuntu中无此选项
登录验证
[root@CentOS8 ~]#chage -M 7 -E 7 mageia
chage 可以修改用户密码策略,chage [OPTION]… LOGIN
常见选项:
-d LAST_DAY #更改密码的时间
-m --mindays MIN_DAYS
-M --maxdays MAX_DAYS
-W --warndays WARN_DAYS
-I --inactive INACTIVE #密码过期后的宽限期
-E --expiredate EXPIRE_DATE #用户的有效期
-l 显示密码策略
-M 7 ,表示mageia用户使用此密码最长时间为7天,-E 7 表示
mageia用户有效期为7天。
(5)删除mandriva,但保留其家目录;
[root@CentOS8 ~]#userdel mandriva
6)创建用户slackware,其ID号为2002,基本组为distro,附加组peguin;
为用户指明附加组,组必须事先存在
groupadd -g 1001 peguin
-g 为用户指明基本组,-G为用户指明附加组
[root@CentOS8 ~]#useradd -u 2002 -g distro -G peguin slackware
(7)修改slackware的默认shell为/bin/tcsh;
[root@CentOS8 ~]#usermod -s /bin/tcsh slackware
(8)为用户slackware新增附加组admins,并设置不可登陆。
[root@CentOS8 ~]#groupadd admins
[root@CentOS8 ~]#usermod -G admins -s /sbin/nologin slackware
5、创建用户user1、user2、user3。在/data/下创建目录test
(1)目录/data/test属主、属组为user1
[root@CentOS8 data]#chown user1:user1 /data/test
(2)在目录属主、属组不变的情况下,user2对文件有读写权限
[root@CentOS8 data]#chmod o=wr /data/test
(3)user1在/data/test目录下创建文件a1.sh, a2.sh, a3.sh, a4.sh,设置所有用户都不可删除a1.sh,a2.sh文件、除了user1及root之外,所有用户都不可删除a3.sh, a4.sh
[root@CentOS8 test]#chattr +i a1.sh a2.sh
设置文件特殊性
[root@CentOS8 data]#chmod o+t /data/test/a3.sh /data/test/a4.sh
sticky权限:只有文件的所有者或者root可以删除文件
检验:
user2无法删除
user1删除
(4)user3增加附加组user1,同时要求user1不能访问/data/test目录及其下所有文件
[root@CentOS8 test]#usermod -G user1 user3
[root@CentOS8 test]#setfacl -m u:user1:0 /data/test
(5)清理/data/test目录及其下所有文件的acl权限
[root@CentOS8 test]#setfacl -R -b /data