CentOS下的awk

awk

awk就是把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分在进行各种分析处理

打印,$1:第一列,每行默认tab切割

$0:全部列

例如

$>last -n 5 | awk '{print $1}'



比如jps

jps | awk '{print $1}'


-F : 指定分隔符

比如按照.切割,打印第一列

$>last -n 5 | awk -F '.' '{print $1}'

实例1

last -n 5结果为

cj       pts/2        192.168.217.1    Thu Mar 15 19:01   still logged in   
cj       pts/1        192.168.217.1    Thu Mar 15 19:00   still logged in   
cj       pts/0        192.168.217.1    Thu Mar 15 18:49   still logged in   

cj       tty1         :0               Thu Mar 15 18:48   still logged in   

last -n 5 | awk -F '.' '{print $1}'结果为

cj       pts/2        192
cj       pts/1        192
cj       pts/0        192
cj       tty1         :0               Thu Mar 15 18:48   still logged in   

reboot   system boot  2

实例2

获得/etc/hosts 中ip地址的最后三位

192.168.217.110  hadoop-senior.cj.com


cat /etc/hosts | awk '{print $1}' | awk -F '.' '{print $4}'


实例3 杀死进程

kill -9 `jps | grep Kafka | awk '{print $1}'`

``为强行解析

书写杀死进程脚本

[xkill.sh]
	#!/bin/bash

	pids=`jps | grep $1 | awk '{print $1}'`

	for pid in $pids ; do
		kill -9 $pid
	done
grep $1  这句中的$1指传过来的参数

支持正则

awk -F '/^datanode/' '{print $1}'

动态提取ip地址

ifconfig | grep inet | head -1 | awk '{print $2}'

head -1取出第一行



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

卡搜偶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值