马哥教育网络班20期+第3周课程练习

1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。

[root@localhost ~]# who | cut -d" " -f1 | sort -u

2、取出最后登录到当前系统的用户的相关信息。

[root@localhost ~]# w | tail -1

3、取出当前系统上被用户当作其默认shell的最多的那个shell。

[root@localhost ~]# cut -d: -f7 /etc/passwd | uniq -c | sort -n | tail -1 | cut -d" " -f7

4、将/etc/passwd中的第三个字段数值最大的后10个用户的信息全部改为大写后保存至/tmp/maxusers.txt文件中。

[root@localhost ~]# sort -t: -n -k 3 /etc/passwd | tail -10 | tr 'a-z' 'A-Z' > /tmp/maxusers.txt

5、取出当前主机的IP地址,提示:对ifconfig命令的结果进行切分。

[root@localhost ~]# ifconfig | head -2 | tail -1 | cut -d: -f2 | cut -d" " -f1

6、列出/etc目录下所有以.conf结尾的文件的文件名,并将其名字转换为大写后保存至/tmp/etc.conf文件中。

[root@localhost ~]# ls /etc/*.conf | tr 'a-z' 'A-Z' && ls /etc/*.conf | tr 'a-z' 'A-Z' > /tmp/etc.c

7、显示/var目录下一级子目录或文件的总个数。

[root@mouse015110 ~]# ll /var | grep -v "^total" | wc -l

8、取出/etc/group文件中第三个字段数值最小的10个组的名字。

[root@mouse015110 ~]# sort -n -t: -k3 /etc/group | head -10 | cut -d: -f1

9、将/etc/fstab和/etc/issue文件的内容合并为同一个内容后保存至/tmp/etc.test文件中。

[root@mouse015110 ~]# cat /etc/fstab > /tmp/etc.test && cat /etc/issue >> /tmp/etc.test

10、请总结描述用户和组管理类命令的使用方法并完成以下练习:

    1)、用户创建:useradd(增加用户是系统会自动增加一个与其对应的私有组)

            useradd [options] LOGIN
                -u UID: [UID_MIN, UID_MAX], 定义在/etc/login.defs                
                -g GID:指明用户所属基本组,可为组名,也可以GID;                                    
                -c "COMMENT":用户的注释信息;                
                -d /PATH/TO/HOME_DIR: 以指定的路径为家目录(此目录避免事先存在);                
                -G GROUP1[,GROUP2,...[,GROUPN]]]:为用户指明附加组;组必须事先存在;                
                -r:创建系统用户                    
                    CentOS 6: ID<500
                    CentOS 7: ID<1000
                    默认值设定:/etc/default/useradd文件中
                 -D:变更预设值                     
                 -s SHELL:指定用户登入后所使用的shell

    2)、组创建:groupadd         

            groupadd [OPTION]... group_name
                -g GID: 指明GID号;[GID_MIN, GID_MAX]            
                -r: 创建系统组;                
                CentOS 6: ID<500
                CentOS 7: ID<1000

    3)、查看用户相关ID信息:id        

            id [OPTION]... [USER]
                -u: UID            
                -g: GID            
                -G: Groups            
                -n: Name

    4)、切换用户或以其他用户身份执行命令:su       

            su [options...] [-] [user [args...]]
            切换用户的方式:
                su UserName:非登录式切换,即不会读取目标用户的配置文件;
                su - UserName:登录式切换,会读取目标用户的配置文件;完全切换;
                Note:root su至其他用户无须密码;非root用户切换时需要密码;
            换个身份执行命令:
                su [-] UserName -c 'COMMAND'
            选项:
                -l:“su -l UserName”相当于“su - UserName”

    5)、用户属性修改:usermod        

            usermod [OPTION] login
                -u UID: 新UID            
                -g GID: 新基本组            
                -G GROUP1[,GROUP2,...[,GROUPN]]]:新附加组,原来的附加组将会被覆盖;若保留原有,则要同时使用-a选项,表示append;            
                -s SHELL:新的默认SHELL;            
                -c 'COMMENT':新的注释信息;            
                -d HOME: 新的家目录;原有家目录中的文件不会同时移动至新的家目录;若要移动,则同时使用-m选项;            
                -L: lock指定用户            
                -e YYYY-MM-DD: 指明用户账号过期日期;            
                -f INACTIVE: 设定非活动期限;

    6)、给用户添加密码:passwd       

            passwd [OPTIONS] UserName: 修改指定用户的密码,仅root用户权限
            passwd: 修改自己的密码;普通用户只能改自己的密码
                -l: 锁定指定用户                
                -u: 解锁指定用户                
                -n mindays: 指定最短使用期限                
                -x maxdays:最大使用期限                
                -w warndays:提前多少天开始警告                
                -i inactivedays:非活动期限;                
                --stdin:从标准输入接收用户密码;(echo "PASSWORD" | passwd --stdin USERNAME)

    7)、删除用户:userdel       

            userdel [OPTION]... login
                -r: 删除用户家目录;

    8)、组属性修改:groupmod       

            groupmod [OPTION]... group
                -n group_name: 新名字            
                -g GID: 新的GID;

    9)、组删除:groupdel       

            groupdel GROUP

    

    10)、组密码:gpasswd        

            gpasswd [OPTION] GROUP
                -a user: 将user添加至指定组中;附加组            
                -d user: 删除用户user的以当前组为组名的附加组            -A user1,user2,...: 设置有管理权限的用户列表

    11)、修改用户属性:chage        

            chage [OPTION]... LOGIN
                -d LAST_DAY            
                -E, --expiredate EXPIRE_DATE            
                -I, --inactive INACTIVE            
                -m, --mindays MIN_DAYS            
                -M, --maxdays MAX_DAYS            
                -W, --warndays WARN_DAYS

   (1)、创建组distro,其GID为2016;

[root@mouse015110 ~]# groupadd distro -g 2016

   (2)、创建用户mandriva, 其ID号为1005;基本组为distro;

[root@mouse015110 ~]# useradd mandriva -u 1005 -g 2016

   (3)、创建用户mageia,其ID号为1100,家目录为/home/linux;

[root@mouse015110 ~]# useradd megeia -u 1100 -d /home/linux


   (4)、给用户mageia添加密码,密码为mageedu;

[root@mouse015110 ~]# passwd megeia
Changing password for user megeia.
New password: 
BAD PASSWORD: The password is shorter than 8 characters
Retype new password: 
passwd: all authentication tokens updated successfully.

   (5)、删除mandriva,但保留其家目录;

[root@mouse015110 ~]# userdel mandriva


   (6)、创建用户slackware,其ID号为2002,基本组为distro,附加组peguin;

[root@mouse015110 ~]# useradd slackware -u 2002 -g distro -G peguin


   (7)、修改slackware的默认shell为/bin/tcsh;

[root@mouse015110 ~]# usermod slackware -s /bin/tcsh


   (8)、为用户slackware新增附加组admins;

[root@mouse015110 ~]# usermod slackware -G admins


   (9)、为slackware添加密码,且要求密码最短使用期限为3天,最长为180天,警告为3天;

[root@mouse015110 ~]#passwd -n3 -x180 -w3 slackware


   (10)、添加用户openstack,其ID号为3003, 基本组为clouds,附加组为peguin和nova;

[root@mouse015110 ~]# useradd openstack -u 3003 -g clouds -G peguin,nova


   (11)、添加系统用户mysql,要求其shell为/sbin/nologin;

[root@mouse015110 ~]# useradd mysql -s /sbin/nologin


   (12)、使用echo命令,非交互式为openstack添加密码。

[root@mouse015110 ~]# echo "test" | passwd --stdin openstack

原创文章,作者:mouse015110,如若转载,请注明出处:http://www.178linux.com/19778

(0)
mouse015110mouse015110
上一篇 2016-06-26
下一篇 2016-06-26

相关推荐

  • linux-第一周

    inux命令:(type)                  1,集成在bash中的命令,内部命令。依赖于shell类型。                  2,在文件系统路径下有…

    Linux干货 2017-05-20
  • N22-℡浮生.若夢 ╮-第二周作业

    1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。 cp文件复制:       常用选项:     -i:交互式复制,即覆盖之前提醒用户确认;     -f:强制覆盖目标文件;  &n…

    Linux干货 2016-09-06
  • 0804正则表达式作业

    用正则表达式表示IP地址         首先来分析一下,制IP地址是一个32位的二进制数,通常被分割为4个“8位二进制数”(也就是4个字节)。IP地址通常用“点分十进制”表示成(a.b.c.d)的形式,其中,a,b,c,d都是0~255之间的十进制整数。例:点分十进IP地址(1…

    Linux干货 2016-08-10
  • shell脚本实现MD5破解的相关小计

    分享编写shell脚本暴力破解md5的方法 方法一 单个破解法(以10位数为例) #!/bin/bash read -p “please input strings:”string for n in {0..33000} do Md5=`echo $n |md5sum|cut -c 1-10`      …

    Linux干货 2017-03-26
  • Linux的文件压缩、解压之tar的使用

    文件的压缩   一、压缩、解压缩及归档工具 压缩 解压 后缀(压缩后) file-roller 图形操作界面上的使用(略) compress 解压一:uncompress 或compress -d (注:使用上面的解压命令,实际上是在屏幕上打印解压的文件信息,并不是真正上解压到文件,所以需要在命令后面加上“重定向到指定的文件中”,方可完成解压。如:…

    Linux干货 2016-08-18
  • 正则表达式简述

    bashshell中的正则表达式         俗话说,工欲善其事,必先利其器。由于很多Linux的文本处理工具普遍使用到了正则表达式,因此,不理解正则表达式就无法愉快的从事Linux日常系统管理。那什么是正则表达式呢?         正则表达式(Regu…

    Linux干货 2015-05-23

评论列表(1条)

  • 马哥教育
    马哥教育 2016-06-29 15:32

    写的很好,排版也很棒,加油