第三周:文本处理工具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
下一篇 2016-09-27

相关推荐

  • 第二周作业新

    一、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。 pwd :显示当前所在路径   cd :切换目录   cd – :在上次目录与当前目录之间切换。   cd ~ :切换回自己的家目录   cd . :当前目录      cd .. :切换到…

    2017-02-18
  • 第十二周作业

      1、描述一次完整的http请求处理过程 简介 一次完整的HTTP请求过程从TCP三次握手建立连接成功后开始,客户端按照指定的格式开始向服务端发送HTTP请求,服务端接收请求后,解析HTTP请求,处理完业务逻辑,最后返回一个HTTP的响应给客户端,HTTP的响应内容同样有标准的格式。无论是什么客户端或者是什么服务端,大家只要按照HTTP的协议标准…

    2017-11-12
  • 马哥教育网络班21期+第3周课程练习

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 [root@localhost ~]# who | cut -d' ' -f1 | sort -u 2、取出最后登录到当前系统的用户的相关信息。 [ro…

    Linux干货 2016-07-29
  • N22第八周作业

    1、请描述网桥、集线器、二层交换机、三层交换机、路由器的功能、使用场景与区别。 网桥: 网桥是早期的二层网络设备,每个端口分别有一条独立的交换信道,不是共享一条信道,可隔离冲突域。网桥比集线器(Hub)性能更好,集线器上各端口都是共享同一条信道的,工作于数据链路层。后被端口更多的交换机替代。 集线器: 多端口中继器,工作在物理层,本身不具备识别信号的能力,只…

    Linux干货 2016-10-17
  • 什么是Ansible?

    自动化工具——ansible   ansibleArchitecture ansibleProject 1. 什么是ansible ansible是个什么东西呢?官方的title是“Ansible is Simple IT Automation”——简单的自动化IT工具。这个工具的目标有这么几项:让我们自动化部署APP;自动化管理配置项;自动化的持…

    2017-09-24