马哥教育网络班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 22:39
下一篇 2016-06-26 22:39

相关推荐

  • Linux第七周小结

    1、创建一个10G分区,并格式为ext4文件系统 a) 要求其block大小为2048,预留空间百分比为2,卷标为MYDATA,默认挂载属性包含acl; b) 挂载至/data/madata目录,要求挂载时禁止程序自动运行,且不更新文件的访问时间戳; 2、创建一个大小为1G的swap分区,并创建好文件系统,并启用之 3、写一个脚本 a)&…

    2017-08-13
  • 再不自动化就晚啦!优云教你4步打造基于CentOS的产品镜像

    随着Linux程序的增多,软件的安装过程中经常出现如下问题: 1、硬件配置类似或者相同时,批量安装系统和软件,希望实现自动化安装,减少安装时间和人为出错。 2、工程实施人员在不同客户现场进行系统和软件安装(硬件配置不同),由于硬件有差别,不容易实现自动化。 笔者针对以上场景,从提高生产效率,减少误操作的立场,提出如下解决方案,希望能达到抛砖引玉的目的,并能与…

    系统运维 2016-07-16
  • LVM管理

    一、简介 LVM是逻辑盘卷管理(Logical Volume Manager)的简称,它是Linux环境下对磁盘分区进行管理的一种机制,LVM是建立在硬盘和分区之上的一个逻辑层,来提高磁盘分区管理的灵活性。 LVM的工作原理是通过将底层的物理硬盘抽象的封装起来,然后以逻辑卷的方式呈现给上层应用。在传统的磁盘管理机制中,我们的上层应用是直接访问文件系统,从而对…

    Linux干货 2016-09-06
  • shell脚本编程初步

    shell脚本编程初步    随着课程学习的深入,我们已经学习了一些常用的命令,会去解决了一部分简单的问题,但是这不能满足复杂的工作,它可以帮助我执行自动化的常用命令、执行系统管理和故障排除、创建简单的应用程序、处理文本或文件。所以我们开始了shell脚本的编程,帮助我们更好的去完成工作。简单地说,shell编程相当于帮我们之前…

    Linux干货 2016-08-15
  • linux中文本处理工具cat 、less、more、head、tail、cut等使用

    文本内容查看工具:cat和less  cat 使用:查看文件内容          cat  选项      文件        …

    Linux干货 2016-08-08
  • 网卡别名及多网卡配置

    网卡别名 对于要在不同网段环境中使用的设备有很大的帮助。     要使用网卡别名首先要关闭NetworkManager这个服务,防止在后续操作中引起不必要的冲突。 [root@laodeng6 ~]# chkconfig NetworkManager off [root@laod…

    Linux干货 2016-09-06

评论列表(1条)

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

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