基本shell命令

awk和sed以及xargs的使用总结

ls -la|awk '{print $0}'|xargs -i echo {}|sed -n '1,10p'|tail -n 2
  • awk 显示第几列 0显示全部 1 2 3 一次类推
  • xargs 将前面cmd输出到后面的cmd -i 可以指定位置
  • sed -n 显示前面1 到 10列
  • tail -n 显示后面几列
ps -ef|grep XXXX | grep -v grep | awk {'print $2'} |xargs kill -9

kill -9 `ps -ef|grep YYYY|grep -v grep |awk '{print $2}'`
  • 第一个语句杀死所有匹配到XXXX的进程,如果有多个XXXX语句也不会出错
  • 第二个语句杀死匹配到的YYYY进程,如果有多个语句就是报错

shell结合docker的一些使用

docker exec -it `docker ps | grep xx | grep -v xx | awk '{print $1}'` bash

docker ps | grep port | awk '{print $1}' | xargs -i docker exec -i {} date
  • 查找并过滤容器,然后直接进入容器
  • 查找并过滤容器,不进入容器 只是简单执行某些命令

正则表达式grep的正则匹配

ps -ef |grep '^xx'    匹配以xx开始的行 -n打印行号

ps -ef |grep 'xx$'    匹配以xx结束的行

nohup组合使用

一般情况下,我们使用的nohup都会只下面这样的,没什么问题:

    nohup python run.py conf.yml start >> ./min.log 2>&1 &

但是有这样的需求: nohup得到启动的进程pid,并且得到启动进程退出码

(sh nohup_run.sh > ./min.log & echo $! > ./pid.log 2>&1 & exitcode=$? echo exitcode > 3.log
) > /dev/null 2>&1 &
  • \$! 得到上一个后台进程的pid,$$ 得到当前进程的pid,$?得到上个命令的退出码

shell中的一些字符分割

  • ${str#*,} 得到str字符后面的字符
str='1212,12';echo ${str#*,} ---> 12
str='1212,12 ggg';echo ${str#*,}|awk '{print $2}' ---> ggg

目录的循环遍历

for item in `ls $1`; do echo $item; done 
posted @ 2019-02-14 09:47  紫系流月  阅读(572)  评论(0编辑  收藏  举报