1、显示/etc目录下,以非字母开头,后面跟了一个字母以及其它任意长度任意字符的文件或目录
ls -d /etc/[^[:alpha:]][[:alpha:]]*
2、复制/etc目录下所有以p开头,以非数字结尾的文件或目录到/tmp/mytest1目录中。
cp -r /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 [选项] 用户名 默认设定配置文件:/etc/login.defs
-u UID: 指定UID
-g GID: 指定基本组ID(默认值)
-G groups: 指定用户的附加组,多个组之间用逗号分隔
-c “ ”: 指定注释信息
-d 路径: 给用户指定家目录;通过复制/etc/skel此目录并重命名实现的;指定的路径如果事先存在,则不会为用户复制配置文件;
-s SHELL路径 指定用户的默认shell,可用的所有shell列表存储在/etc/shells文件中;
-r 创建系统用户
-D: 显示创建用户的默认配置;(配置文件:/etc/default/useradd)
-D 选项: 修改默认配置选项的值
修改用户属性 # usermod [选项] 用户名
-u UID: 修改用户的UID
-g GID: 修改用户的GID
-a -G groups: 追加新的附加组;不用-a 会覆盖原有的附加组
-d -m 路径: 修改家目录,并移动原来的文件至新目录下;不用-m原文件不会移动
-c 注释: 修改注释信息
-s SHELL路径: 修改用户的默认shell
-l 用户名 用户名: 改用户名
-L 用户名: 锁定用户密码;即在用户原来的密码字符串前面添加一个“!”
-U 用户名: 解锁用户密码
删除用户 # userdel [选项] 用户名 (家目录不会被删除)
-r: 删除用户及其家目录
显示用户的真和有效ID # id [选项] 用户名
-u:只显示有效的UID
-g:只显示用户的基本组ID
-G:只显示用户所属的所有组ID
-n:显示名字而非ID
设置用户密码 # passwd [选项]用户名 # echo “密码”| passwd --stdin 用户名
-l: 锁定用户
-u: 解锁用户(空密码不能被解锁)
-d: 清空密码
-e 日期: 过期期限
-n 天数: 最短使用期限
-x 天数: 最长使用期限
-w 天数: 快过期提醒时间
-i 天数: 过期后至禁用前的非活动天数
-S 用户名: 查询用户密码状态
修改用户密码过期信息 # chage [选项] 用户名
-l: 查看用户密码状态
-d 2021-10-13: 设置最近一次密码修改时间 # chage -d 0 USERNAME (立即改密)
-E 2020-10-13: 设置密码失效时间 # chage -E -1 USERNAME (永远有效)
-m 数字: 设置最短使用期限,期间无法改密
-M 数字: 设置最长使用期限
-W 数字: 设置提醒时间
-I 数字: 设置过期后-禁用前的时间 # chage -I -1 USERNAME (过期后永不禁用)
用户间的切换: switch user
登陆式切换:会通过读取目标用户的配置文件来重新初始化
# su - USERNAME
# su -l USERNAME
非登录式切换:不会读取目标用户的配置文件进行初始化
# su USERNAME
# su - USERNAME - c 'COMMAND' 仅以指定用户的身份运行此处指定的命令
添加组 # groupadd [选项] group_name
-g GID: 指定组ID
-r: 创建系统组
修改组属性 # groupmod [选项] GROUP
-g GID:改组ID
-n new_name: 改组名
删除组 # groupdel [选项] GROUP
管理组# gpasswd [选项] GROUP 给组加密码 (组密码文件/etc/gshadow)
-r: 删除组密码
-a USERNAME: 给组里添加用户
-d USERNAME: 给阻里移除用户
-A USERNAME: 给组里加管理者
-R: 限制用户登入组,只有组中的成员才可以用newgrp加入该组
# newgrp [-] 组名 临时切换指定的组为基本组,用exit退出到原来组
-:会模拟用户重新登录以实现重新初始化其工作环境;
(1)、创建组distro,其GID为2019;
groupadd -g 2019 distro
(2)、创建用户mandriva, 其ID号为1005;基本组为distro;
useradd -u 1005 -g 2019 mandriva
(3)、创建用户mageia,其ID号为1100,家目录为/home/linux;
useradd -u 1100 -d /home/linux mageia
(4)、给用户mageia添加密码,密码为mageedu,并设置用户密码7天后过期
echo “mageedu” | passwd --stdin mageia;passwd -x 7 mageia
(5)、删除mandriva,但保留其家目录;
userdel mandriva
(6)、创建用户slackware,其ID号为2002,基本组为distro,附加组peguin;
groupadd peguin
useradd -u 2002 -g 2019 -G peguin slackware
(7)、修改slackware的默认shell为/bin/tcsh;
usermod -s /bin/tcsh slackware
(8)、为用户slackware新增附加组admins,并设置不可登陆。
groupadd admins
usermod -a -G admins slackware
passwd -l slackware
5、创建用户user1、user2、user3。在/data/下创建目录test
useradd user1;useradd user2;useradd use3
mkdir /data/test
(1)、目录/data/test属主、属组为user1
chown user1:user1 /data/test
(2)、在目录属主、属组不变的情况下,user2对文件有读写权限
setfacl -m u:user2:rw /data/test
(3)、user1在/data/test目录下创建文件a1.sh, a2.sh, a3.sh, a4.sh,设置所有用户都不可删除1.sh,2.sh文件、除了user1及root之外,所有用户都不可删除a3.sh, a4.sh
touch /data/test/a{1,2,3,4}.sh
cd /data/test/
chattr +i a1.sh a2.sh
chmod o+T a3.sh a4.sh
(4)、user3增加附加组user1,同时要求user1不能访问/data/test目录及其下所有文件
usermod -a -G user1 user3
setfacl -m u:user1:- /data/test
(5)、清理/data/test目录及其下所有文件的acl权限
setfacl -Rb /data/test