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即为权限所对应的值。