文件系统管理及用户管理之练习

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

# 方式一
[root@CentOS8 data]# ll -d /etc/[^a-Z][a-Z]* 

# 方式二
[root@CentOS8 boot]# ll -d /etc/[^[:alpha:]][[:alpha:]]*

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

[root@CentOS8 ~]# mkdir -p /tmp/mytest1; cp -rf /etc/p*[^0-9] /tmp/mytest1

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

# 方式一
[root@CentOS7 ~]# cat /etc/issue|tr [:lower:] [:upper:] >> /tmp/issue.out
[root@CentOS7 ~]# cat /tmp/issue.out
\S
KERNEL \R ON AN \M

# 方式二
[root@CentOS8 mytest1]# tr [:lower:] [:upper:] < /etc/issue >> /tmp/issue.out


# 方式三
[21:28:49 root@CentOS7 ~]# tr -t [a-z] [A-Z] </etc/issue >/tmp/issue.out
[21:29:26 root@CentOS7 ~]# cat /tmp/issue.out 
\S
KERNEL \R ON AN \M

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

  • 用户管理
    • 用户创建:useradd
    • 用户信息修改:usermod
    • 删除用户:userdel
    • 密码管理:passwd、chage
  • 用户组管理
    • 创建用户组:groupadd
    • 修改用户组信息:groupmod
    • 删除用户组:groupdel

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

[root@CentOS8 data]# groupadd -g 2019 distro
[root@CentOS8 data]# getent group distro
distro:x:2019:

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

[root@CentOS8 data]# useradd -u 1005 -g distro mandriva

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

[root@CentOS8 data]# useradd -u 1100 -d /home/linux mageia
[root@CentOS8 data]# getent passwd mageia
mageia:x:1100:1100::/home/linux:/bin/bash

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

# 给用户设置密码
[root@CentOS8 data]# echo mageia:mageedu|chpasswd 

# 设置用户密码7天后过期
[21:34:21 100 root@CentOS8 ~]# chage -M 7 mageia
[21:34:33 101 root@CentOS8 ~]# getent shadow mageia
mageia:$6$Ydg6R/.Ac3$VCp67n4Rium5UnhFNQtTh/nl4lq9xCjWCW1fN/7yevdzAJl0glJWXXjmJxEkhUe7Si1z/h069Ceg4e4u4RFlD0:18892:0:7:7:::
# 设置密码
[root@CentOS8 data]# echo mageedu |passwd --stdin mageia
Changing password for user mageia.
passwd: all authentication tokens updated successfully.

# 设置账户有效期
[root@CentOS8 data]# passwd -x 7 mageia
Adjusting aging data for user mageia.
passwd: Success

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

[root@CentOS8 data]# userdel mandriva

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

[root@CentOS8 data]# groupadd peguin;useradd -u 2002 -g distro -G peguin slackware
[root@CentOS8 data]# getent passwd slackware
slackware:x:2002:2019::/home/slackware:/bin/bash
[root@CentOS8 data]# id slackware
uid=2002(slackware) gid=2019(distro) groups=2019(distro),2020(peguin)

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

[root@CentOS8 data]# usermod -s /bin/tcsh slackware
[root@CentOS8 data]# getent passwd slackware
slackware:x:2002:2019::/home/slackware:/bin/tcsh

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

[22:00:28 206 root@CentOS8 data]# groups slackware
slackware : distro peguin

[21:58:15 202 root@CentOS8 data]# groupadd admins

[22:02:08 210 root@CentOS8 data]# usermod -aG admins -s /sbin/nologin slackware

[22:02:55 211 root@CentOS8 data]# groups slackware
slackware : distro peguin admins
[22:08:17 216 root@CentOS8 data]# getent passwd slackware
slackware:x:2002:2019::/home/slackware:/sbin/nologin


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

# 1.创建用户
# 方式一:
[22:12:17 218 root@CentOS8 data]# useradd user1
[22:12:17 218 root@CentOS8 data]# useradd user2
[22:12:17 218 root@CentOS8 data]# useradd user3

# 方式二
[22:12:17 218 root@CentOS8 data]# echo user{1..3}|xargs -n1 useradd


# 2.在/data/下创建目录test
[22:15:09 224 root@CentOS8 data]# mkdir -p /data/test

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

[22:16:16 226 root@CentOS8 data]# ll -d /data/test
drwxr-xr-x. 2 root root 6 Sep 21 22:15 /data/test

[22:16:24 227 root@CentOS8 data]# chown user1.user1 /data/test

[22:16:41 228 root@CentOS8 data]# ll -d /data/test
drwxr-xr-x. 2 user1 user1 6 Sep 21 22:15 /data/test

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

[22:18:44 231 root@CentOS8 data]# setfacl -m u:user2:rw /data/test
[22:19:03 232 root@CentOS8 data]# 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,设置所有用户都不可删除1.sh,2.sh文件、除了user1及root之外,所有用户都不可删除a3.sh, a4.sh

[22:26:22 9 user1@CentOS8 ~]$ touch /data/test/a{1..4}.sh
[22:26:41 10 user1@CentOS8 ~]$ tree /data
/data
└── test
    ├── a1.sh
    ├── a2.sh
    ├── a3.sh
    └── a4.sh

[22:37:03 234 root@CentOS8 data]# chattr +i /data/test/a{1,2}.sh
[22:37:10 235 root@CentOS8 data]# chmod o+t /data/test

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

# 添加附加组user1
[21:47:25 115 root@CentOS8 test]# usermod -aG user1 user3
[21:47:39 116 root@CentOS8 test]# id user3
uid=1103(user3) gid=1103(user3) groups=1103(user3),1101(user1)


[21:57:35 130 root@CentOS8 test]# setfacl -m u:user1:- /data/test


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

[21:57:35 130 root@CentOS8 test]# setfacl -R -b /data/test
[21:57:46 131 root@CentOS8 test]# getfacl /data/test
getfacl: Removing leading '/' from absolute path names
# file: data/test
# owner: user1
# group: user1
user::-wx
group::r-x
other::r-x

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值