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
下一篇 2017-10-22

相关推荐

  • week4

    一,复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其他用户均没 有任何访问权限; cp -r /etc/skel/ /home/tuser1 chmod -R go= /home/tuser1/ 二,编辑/etc/group文件,添加组hado…

    Linux干货 2016-11-18
  • 关于大型网站技术演进的思考(十三)–网站静态化处理—CSI(5)

    原文出处: 夏天的森林   讲完了SSI,ESI,下面就要讲讲CSI了 ,CSI是浏览器端的动静整合方案,当我文章发表后有朋友就问我,CSI技术是不是就是通过ajax来加载数据啊,我当时的回答只是说你的理解有点片面,那么到底什么是CSI技术了?这个其实要和动静资源整合的角度来定义。 CSI技术其实是在页面进行动静分离后,将页面加…

    2015-03-11
  • gitlab-ce并发超过30引起ip被封1小时的问题

    系统环境描述 System information System:     Ubuntu 14.04 Current User:   git Using RVM:  no Ruby Version: …

    Linux干货 2015-09-06
  • Linux运维基础2

    shell编程

    Linux干货 2018-03-19
  • CentOS 7 yum安装LAMP,LNMP并搭建WordPress个人博客网站

    本次实验要进行的是在CentOS7.2,内核版本3.10.0-327.el7.x86_64的环境下搭建LAMP和LNMP,并在此之上做一个WordPress博客网站。 [root@Shining ~]# uname -a Linux Shining.ACG 3.10.0-327.el7.x86_64&nbsp…

    Linux干货 2016-11-24
  • linux网络配置

    主要内容: ip地址以及子网划分 路由基本概念 网络配置工具:ifconfig,ip,netstat使用 网卡配置文件及修改 IP地址: 它们可唯一标识 IP 网络中的每台设备 v  每台主机(计算机、网络设备、外围设备)必须具有唯 一的地址 v IP地址由两部分组成:   &n…

    Linux干货 2016-09-07