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

    who | cut -d '' -f1 |sort |uniq

新手上路       --linux基础命令使用_Linux

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

    last |head -1 

新手上路       --linux基础命令使用_Linux_02

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

   cat /etc/passwd | cut -d":" -f7 /etc/passwd | uniq -c | sort -n | tail -1

新手上路       --linux基础命令使用_Linux_03

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

   cat /etc/passwd |sort -n -k 3 -t: | tail -n 10 | tr 'a-z' 'A-Z' >> /tmp/maxuser.txt

新手上路       --linux基础命令使用_Linux_04

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

    ifconfig | grep '[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}'

    hostname -i

新手上路       --linux基础命令使用_linux_05

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

    find /etc/ -name "*.conf"  | tr 'a-z' 'A-Z' > /tmp/etc.conf

新手上路       --linux基础命令使用_Linux_06

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

    ls -d /var/* | wc -l

新手上路       --linux基础命令使用_Linux_07

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

    sort -t: -k3 -n  /etc/group | cut -d: -f1  | head

新手上路       --linux基础命令使用_linux_08

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

    cat /etc/fstab  /etc/issue > /tmp/etc.test

新手上路       --linux基础命令使用_Linux_09

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

    

用户、组管理命令:

 

    useradd:用户创建

        -u UID: [UID_MIN, UID_MAX], 定义在/etc/login.defs

        -g GID:指明用户所属基本组,可为组名,也可以GID

        -c "COMMENT":用户的注释信息

        -d /PATH/TO/HOME_DIR: 以指定的路径为家目录

        -s SHELL: 指明用户的默认shell程序,可用列表在/etc/shells文件中

        -G GROUP1[,GROUP2,…[,GROUPN]]]:为用户指明附加组;组必须事先存在

        -r: 创建系统用户,其中CentOS 6中系统用户id小于500,CentOS 7中系统用户id小于1000

 

    userdel:删除用户

        -r: 删除用户家目录

        usermod:修改用户

        -u UID: 新UID

        -g GID: 新基本组

        -G GROUP1[,GROUP2,…[,GROUPN]]]:新附加组,原来的附加组将会被覆盖;若保留原有,则要同时使用-a选项

        -s SHELL:新的默认SHELL;

        -c 'COMMENT':新的注释信息;

        -d HOME: 新的家目录;原有家目录中的文件不会同时移动至新的家目录;若要移动,则同时使用-m选项;

        -l login_name: 新的名字;

        -L: lock指定用户

        -U: unlock指定用户

 

    groupadd:组创建

    groupadd    [option]...group_name

        -g    GID:指明GID号:[GID_MIN,GID_MAX]

        -r:创建系统组:

        CentOS    6:ID<500

        CentOS    7:ID<1000

        

    id:查看用户相关的ID的信息

    id    [option]...[USER]

        -u:UID

        -g:GID

        -G:Groups

        -n:Name

 

    passwd:添加修改密码,仅root用户权限

        -l: 锁定指定用户

        -u: 解锁指定用户

        -n mindays: 指定最短使用期限

        -x maxdays:最大使用期限

        -w warndays:提前多少天开始警告

        -i inactivedays:非活动期限;

        –stdin:从标准输入接收用户密码;

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

    groupadd distro -g 2016 


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

    useradd mandriva -u 1005 -g distro 


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

    useradd mageia -u 1100 -s /home/linux 


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

    echo "tangkai"  | passwd --stdin mageia

    usermod -p tangkai mageia


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

    userdel mandriva


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

    useradd slackware -u 2002 -g distro -G peguin 


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

    usermod slackware -s /bin/tcsh  


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

    usermod slackware -a -G admins 


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

    passwd slackware -n 3 -x 180  -w 3 


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

    useradd openstack -u 3003 -g clouds -G penguin,nova 


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

    useradd -r mysql -s /sbin/nologin 


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

    echo tangkai | passwd --stdin openstack