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

相关推荐

  • 推荐-DNS BIND初探

    DNS BIND DNS BIND 正向解析 反向解析 从服务器 子域授权 转发 view DNS 什么是DNS? DNS是domain name system,域名系统的简写,负责实现域名与IP的转换。 DNS的功能是什么? DNS能够将IP地址与域名相互双向转换,能够实现域名访问。 DNS的历史:  1. 初期网络…

    2016-04-19
  • 抓包获取QQ好友IP地址

    作者:网海过客 原文连接:https://www.chinasa.net/archives/326.html 原理:通过抓包软件,抓取QQ进程,向QQ好向发送UDP数据包,获取QQ好友IP地址 抓包软件:科来网络分析系统 步骤: 1、打开抓包软件,选择网卡,本地进程分析。 2、向QQ好友发起语音通话 3、在抓包软件里,找到QQ进程,数据包,过滤UDP协议,在…

    Linux干货 2017-06-30
  • PHP通过Thrift操作Hbase

    HBase是一个开源的NoSQL产品,它是实现了Google BigTable论文的一个开源产品,和Hadoop和HDFS一起,可用来存储和处理海量column family的数据。官方网址是:http://hbase.apache.org 一 、HBase访问接口 1.  Native Java API,最常规和高效的访问方式,适合Hadoop …

    Linux干货 2015-05-18
  • Linux-第一周作业

    1.计算机组成及其功能 计算机主要分为三部分: A、输入单元:包括键盘、鼠标、扫描仪、手写板、触摸屏等。 B、中央处理器(CPU):含有算术逻辑、控制、记忆等单元。 C、输出单元:例如屏幕、打印机等。 我们通过输入设备(如鼠标与键盘)来将一些数据输入到PC里面,然后再由PC的功能处理成为图表或文章等信息后,将结果传输到输出设备,如屏幕或打印机上面,这是计算机…

    Linux干货 2016-07-07
  • linux的基础小命令

    1、ifconfig,显示主机的IP地址 2、echo 用法echo [short-option]… [string]…     -n:不进行换行     string可以使用单引号或双引号引用变量,单引号变量内容不会替换,双引号会替换  &nb…

    Linux干货 2016-10-30

评论列表(1条)

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

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