用烂了的命令如今忘记了 该打!!

Share

  三、xargs

  xargs – build and execute command lines from standard input

  在使用 find命令的-exec选项处理匹配到的文件时, find命令将所有匹配到的文件一起传递给exec执行。但有些系统对能够传递给exec的命令长度有限制,这样在find命令运行几分钟之后,就会出现溢出错误。错误信息通常是“参数列太长”或“参数列溢出”。这就是xargs命令的用处所在,特别是与find命令一起使用。

  find命令把匹配到的文件传递给xargs命令,而xargs命令每次只获取一部分文件而不是全部,不像-exec选项那样。这样它可以先处理最先获取的一部分文件,然后是下一批,并如此继续下去。

  在有些系统中,使用-exec选项会为处理每一个匹配到的文件而发起一个相应的进程,并非将匹配到的文件全部作为参数一次执行;这样在有些情况下就会出现进程过多,系统性能下降的问题,因而效率不高;

  而使用xargs命令则只有一个进程。另外,在使用xargs命令时,究竟是一次获取所有的参数,还是分批取得参数,以及每一次获取参数的数目都会根据该命令的选项及系统内核中相应的可调参数来确定。

  来看看xargs命令是如何同find命令一起使用的,并给出一些例子。

  下面的例子查找系统中的每一个普通文件,然后使用xargs命令来测试它们分别属于哪类文件

  #find . -type f -print | xargs file

  ./.kde/Autostart/Autorun.desktop: UTF-8 Unicode English text

  ./.kde/Autostart/.directory: ISO-8859 text\

  ……

  在整个系统中查找内存信息转储文件(core dump) ,然后把结果保存到/tmp/core.log 文件中:

  $ find / -name “core” -print | xargs echo “” >/tmp/core.log

  上面这个执行太慢,我改成在当前目录下查找

  #find . -name “file*” -print | xargs echo “” > /temp/core.log

  # cat /temp/core.log

  ./file6

  在当前目录下查找所有用户具有读、写和执行权限的文件,并收回相应的写权限:

  # ls -l

  drwxrwxrwx 2 sam adm 4096 10月 30 20:14 file6

  -rwxrwxrwx 2 sam adm 0 10月 31 01:01 http3.conf

  -rwxrwxrwx 2 sam adm 0 10月 31 01:01 httpd.conf

  # find . -perm -7 -print | xargs chmod o-w

  # ls -l

  drwxrwxr-x 2 sam adm 4096 10月 30 20:14 file6

  -rwxrwxr-x 2 sam adm 0 10月 31 01:01 http3.conf

  -rwxrwxr-x 2 sam adm 0 10月 31 01:01 httpd.conf

  用grep命令在所有的普通文件中搜索hostname这个词:

  # find . -type f -print | xargs grep “hostname”

  ./httpd1.conf:# different IP addresses or hostnames and have them handled by the

  ./httpd1.conf:# VirtualHost: If you want to maintain multiple domains/hostnames

  on your

  用grep命令在当前目录下的所有普通文件中搜索hostnames这个词:

  # find . -name \* -type f -print | xargs grep “hostnames”

  ./httpd1.conf:# different IP addresses or hostnames and have them handled by the

  ./httpd1.conf:# VirtualHost: If you want to maintain multiple domains/hostnames

  on your

  注意,在上面的例子中, \用来取消find命令中的*在shell中的特殊含义。

  find命令配合使用exec和xargs可以使用户对所匹配到的文件执行几乎所有的命令。

  四、find 命令的参数

  下面是find一些常用参数的例子,有用到的时候查查就行了,像上面前几个贴子,都用到了其中的的一些参数,也可以用man或查看论坛里其它贴子有find的命令手册

  1、使用name选项

  文件名选项是find命令最常用的选项,要么单独使用该选项,要么和其他选项一起使用。

  可以使用某种文件名模式来匹配文件,记住要用引号将文件名模式引起来。

  不管当前路径是什么,如果想要在自己的根目录$HOME中查找文件名符合*.txt的文件,使用~作为 'pathname'参数,波浪号~代表了你的$HOME目录。

  $ find ~ -name “*.txt” -print

  想要在当前目录及子目录中查找所有的‘ *.txt’文件,可以用:

  $ find . -name “*.txt” -print

  想要的当前目录及子目录中查找文件名以一个大写字母开头的文件,可以用:

  $ find . -name “[A-Z]*” -print

  想要在/etc目录中查找文件名以host开头的文件,可以用:

  $ find /etc -name “host*” -print

  想要查找$HOME目录中的文件,可以用:

  $ find ~ -name “*” -print 或find . -print

  要想让系统高负荷运行,就从根目录开始查找所有的文件。

  $ find / -name “*” -print

  如果想在当前目录查找文件名以两个小写字母开头,跟着是两个数字,最后是.txt的文件,下面的命令就能够返回名为ax37.txt的文件:

  $find . -name “[a-z][a-z][0–9][0–9].txt” -print

  2、用perm选项

  按照文件权限模式用-perm选项,按文件权限模式来查找文件的话。最好使用八进制的权限表示法。

  如在当前目录下查找文件权限位为755的文件,即文件属主可以读、写、执行,其他用户可以读、执行的文件,可以用:

  $ find . -perm 755 -print

  还有一种表达方法:在八进制数字前面要加一个横杠-,表示都匹配,如-007就相当于777,-006相当于666

  # ls -l

  -rwxrwxr-x 2 sam adm 0 10月 31 01:01 http3.conf

  -rw-rw-rw- 1 sam adm 34890 10月 31 00:57 httpd1.conf

  -rwxrwxr-x 2 sam adm 0 10月 31 01:01 httpd.conf

  drw-rw-rw- 2 gem group 4096 10月 26 19:48 sam

  -rw-rw-rw- 1 root root 2792 10月 31 20:19 temp

  # find . -perm 006

  # find . -perm -006

  ./sam

  ./httpd1.conf

  ./temp

  -perm mode:文件许可正好符合mode

  -perm +mode:文件许可部分符合mode

  -perm -mode: 文件许可完全符合mode

  3、忽略某个目录

  如果在查找文件时希望忽略某个目录,因为你知道那个目录中没有你所要查找的文件,那么可以使用-prune选项来指出需要忽略的目录。在使用-prune选项时要当心,因为如果你同时使用了-depth选项,那么-prune选项就会被find命令忽略。

  如果希望在/apps目录下查找文件,但不希望在/apps/bin目录下查找,可以用:

  $ find /apps -path “/apps/bin” -prune -o -print

  4、使用find查找文件的时候怎么避开某个文件目录

  比如要在/usr/sam目录下查找不在dir1子目录之内的所有文件

  find /usr/sam -path “/usr/sam/dir1” -prune -o -print

  find [-path ..] [expression] 在路径列表的后面的是表达式

  -path “/usr/sam” -prune -o -print 是 -path “/usr/sam” -a -prune -o

  -print 的简写表达式按顺序求值, -a 和 -o 都是短路求值,与 shell 的 && 和 || 类似如果 -path “/usr/sam” 为真,则求值 -prune , -prune 返回真,与逻辑表达式为真;否则不求值 -prune,与逻辑表达式为假。如果 -path “/usr/sam” -a -prune 为假,则求值 -print ,-print返回真,或逻辑表达式为真;否则不求值 -print,或逻辑表达式为真。

  这个表达式组合特例可以用伪码写为

  if -path “/usr/sam” then

  -prune

  else

  -print

  避开多个文件夹

  find /usr/sam \( -path /usr/sam/dir1 -o -path /usr/sam/file1 \) -prune -o -print

  圆括号表示表达式的结合。

  \ 表示引用,即指示 shell 不对后面的字符作特殊解释,而留给 find 命令去解释其意义。

  查找某一确定文件,-name等选项加在-o 之后

  #find /usr/sam \(-path /usr/sam/dir1 -o -path /usr/sam/file1 \) -prune -o -name “temp” -print

  5、使用user和nouser选项

  按文件属主查找文件,如在$HOME目录中查找文件属主为sam的文件,可以用:

  $ find ~ -user sam -print

  在/etc目录下查找文件属主为uucp的文件:

  $ find /etc -user uucp -print

  为了查找属主帐户已经被删除的文件,可以使用-nouser选项。这样就能够找到那些属主在/etc/passwd文件中没有有效帐户的文件。在使用-nouser选项时,不必给出用户名; find命令能够为你完成相应的工作。

  例如,希望在/home目录下查找所有的这类文件,可以用:

  $ find /home -nouser -print

Pages: 1 2 3