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

相关推荐

  • 强大的vim编辑器

    vim编辑器 一、Vim编译器的概述 vi: Visual Interface,文本编辑器 v 文本:ASCII, Unicode v  文本编辑种类:      行编辑器: sed      全屏编辑器:nano,   &nbs…

    Linux干货 2016-08-12
  • M22 使用非对称密钥实现ssh自动登陆

    一 实验目的 一般在用户使用ssh客户端登陆ssh服务器时需要使用用户名和密码,本实验使用非对称加密的方式实现了无密码登陆ssh服务器。 二 实验流程  、 1 在客户端生成非对称密钥对 2 将非对称密钥中的公钥发送给ssh服务器端相应的帐号 3 当客户端通过ssh协议与服务器端发起连接时,客户端将私钥加密过的签名发送给服务器端,服务器端使用客户端…

    2017-04-13
  • find使用详解

    文件查找是根据文件的各种属性去找到相对应的文件。 文件查找分为实时查找和非实时查找。     非实时查找是根据索引来进行查找;虽然非实时查找查询速度快,但在构建索引时相当占用资源,只有在系统空闲时才能进行,这样有可能会造成索引内容与当前系统中文件的状态不一致的情况,所以查找结果有可能会不准确。   …

    Linux干货 2015-03-18
  • bettilt.link-bettlit-22

    Bettilt Giriş İşlemi: Mevcut Adres, Mobil Kullanıcı Girişi ve Casino Platformu İncelemesi Bettilt Nedir? Genel İnceleme Bettilt, global ölçekte hizmet veren online bir spor bahisle…

    Linux干货 2025-05-09
  • 计算机的组成和Linux发展史

    计算机的组成及功能   计算机是由CPU,内存,输入装置和输出装置四大部件组成计算机,每一部件分别按要求执行特定的基本功能。  CPU: 控制器和运算器合称中央处理器,也就是CPU,它的功能主要是解释计算机指令以及处理计算机软件中的数据。  内存: 它是与CPU进行沟通的桥梁。计算机中所有程序的运行都是在内存中进行的,内存(Me…

    Linux干货 2016-10-30
  • 马哥教育网络班21期+第4周课程练习

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 [root@itop ~]# cp -r /etc/skel /home/tuserl [root@itop ~]# chmod -R&nbsp…

    Linux干货 2016-08-01