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

相关推荐

  • MHA+keepalived 高可用MYSQL集群

    一、MHA简介 二、试验环境及要求 三、部署MHA 四、测试MHA集群功能 一、MHA简介     MHA(Master High Availability)目前在MySQL高可用方面是一个相对成熟的解决方案。在MySQL故障切换过程中,MHA能做到在0~30秒之内手动或自动(结合脚本)完成数据库的故障切换操作,并且在…

    2017-02-25
  • useradd的学习小结

    1、作用 创建一个新的用户账号或者更新创建用户时的默认设置。 2、语法 有两种语法格式,第一种是创建新用户时,为新用户设置属性,而不完全使用/etc/default/useradd默认设置的内容;第二种是设置/etc/default/useradd的内容,即设置创建新用户时,新用户具有的默认属性。 (1)useradd [选项 属性] 用户名 如果不加选项,…

    2017-07-22
  • 03葵花宝典之linux用户

    介绍了linux上有关用户和组的相关命令及配置文件

    2018-03-16
  • 学习了点命令

    什么是shell 它提供了用户与内核进行交互操作的一种接口shell它接受用户输入的命令并把它送入内核去执行 shell也被称为Linux的命令解释器 shell是一种高级程序设计 语言 查看当前系统使用了那个shell            &nb…

    Linux干货 2017-07-13
  • 编译内核

     编译内核: 步骤: (1) 准备好开发环境 (2) 获取目标主机上硬件设备的相关信息 (3) 获取目标主机系统功能的相关信息         例如:需要启用相应的文件系统 (4) 获取内核源代码包 www.kernel.org  

    Linux干货 2018-01-01
  • Tomcat基于memcached会话共享

    安装两台memcache,基于tomcat做会话同步;(只对动态内容缓存,用于追踪用户会话) 前提:两个tomcat节点:172.16.100.7(tomcatA.magedu.com),172.16.100.8(tomcatB.magedu.com)两个memcached节点:172.16.100.9, 172.16.100.10一个负载均衡节点:172.…

    2017-05-25

评论列表(1条)

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

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