第三周:文本处理工具wc,cut,sort,uniq,tr,tee命令练习和用户及组相关命令练习

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

[root@app1 tmp]# who | cut -d" " -f1| uniq
root
dts
centos

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

[root@app1 tmp]# last -1
centos   pts/5        10.88.103.46     Tue Sep 27 15:24   still logged in   

wtmp begins Sat Jun  4 13:22:15 2016

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

[root@app1 tmp]# cut -d: -f7 /etc/passwd | uniq -c | sort -n | tail -1
     25 /sbin/nologin

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

[root@app1 tmp]# ifconfig eth0 | grep "inet addr" | cut -d":" -f2 |cut -d" " -f1
10.88.158.84
[root@app1 tmp]# ifconfig eth0 | grep "inet addr" | awk '{print $2}' | awk -F":" '{print $2}'
10.88.158.84

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

[root@app1 tmp]#  sort -t: -k3 -n /etc/passwd | tail -10 | tr "a-z" "A-Z" | tee /tmp/maxusers.txt
[root@app1 tmp]#  sort -t: -k3 -n /etc/passwd | tail -10 > /tmp/maxusers.txt
[root@app1 tmp]# cat /tmp/maxusers.txt

6、列出/etc目录下所有.conf结尾的文件的文件名,并将其名字转换为大写;

[root@app1 tmp]# ls /etc/*.conf | tr "a-z" "A-Z" | tee /tmp/etc.conf

7、显示/var目录下一级子目录的总个数;

[root@app1 tmp]# ll /var/ | grep ^d | wc -l

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

[root@app1 tmp]# sort -t: -k3 -n /etc/group | head -10 | cut -d: -f1

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

[root@app1 tmp]# cat /etc/fstab > /tmp/etc.test && cat /etc/issue >> /tmp/etc.test
[root@app1 tmp]# cat /etc/fstab /etc/issue > /tmp/etc.test

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

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

        [root@app1 tmp]# groupadd -g 2016 distro
        [root@app1 tmp]# grep distro /etc/group
        distro:x:2016:

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

        [root@app1 tmp]# useradd -u 100 -g distro mandriva
        [root@app1 tmp]# grep mandriva /etc/passwd
        mandriva:x:100:2016::/home/mandriva:/bin/bash

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

        [root@app1 tmp]# useradd mageia -u 1100 -d /home/linux    
        [root@app1 tmp]# ls -ld /home/linux/
        drwx------ 4 mageia mageia 4096 Sep 27 16:35 /home/linux/
        [root@app1 tmp]# grep mageia /etc/passwd
        mageia:x:1100:1100::/home/linux:/bin/bash

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

        [root@app1 tmp]# echo "mageedu" | passwd mageia --stdin
        Changing password for user mageia.
        passwd: all authentication tokens updated successfully.

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

        [root@app1 tmp]# userdel mandriva    
        [root@app1 tmp]# ls -ld /home/mandriva
        drwx------ 4 100 distro 4096 Sep 27 16:32 /home/mandriva

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

        [root@app1 tmp]# useradd -u 2002 -g distro -G peguin slakware    
        [root@app1 tmp]# grep slakware /etc/passwd
        slakware:x:2002:2016::/home/slakware:/bin/bash
        [root@app1 tmp]# grep slakware /etc/shadow
        slakware:!!:17071:0:99999:7:::
        [root@app1 tmp]# grep slakware /etc/group
        peguin:x:505:gentoo,slakware

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

        [root@app1 tmp]# usermod -s /bin/tcsh slakware
        [root@app1 tmp]# grep slakware /etc/passwd
        slakware:x:2002:2016::/home/slakware:/bin/tcsh

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

        [root@app1 tmp]# groupadd admins        
        [root@app1 tmp]# usermod -a -G admins slakware
        [root@app1 tmp]# grep slakware /etc/group
        peguin:x:505:gentoo,slakware
        admins:x:4005:slakware

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

        [root@app1 tmp]# echo "dtsdts" |  passwd -n 3 -x 180 -w 3 --stdin slakware

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

        [root@app1 tmp]# useradd -u 3003 -g clouds -G peguin,nova openstack        
        [root@app1 tmp]# grep openstack /etc/group
        peguin:x:505:gentoo,slakware,openstack
        nova:x:4007:openstack

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

        [root@app1 tmp]# useradd -r mysql -s /sbin/nologin

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

        [root@app1 tmp]# echo "dtsdts" | passwd --stdin openstack        
        Changing password for user openstack.
        passwd: all authentication tokens updated successfully.
        [root@app1 tmp]#

原创文章,作者:dawning,如若转载,请注明出处:http://www.178linux.com/49508

(0)
dawningdawning
上一篇 2016-09-27 16:00
下一篇 2016-09-27 17:35

相关推荐

  • Linux入门命令(一)

    已经一年没有在接触过Linux了,经过一个星期的Linux学习之后,又重新对她产生了兴趣,本周学习了一些Linux入门级的命令: (1)     (1)tty 这个命令是查看当前所处于的中终端信息的,同样也可以使用 who am i ,who以及w来查看终端信息. 终端也还有物理终端、虚拟终端以及伪终端之分,在虚拟机下…

    2017-07-16
  • Linux中的shell脚本编程——基础篇

    概述:       shell脚本在Linux系统管理员的运维工作中非常重要。shell脚本能够帮助我们很方便的管理服务器,因为我们可以指定一个任务计划,定时的去执行某一个脚本以满足我们的需求。本篇将从编程基础、脚本基本格式、变量、运算、条件测试这几个方面详细介绍shell脚本编程的基础内容,也是我们必须要掌握熟练的内容。 一、…

    Linux干货 2016-08-15
  • 马哥网络教育班第21期+第六周课程练习

    请详细总结vim编辑器的使用并完成以下练习题 1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#; [root@localhost ~]# cp /etc/rc.d/rc.sysinit /tmp/ [root@localho…

    Linux干货 2016-08-02
  • 文件系统管理_设定文件系统的配额

    认识配置配额系统 :为控制用户使用的空间的大小,在linux可以实现对分区的大小控制,控制用户在这个分区内使用空间的大小同时还可以对用户的文件个数实现控制。 在linux系统中其遵循文件分区来实现控制 磁盘的配额只针对单个分区来实现控制,不能对单块磁盘(硬盘)来实现控制的 【搭建试验环境 1】 怎样把某一个文件夹(/home)单独放到(迁移)一个独立的分区中…

    Linux干货 2017-04-24
  • 马哥教育网络班21期-第三周课程练习

    第三周课程练习 1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 [root@localhost ~]# who | cut -f1 -d' ' | uniq  root 2、取出最后登录到当前系统的用…

    Linux干货 2016-07-12