做业2

2021年11月23日 阅读数:3
这篇文章主要向大家介绍做业2,主要内容包括基础应用、实用技巧、原理机制等方面,希望对大家有所帮助。

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


二、复制/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/mytest1git


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


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

(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 mandriva
uid=1005(mandriva) gid=2019(distro) groups=2019(distro)ui

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

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

(6)、建立用户slackware,其ID号为2002,基本组为distro,附加组peguin;
[root@localhost ~]# groupadd peguin
[root@localhost ~]# useradd -u 2002 -g distro -G peguin slackware
[root@localhost ~]# id 2002
uid=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 2002
slackware:x:2002:2019::/home/slackware:/bin/tcshit

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

(1)、目录/data/test属主、属组为user1
mkdir /data/test -p
chown -R user1:user1 /data/test/
(2)、在目录属主、属组不变的状况下,user2对文件有读写权限
[root@localhost ~]# setfacl -m u:user2:rw- /data/test/
[root@localhost ~]# ll /data/
total 0
drwxrwxr-x+ 2 user1 user1 6 Aug 31 21:47 test
[root@localhost ~]# setfacl -m u:user2:rw- /data/test/
[root@localhost ~]# ll /data/
total 0
drwxrwxr-x+ 2 user1 user1 6 Aug 31 21:47 test
[root@localhost ~]# getfa
getfacl   getfattr  
[root@localhost ~]# 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-xclass


(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

上一篇: 第七周
下一篇: 第六周