Linux常用命令练习
1.显示/etc目录下,以非字母开头,后面跟了一个字母以及其它任意长度任意字符的文件或目录
[root@node1 etc]# ls /etc/|grep "^[^[:alpha:]][[:alpha:]].*"
3g333.txt
2、复制/etc目录下所有以p开头,以非数字结尾的文件或目录到/tmp/mytest1目录中
[root@node1 ~]# mkdir /tmp/mytest1
[root@node1 ~]# cp /etc/p*[^[:digit:]] /tmp/mytest1/
3、将/etc/issue文件中的内容转换为大写后保存至/tmp/issue.out文件中
[root@node1 ~]# cat /etc/issue | tr a-z A-Z >> /tmp/issue.out
[root@node1 ~]# cat /tmp/issue.out
\S
KERNEL \R ON AN \M
4、请总结描述用户和组管理类命令的使用方法并完成以下练习:
groupadd:添加组
groupadd [选项] group_name
-g GID:指定GID;
-r:创建系统组;
groupmod:修改组属性
groupmod [选项] GROUP
-g GID:修改GID;
-n new_name:修改组名;
groupdel:删除组
groupdel [选择] GROUP
useradd:创建用户
useradd [选项] 登录名
-u,–uid UID:指明UID;
-g,–gid GROUP:指定基本ID;
-G,–groups GROUP1 [,GROUP2,…[,GROUPN]]:指明用户所属的附加组,多组用逗号分隔;
-c,–comment COMMENT:指明注释信息;
-d,–home HOME_DIR:以指定的路径为用户的家目录;通过复制/etc/skel;
-s,–shell SHELL:指定用户默认shell,可用的所有shell列表存储在/etc/shells文件中;
-r,–system:创建系统用户;
创建用户时的诸多默认设定配置文件为/etc/login.defs
-useradd -D:显示创建用户的默认配置;
-useradd -D 选项:修改默认选项的值;修改的结果保存于/etc/default/useradd文件中
usermod:修改用户属性
usermod [选项] 登录
-u,–uid UID:修改用户的ID为此处指定的新UID;
-g,–gid GROUP:修改用户所属的基本组;
-G,–groups GROUP1[,GROUP2,…[,GROUPN]],原来附加组会被覆盖;
-a,–append:与-G一同使用,用于为用户追加新的附加组;
-c,–comment COMMENT:修改注释信息;
-d,–home HOME_DIR:修改用户的家目录,用户原有的文件不会被转移至新位置;
-m,–move-home:只能与-d选项一同使用,用于将原有的家目录移动为新的家目录;
-l,–login NEW_LOGIN:修改用户名;
-s,–shell SHELL:修改用户默认shell;
-L,–lock:锁定用户密码,即在用户原来的密码字符串之前添加一个"!";
-u,–unlock:解锁用户的密码;
userdel:删除用户
userdel [选项] 登录
-r:删除用户时一并删除其家目录;
passwd:
-l,-u:锁定和解锁用户;
-d:清除用户密码串;
-e DATE:过期期限,日期;
-i DAYS:非活动期限;
-n DAYS:密码最短使用期限;
-x DAYS:密码最长使用期限;
-w DAYS:警告期限
--stdin:echo “PASSWORD” | passwd --stdin USERNAME
gpasswd:
gpasswd [选项] group
-a USERNAME:向组添加用户;
-d USERNAME:从组中移除用户;
chage:更改用户密码过期信息
chage [选项] 登录名
(1)、创建组distro,其GID为2019;
[root@node1 ~]# groupadd -g 2019 distro
(2)、创建用户mandriva, 其ID号为1005;基本组为distro;
[root@node1 ~]# useradd -u 1005 -g distro mandriva
(3)、创建用户mageia,其ID号为1100,家目录为/home/linux;
[root@node1 ~]# useradd -u 1100 -d /home/linux mageia
(4)、给用户mageia添加密码,密码为mageedu,并设置用户密码7天后过期
[root@node1 ~]# echo mageedu | passwd --stdin mageia
Changing password for user mageia.
passwd: all authentication tokens updated successfully.
[root@node1 ~]# passwd -x 7 mageia
Adjusting aging data for user mageia.
passwd: Success
[root@node1 ~]# chage -l mageia
Last password change : Jul 18, 2021
Password expires : Jul 25, 2021
Password inactive : never
Account expires : never
Minimum number of days between password change : 0
Maximum number of days between password change : 7
Number of days of warning before password expires : 7
(5)、删除mandriva,但保留其家目录;
[root@node1 ~]# userdel mandriva
[root@node1 ~]# ls -ld /home/mandriva/
drwx------. 2 1005 distro 62 Jul 18 16:27 /home/mandriva/
(6)、创建用户slackware,其ID号为2002,基本组为distro,附加组peguin;
[root@node1 ~]# groupadd peguin
[root@node1 ~]# useradd -u 2002 -g distro -G peguin slackware
(7)、修改slackware的默认shell为/bin/tcsh;
[root@node1 ~]# usermod --shell /bin/tcsh slackwareh
[root@node1 ~]# grep slack /etc/passwd
slackware:x:2002:2019::/home/slackware:/bin/tcsh
(8)、为用户slackware新增附加组admins,并设置不可登陆。
[root@node1 ~]# usermod -G admins --shell /sbin/nologin slackware
[root@node1 ~]# su - slackware
This account is currently not available.
5、创建用户user1、user2、user3。在/data/下创建目录test
[root@node1 test]# useradd user1
[root@node1 test]# useradd user2
[root@node1 test]# useradd user3
[root@node1 test]# mkdir /data/test
(1)、目录/data/test属主、属组为user1
[root@node1 test]# chown user1.user1 /data/test
(2)、在目录属主、属组不变的情况下,user2对文件有读写权限
[root@node1 test]# 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
[root@node1 test]# su - user1
[user1@node1 ~]$ touch /data/test/a{1..4}.sh
[user1@node1 ~]$ exit
[user1@node1 ~]$ cd /data/test
[root@node1 test]# chattr +i a{1..2}.sh
[root@node1 test]# lsattr
----i----------- ./a1.sh
----i----------- ./a2.sh
---------------- ./a3.sh
---------------- ./a4.sh
[root@node1 test]# rm -f a1.sh
rm: cannot remove ‘a1.sh’: Operation not permitted
[root@node1 test]# su - user2
[user2@node1 ~]$ rm -f /data/test/a3.sh
rm: cannot remove ‘/data/test/a3.sh’: Permission denied
(4)、user3增加附加组user1,同时要求user1不能访问/data/test目录及其下所有文件
[root@node1 test]# usermod -G user3 user1
[root@node1 ~]# chmod u=--- /data/test/
[root@node1 ~]# su - user1
[user1@node1 ~]$ ls /data/test/
ls: cannot open directory /data/test/: Permission denied
(5)、清理/data/test目录及其下所有文件的acl权限
[root@node1 ~]# setfacl -b /data/test/
[root@node1 ~]# setfacl -b /data/test/*
[root@node1 ~]# getfacl /data/test/
getfacl: Removing leading '/' from absolute path names
# file: data/test/
# owner: user1
# group: user1
user::---
group::r-x
other::r-x