linux find命令出现Permission denied后怎么办?------利用linux黑洞文件/dev/null

之前定制了一个命令, 也就是findfile, 如下:

        alias findfile='find . -depth -type f -iname "*" |  xargs md5sum | grep --color -nE -ir' 

        但是, find命令经常遇到Permission denied,

 

  1. find: `./proc/1796/fd': Permission denied

  2. find: `./proc/1796/fdinfo': Permission denied

  3. find: `./proc/1834/task/1834/fd': Permission denied

  4. find: `./proc/1834/task/1834/fdinfo': Permission denied

  5. find: `./proc/1834/fd': Permission denied

  6. find: `./proc/1834/fdinfo': Permission denied

  7. find: `./proc/1971/task/1971/fd': Permission denied

  8. find: `./proc/1971/task/1971/fdinfo': Permission denied

  9. find: `./proc/1971/fd': Permission denied

  10. find: `./proc/1971/fdinfo': Permission denied

        有点让人不高兴啊, 究其原因是, 没有去进行错误处理。 我开始想, 用grep -v过滤一下“Permission denied”, 然并卵。 那还是把错误信息写进linux黑洞文件(/dev/null)吧, 0表示标准输入, 1表示标准输出, 2表示标准错误, 所以可以这么搞:

       alias findfile='find . -depth -type f -iname "*" 2>/dev/null |  xargs md5sum 2>/dev/null | grep --color -nE -ir'

       于是, 一切就OK了, 说一下, 黑洞文件就是只写文件, 写进去后, 就被黑洞吸收了, 只可写, 不可读。 2>/dev/null表示把错误信息写进黑洞, 不显示出来。 比如:

  1. [taoge@localhost /]$ findfile txt

  2. 32308:e3c6707ccec12a5f1a7d27b9fa1e914f ./usr/sbin/httxt2dbm

  3. 36108:d41d8cd98f00b204e9800998ecf8427e ./usr/src/kernels/2.6.32-71.el6.i686/include/config/have/intel/txt.h  

        OK, 不多聊。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值