find命令拾遗

1. -maxdepth的用法

-maxdepth-mindepth可以限制搜索的深度。当搜索文件超过某个级别或者搜索过多的目录,会导致查找速度变慢,查找花费的时间过多,这时候就可以用-maxdepth来解决:

find /home -maxdepth 1 -name "*.csv" -mtime -5 | wc -l

本例表示只在/home目录下查找最后修改时间在5天以内的csv文件,并统计文件的数目。如果修改为-maxdepth 2就表示在/home目录及其一级子目录下查找,不会搜索到/home/sub/sub1目录下。-mindepth的意义同-maxdepth相反,此处不赘述。

2. -depth的用法和find结果的排列顺序

在你想要批量备份文件的时候,总希望先备份所有的文件,再备份子目录下的文件,这里需要考虑如何find出想要备份文件的顺序。
-depth可以在处理目录以前首先处理目录下的子内容。以下查询显示了使用-depth的效果:
第一个例子:不使用depth,使用通配符*搜索当前目录下的file和directory

find *            
#输出结果:
chmod
result.txt
sasuser.v94
sasuser.v94/regstry.sas7bitm
sasuser.v94/parms.sas7bcat
zhnlicron

第二个例子:使用depth,使用通配符*搜索当前目录下的file和directory

find * -depth
#输出结果
chmod
result.txt
sasuser.v94/regstry.sas7bitm
sasuser.v94/parms.sas7bcat
sasuser.v94
zhnlicron

可以看到/sasuser和它的子目录中的文件位置做了调换。find * -depth会先输出/sasuser目录下的文件。

那么问题来了,在不考虑depth的情况下,find是按照什么顺序来输出结果呢?如上第一个例子使用了*通配符,所以默认会先按照字典序来匹配,在进行find操作。

比如*会先匹配到当前目录下的./chmod,然后再find ./chmod,所以find出来的结果是按照字典序的。

我们再做一个find操作,不使用通配符*直接进行find当前目录:

find .          
#输出结果
chmod
zhnlicron
result.txt
sasuser.v94
sasuser.v94/regstry.sas7bitm
sasuser.v94/parms.sas7bcat

位置再次发生了变化,至少表面上看不可能是按照字典序了,那么是依照什么规则呢?这种则涉及到linux中文件名在超级块中的存储方式(spuer_block):为了快速找到一个文件,我们通常会使用hash算法,和B树算法(二叉树算法)在超级块存储文件名(与inode对应),find操作就是根据B树遍历查找的。

在不同的机器中,文件挂到B树上的方式不同,可能遍历查找的结果就会不同。比如以左遍历挂文件名,右遍历来查找文件名。参考资料

3. 使用多个{}的例子

继续上面提出的备份问题,我们已经按照顺序把需要的文件find出来了,需要批量备份成*.bak文件。可以利用{}这样写:

find -name "*.txt" -exec cp {} {}.bak \;
    #注意括号之间的空格。
    #批量将当前目录下后缀为txt的文件备份一份txt.bak文件

4. -perm的用法

上一篇将find操作用于定时crontab任务,来执行change group的操作。其实可以用-perm来更准确的定位到需要修改权限的文件。-perm的用法有以下几种简单的形式:

  • find -perm mode
  • find -perm -mode
  • find -perm +mode

mode表示严格匹配,-mode表示find权限大于等于mode的文件,+mode表示find权限小于等于mode的文件(可能跟正常的认识刚好相反)。

find . -perm -g=r -type f -exec ll {} \;
    #找到具有组读权限的文件,用ll命令显示文件详细信息。
find . -perm -744;
    #找到权限大于等于744的文件。

【权限的数字表示】使用ll命令可以查看文件的权限:

ll /home/tyrone
#显示结果
-rw-rw-r-- 1 tyrone tyrone   199 Jun  9 20:02 autoexec.sas
-rw-rw-r-- 1 tyrone tyrone     0 Jun  4 01:42 chmod
-rw------- 1 tyrone tyrone     0 Jun  9 19:36 nohup.out
-rw-rw-r-- 1 tyrone tyrone 70429 Jun 10 22:10 resultOfNas.txt
drwxrwxr-x 2 tyrone tyrone  4096 Jun  9 23:11 sasuser.v94
-rw-rw-r-- 1 tyrone tyrone     0 Jun  5 02:13 tyronecron

最左边是一串字母和-的集合,从第二列开始每三个一组,分别表示文件所属用户、所属组、组外用户的权限。r代表读,w代表写,x代表执行。例如-rw-rw-r--就表示文件所属用户和所属组对该文件有读写权限,组外只有读的权限。

那么怎么对应于数字呢?其中,r=4,w=2,x=1,然后每三个字母一组把数字加起来的和组成一个三位数字。例如-rw-rw-r--就等于-420420400,化为三位数字664即为权限所对应的值。

你可能感兴趣的:(find命令拾遗)