作业2

网友投稿 209 2022-11-07

作业2

1、显示/etc目录下,以非字母开头,后面跟了一个字母以及其它任意长度任意字符的文件或目录ls只支持通配符,不支持正则,需要grep,awk等进一步配合[root@localhost etc]# ls -a /etc/ | grep -E  "^[^[:alpha:]][[:alpha:]]+.*"

2、复制/etc目录下所有以p开头,以非数字结尾的文件或目录到/tmp/mytest1目录中。显示:ls -a /etc | grep -E "^p.*[^[:digit:]]$"  ls -ad /etc/p*[!0-9]cp -ar `ls -ad /etc/p*[!0-9]` /tmp/mytest1

3、将/etc/issue文件中的内容转换为大写后保存至/tmp/issue.out文件中cat /etc/issue | tr 'a-z' 'A-Z' > /tmp/issue.out

4、请总结描述用户和组管理类命令的使用方法并完成以下练习:名称       useradd - 创建一个新用户或更新默认新用户信息       usermod - 修改一个用户账户       userdel - 删除用户账户和相关文件       groupadd - 创建一个新组       groupmod - modify a group definition on the system       groupdel - 删除一个组

(1)、创建组distro,其GID为2019;groupadd -g 2019 distro cat /etc/group(2)、创建用户mandriva, 其ID号为1005;基本组为distro;[root@localhost mytest1]# useradd -u 1005 -g distro mandriva[root@localhost mytest1]# id mandrivauid=1005(mandriva) gid=2019(distro) groups=2019(distro)

(3)、创建用户mageia,其ID号为1100,家目录为/home/linux;[root@localhost mytest1]# useradd -u 1100 -d /home/linux mageia

(4)、给用户mageia添加密码,密码为mageedu,并设置用户密码7天后过期echo mageedu |passwd --stdin mageiapasswd -x 7 mageiacat /etc/shadow | grep mageia(5)、删除mandriva,但保留其家目录;[root@localhost ~]# userdel mandriva[root@localhost ~]# ll /home/

(6)、创建用户slackware,其ID号为2002,基本组为distro,附加组peguin;[root@localhost ~]# groupadd peguin[root@localhost ~]# useradd -u 2002 -g distro -G peguin slackware[root@localhost ~]# id 2002uid=2002(slackware) gid=2019(distro) groups=2019(distro),2020(peguin)(7)、修改slackware的默认shell为/bin/tcsh; usermod -s /bin/tcsh slackware[root@localhost ~]# cat /etc/passwd | grep 2002slackware:x:2002:2019::/home/slackware:/bin/tcsh

(8)、为用户slackware新增附加组admins,并设置不可登陆。[root@localhost ~]# usermod -s /sbin/nologin -aG admins slackware[root@localhost ~]# cat /etc/passwd | grep 2002slackware:x:2002:2019::/home/slackware:/sbin/nologin[root@localhost ~]# id 2002uid=2002(slackware) gid=2019(distro) groups=2019(distro),2020(peguin),2021(admins)5、创建用户user1、user2、user3。在/data/下创建目录test[root@localhost ~]# echo user{1..3}| xargs -n1 useradd[root@localhost ~]# id user1uid=2003(user1) gid=2003(user1) groups=2003(user1)[root@localhost ~]# id user2uid=2004(user2) gid=2004(user2) groups=2004(user2)[root@localhost ~]# id user3uid=2005(user3) gid=2005(user3) groups=2005(user3)-n1 一个个参数传

(1)、目录/data/test属主、属组为user1mkdir /data/test -pchown -R user1:user1 /data/test/(2)、在目录属主、属组不变的情况下,user2对文件有读写权限[root@localhost ~]# setfacl -m u:user2:rw- /data/test/[root@localhost ~]# ll /data/total 0drwxrwxr-x+ 2 user1 user1 6 Aug 31 21:47 test[root@localhost ~]# setfacl -m u:user2:rw- /data/test/[root@localhost ~]# ll /data/total 0drwxrwxr-x+ 2 user1 user1 6 Aug 31 21:47 test[root@localhost ~]# getfagetfacl   getfattr  [root@localhost ~]# getfacl /data/test/getfacl: Removing leading '/' from absolute path names# file: data/test/# owner: user1# group: user1user::rwxuser:user2:rw-group::r-xmask::rwxother::r-x

(3)、user1在/data/test目录下创建文件a1.sh, a2.sh, a3.sh, a4.sh,设置所有用户都不可删除1.sh,2.sh文件、除了user1及root之外,所有用户都不可删除a3.sh, a4.sh[root@localhost ~]# su user1[user1@localhost root]$ cd /data/test/[user1@localhost test]$ touch a{1..4}.sh

[root@localhost ~]# chattr +i /data/test/a1.sh [root@localhost ~]# chattr +i /data/test/a2.sh

chmod o+t /data/test/a3.sh  chmod o+t /data/test/a4.sh

chattr命令的用法:chattr [ -RV ] [ -v version ] [ mode ] files…最关键的是在[mode]部分,[mode]部分是由+-=和[ASacDdIijsTtu]这些字符组合的,这部分是用来控制文件的属性。+ :在原有参数设定基础上,追加参数。- :在原有参数设定基础上,移除参数。= :更新为指定参数设定。i:设定文件不能被删除、改名、设定链接关系,同时不能写入或新增内容

sticky bit: 该位可以理解为防删除位.

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

[root@localhost ~]# gpasswd -a user3 user1

[root@localhost ~]# setfacl -m u:user1:--- /data/test/(5)、清理/data/test目录及其下所有文件的acl权限chmod o-t /data/test/a4.sh chmod o-t /data/test/a3.sh setfacl -bR /data/test/chattr -i /data/test/a1.sh chattr -i /data/test/a2.sh

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:了解Linux通用的双向循环链表
下一篇:智汇华云 | ArSDN之分布式路由及浮动IP简介
相关文章

 发表评论

暂时没有评论,来抢沙发吧~