马哥教育网络班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

相关推荐

  • N21-天天-第九周课程练习

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #!/bin/bash awk -F: '$NF~"/sbin/nologin" {shell++} $NF!~&qu…

    Linux干货 2016-09-01
  • 马哥教育网络班21期第七周作业

    1、创建一个10G分区,并格式为ext4文件系统;   (1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl;   (2) 挂载至/data/mydata目录,要求挂载时禁止程序自动运行,且不更新文件的访问时间戳; [root@localhost ~]#…

    Linux干货 2016-10-09
  • 基于Keepalived构建高可用集群配置实例(HA Cluster)

    什么是集群 简单的讲集群(cluster)就是一组计算机,它们作为一个整体向用户提供一组网络资源。这些单个的计算机系统就是集群的节点(node)。一个理想的集群是,用户从来不会意识到集群系统底层的节点,在他/她们看来,集群是一个系统,而非多个计算机系统。并且集群系统的管理员可以随意增加和删改集群系统的节点。 关于更详细的高可用集群我们在后面再做详解…

    Linux干货 2016-11-03
  • 进程理论和相关工具的使用

    内核的功用 进程管理、文件系统、网络功能、内存管理、驱动程序、安全功能等     Process: 运行中的程序的一个副本,是被载入内存的一个指令集合 进程ID(Process ID,PID)号码被用来标记各个进程     UID、GID、和SELinux语境决定对文件…

    Linux干货 2017-08-28
  • 马哥教育网络班21期第8周课程练习

    1、请描述网桥、集线器、二层交换机、三层交换机、路由器的功能、使用场景与区别。 网桥也叫桥接器,是连接两个局域网的一种存储/转发设备,用来连接不同网段。 集线器称为“Hub”,主要功能是对接收到的信号进行再生整形放大,以扩大网络的传输距离,同时把所有节点集中在以它为中心的节点上。 二层交换机工作于OSI模型的第2层(数据链路层),可识别数据包中的MAC地址信…

    Linux干货 2016-09-19
  • shell脚本练习

    习题1:打印99乘法表 #!/bin/bash # for ((j=1;j<=9;j++)) do for ((i=1;i<=j;i++)) do echo -e -n “${i}x${j}=$[${i}*${j}]\t” done echo done 习题2:写一个脚本(1)创建目录/tmp/dir-当前日期时间;例如/tmp/dir-2015…

    Linux干货 2017-05-22

评论列表(1条)

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

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