who,cut,sort,grep,tr,wc,uniq命令管道和重定向综合应用实例

linux基础

1.列出当前系统上所有已登录的用户名,同一用户登录多次,只显示一次即可。
[root@dxlcentOS ~]# who | cut -d” ” -f1
root
root
root
[root@dxlcentOS ~]# who | cut -d” ” -f1 | sort -u

2.取出最后登录到当前系统的用户的相关信息
[root@dxlcentOS ~]# w | tail -1 && grep “^root” /etc/passwd
root pts/3 192.168.0.105 14:15 6.00s 0.06s 0.00s w
root:x:0:0:root:/root:/bin/bash

3.取出当前系统上被用户当作其默认shell最多的那个shell
[root@dxlcentOS ~]# cut -d: -f7 /etc/passwd |uniq -cd
4 /sbin/nologin
12 /sbin/nologin
3 /bin/bash
6 /bin/bash
5 /sbin/nologin
[root@dxlcentOS ~]# cut -d: -f7 /etc/passwd |uniq -cd | grep 12
12 /sbin/nologin

4.将/etc/passwd中第三个字段中数值最大的后十个用户信息全部改为大写后保存到/tmp/maxusers.txt 文件中
[root@dxlcentOS ~]# sort -t: -k3n /etc/passwd | tail -10 | tr ‘a-z’ ‘A-Z’
/tmp/maxusers.txt
[root@dxlcentOS ~]# cat /tmp/maxusers.txt
WWW:X:1005:1005::/HOME/WWW:/BIN/BASH
MAGEIA:X:1100:1100::/HOME/LINUX:/BIN/BASH
PEGUIN:X:1101:1101::/HOME/PEGUIN:/BIN/BASH
SLACKWARE:X:2002:2016::/HOME/SLACKWARE:/BIN/BASH
ADMINS:X:2003:2003::/HOME/ADMINS:/BIN/BASH
FEDORA:X:2004:2004:FEDORA CORE:/HOME/FEDORA:/BIN/TCSH
BASH:X:2005:2005::/HOME/BASH:/SBIN/NOLOGIN
TESTBASH:X:2006:2006::/HOME/TESTBASH:/SBIN/NOLOGIN
BASHER:X:2007:2007::/HOME/BASHER:/SBIN/NOLOGIN
NOLOGIN:X:2008:2008::/HOME/NOLOGIN:/SBIN/NOLOGIN

5.取出当前主机的IP地址
[root@dxlcentOS ~]# ifconfig | sed -n 2p
inet 192.168.0.196 netmask 255.255.255.0 broadcast 192.168.0.255
[root@dxlcentOS ~]# ifconfig | sed -n 2p | cut -d” ” -f10
192.168.0.196

6.列出/etc目录下所有以.conf结尾的文件的文件名,并将其名字转换为大写后保存至/tmp/etc.conf文件中。
方法一
[root@dxlcentOS ~]# ls -d /etc/.conf | cut -d “/” -f3 | tr “a-z” A-Z >/tmp/conf
[root@dxlcentOS ~]# cat /tmp/conf
ASOUND.CONF
DNSMASQ.CONF
DRACUT.CONF
E2FSCK.CONF
…..
方法二
[root@dxlcentOS ~]# ls /etc/
.conf | egrep -o “[^/]+/?$” | tr “a-z” “A-Z”
ASOUND.CONF
DNSMASQ.CONF
LD.SO.CONF
SYSCTL.CONF
TCSD.CONF
UPDATEDB.CONF
……
[root@dxlcentOS ~]# ls /etc/*.conf | egrep -o “[^/]+/?$” | tr “a-z” “A-Z” >/tmp/etc.conf

7、显示/var目录下一级子目录或文件的总个数。
计算文件总和
[root@dxlcentOS we]# ll /var/ | grep “-” | wc -l
21
计算目录总和
[root@dxlcentOS we]# ll /var/ | grep “d” | wc -l
19
[root@dxlcentOS we]# ls -lR /var/ | grep “d” | wc -l 包括子文件夹里面的目录
4003

8、取出/etc/group/文件中第三个字段数值最小的10个组的名字。
[root@dxlcentOS we]# sort -t: -k3n /etc/group | head -10
root:x:0:dxll2,slackware
bin:x:1:
daemon:x:2:
sys:x:3:
adm:x:4:
tty:x:5:
disk:x:6:
lp:x:7:
mem:x:8:
kmem:x:9:
[root@dxlcentOS we]# sort -t: -k3n /etc/group | head -10 | cut -d: -f1
root
bin
daemon
sys
adm
tty
disk
lp
mem
kmem

9.将/etc/fstab和/etc/issue文件的内容合并为同一个内容后保存至/tmp/etc.test文件中。
[root@dxlcentOS we]# cat /etc/fstab /etc/issue > /tmp/etc.test

总结:以上的练习在centos7进行,功能的的实现基本没次都用到了管道,通过管道送给下一命令进行处理。体现了一个命令完成一个任务,组合小程序完成复杂任务的哲学思想。

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/88006

(0)
N27_dxldengN27_dxldeng
上一篇 2017-10-22 15:39
下一篇 2017-10-22 23:25

相关推荐

  • 马哥linux0728课程内容

    课堂学习内容   -ahistory list –.bash_histroy 保存历史列表到历史文件 -cclear history list 清空历史列表 -d deletehistory entru 清除历史列表某一条命令 -rread .bash_history 读历史文件中的命令到历史列表…

    Linux干货 2016-08-04
  • 权限管理

    权限管理包括普通权限、特殊权限、默认权限、ACL权限。 这些权限都是针对u(owner)、g(group)、o(other)三类定义的。 设置权限时文件和目录不同(此处把文件和目录分开,一般说文件就包含目录(linux思想:一切皆文件))如下图所示, 分别用两个用户分别创建了一个目录一个文件,可以看到同是目录的liutest和test的权限不同,它俩同为目录…

    Linux干货 2017-07-30
  • shell脚本编程之函数、case语句

    一、函数 调用函数前必须先定义,调用时仅使用函数名即可。 语法: function  函数名 {      函数体 } 也可表示为: 函数名 () { 函数体 } 示例:写一个脚本,判定网络内有哪些主机在线,在线的用绿色显示,不在线的用红示表示: c_net&…

    Linux干货 2015-08-24
  • Linux上命令使用格式及如何获取帮助信息

    Linux系统上命令使用: 命令本身是一个可执行的程序文件,二进制格式的文件,有可能会调用共享库文件,发起一条命令,请求内核将某一个二进制程序运行为一个进程。   命令的语法格式:   ~]#COMMAND(命令)   OPENTIONS(选项)   ARGUMENTS(参数) command 命令…

    Linux干货 2016-10-30
  • magedu_20160804

    文本处理工具和grep过滤工具以及正则表达式    一.文本处理工具相关命令    前面课程中曾经使用过cat,head,tail命令查看相关文件,head,tail分别查看文件开头、结尾的行信息。对于特定想要显示的信息则需要特定的文本查看指令,比如cut,sort,paste,uniq等。如下内容分别对每个…

    Linux干货 2016-08-08
  • 磁盘阵列RAID

    磁盘阵列RAID 什么是RAID RAID的全称是Redundant Array of Inexpensive Disks 可以释义为 廉价磁盘冗余阵列,后来的RAID里的字母I被认为是Independent,即独立的磁盘冗余阵列。 RAID的作用 由于服务器中磁盘读写率太大,所以磁盘经常损坏,raid可以让坏了一块磁盘时,服务器不至于岩机。当然这只是其中的…

    Linux干货 2017-06-18