Linux中,关于find结合xargs/parallel的妙用有? (同时要是实用的,不炫技的)-问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文

Linux中,关于find结合xargs/parallel的妙用有? (同时要是实用的,不炫技的)

a123456678 2016-06-28 11:22:31 1352

今天了解到它们结合在一起所产生的强大的力量.

结合实用,应当能够给日常实用Linux带来效率的提升, 有哪些例子呢?

Linux
分享到
取消 提交回答
全部回答(1)
  • a123456678
    2019-07-17 19:48:06

    xargs可以看做一个循环辅助函数,它主要解决的就是在linux环境里,直接使用通配符导致参数过多,命令无法执行的情况。同时结合find,可以实现更多灵活性。
    比如:

    # 把所有以.json为后缀的文件mv到bak目录;如果json文件太多,直接mv *.json bak是不行的。
    find . -type f -name "*.json"|xargs -n10 -I% mv % bak
    # 把所有json文件重命名为以BAK结尾。find可以使用正则匹配,从而实现更多灵活性。
    find . -type f -name "*.json"|xargs -n10 -I% mv % %.BAK
    # 对所有json文件进行sed替换,把其中的_id都换成ID,同时原文件变成.bak后缀文件。
    find . -type f -name "*.json"|xargs -n3 sed -i.bak  's/\_id/ID/g'
    其中 -n number 指定每次给后面的命令多少参数,以上面第一个为例子,如果find到1w个文件,每次执行mv都是3个3个的mv。
    -I replstr指定替换字符串,比如我们指定replstr为%,那么在执行后面的命令时,%将会替换成传入参数的实际内容。注意replstr可以替换的字符串长度最大为255 byte

    在某些系统上,xargs可以使用-P maxprocs开启并行模式。在多核机器上应该会有明显的速度提升。

    0 0
开发与运维
使用钉钉扫一扫加入圈子
+ 订阅

集结各类场景实战经验,助你开发运维畅行无忧

推荐文章
相似问题
推荐课程