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 mandriva
uid=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 mageia
passwd -x 7 mageia
cat /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 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/tcsh

(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)
5、创建用户user1、user2、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 一个个参数传

(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-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