Linux文件查找常用命令-详细笔记

算法踏风人
• 阅读 1316

which-whereis-locate-grep find 命令使用

查找文件一般有以下几个命令:

which查看可执行文件的位置
whereis查看可执行文件的位置及相关文件
locate配合数据库缓存,快速查看文件位置
grep过滤匹配,它是一个文件搜索工具
find查找相关文件

举例:

[root@xuegod63 ~]# which cd
/usr/bin/cd
[root@xuegod63 ~]# whereis cd
cd: /usr/bin/cd /usr/share/man/man1/cd.1.gz /usr/share/man/man1p/cd.1p.gz
[root@xuegod63 ~]# whereis ls
ls: /usr/bin/ls /usr/share/man/man1/ls.1.gz /usr/share/man/man1p/ls.1p.g
locate

locate 命令和 find -name 功能差不多,是它的另外一种写法,但是这个要比 find 搜索快的多,因
为 find 命令查找的是具体目录文件,而 locate 它搜索的是一个数据库
/var/lib/mlocate/mlocate.db,这个数据库中存有本地所有的文件信息;这个数据库是 Linux 自动创
建并每天自动更新维护。相关的配置信息在 /etc/updatedb.conf,查看定时任务信息在
/etc/cron.daily/mlocate

[root@xuegod63 ~]# yum -y install mlocate
[root@xuegod63 mnt]# touch /opt/xuegod.txt
[root@xuegod63 mnt]# locate xuegod.txt     #发现找不到
[root@xuegod63 mnt]# updatedb   #如果对当天文件查找,需要手动更新数据库  updatedb
[root@xuegod63 mnt]# locate xuegod

grep 查找使用

作用:过滤,它能够使用正则表达式来搜索文本,并把结果打印出来
参数:

-v取反
-i忽略大小写
^#以#开头
#$以#结尾
^$空行
-n对过滤的内容加上行号
l或者的意思
[root@xuegod63 ~]#   ps -aux | grep sshd | grep -v grep
root  1089  0.0  0.2 105996   4088 ?   Ss   20:19  0:00 /usr/sbin/sshd –D
[root@xuegod63 ~]# cat /etc/passwd | grep ^a #以 a  开头
[root@xuegod63 ~]# grep bash$ /etc/passwd   #以 bash  结尾
[root@xuegod63 ~]# grep "nologin\|root" /etc/passwd | wc -l
注:  \ 表示转义符
[root@xuegod63 ~]# egrep "nologin|root" /etc/passwd | wc -l
#查看包括 nologin 或 root  的行
注:egrep  是 grep  加强版本

find 命令使用

格式:find     pathname   -options   [-print]
     命令字    路径名称     选项        输出

参数:
pathname: find 命令所查找的目录路径,不输入代表当前目录例如用 . 来表示当前目录,用 /
来表示系统根目录。

find 命令选项:

-name按照文件名查找文件‘名称’
-perm按照文件权限来查找文件。666 777 等
-user按照文件属主来查找文件
-group按照文件所属的组来查找文件
-mtime-n/ +n 按照文件的更改时间来查找文件
- n表示文件更改时间距现在 n 天以内
+ n表示文件更改时间距现在 n 天以前
-type查找某一类型的文件
b -块设备文件
d-目录
c -字符设备文件
p -管道文件
l-符号链接文件
f -普通文件
-size n查找符合指定的文件大小的文件
-exec对匹配的文件执行该参数所给出的其他 linux 命令, 相应命令的形式为' 命令 {} \ 注意{ }和 \;之间的空格,{}代表查到的内容

示例 1:希望在 root 目录下查找更改时间在 1 天以内,被修改的文件

[root@xuegod63 ~]# find /root/ -mtime -1

对查找内容执行相应命令
-exec 这个选项参数后面可以跟自定义的 SHELL 命令,格式如下:
Linux文件查找常用命令-详细笔记

例 2:

[root@xuegod63 ~]# touch {1,2,3}.back
[root@xuegod63 mnt]# find . -name "*.back" -exec ls -l {} \;

例 3:

[root@xuegod63 ~]#   find . -name "*.back" -exec mv {} /opt \;
[root@xuegod63 ~]# ls /opt/
1.back  2.back   3.back  rh   xuegod.txt

例 4:把查找到的文件复制到一个指定的目录

[root@xuegod63 mnt]# find /root -name "*.txt" -exec cp {} /opt\;

例 5:xargs 和 find 命令结合 复制文件

-i   表示  find  传递给 xargs 的结果 由{}来代替   (了
解)
[root@xuegod63 ~]# rm -rf /opt/*
[root@xuegod63 ~]# find . -name "*.txt"   | xargs    -i cp {}
[root@xuegod63 ~]# ls /opt/

例 6:查找多个类型文件

比较符的使用:

-aand 并且
-oor或者
+超过
-低于
[root@xuegod63 ~]# touch a.pdf back.sh
[root@xuegod63 ~]# find . -name "*.sh" -o -name "*.pdf"
[root@xuegod63 ~]# find /etc -size +20k -a -size -50k | wc -l
22
[root@xuegod63 ~]# find /etc -size +20k   | wc -l
49

例 7: 按权限查找:-perm

[root@xuegod63 ~]# find /bin/ -perm 755
#等于 0755  权限的文件或目录
[root@xuegod63 ~]# find /bin/ -perm   -644 #    -表示至少,至少有 644  权限的文件或目录

例:查看系统中权限至少为 777 的文件或目录
创建一些测试文件:

[root@xuegod63 ~]# mkdir ccc
[root@xuegod63 ~]# chmod 777 ccc
[root@xuegod63 ~]# mkdir test
[root@xuegod63 ~]# chmod 1777 test
[root@xuegod63 ~]# touch b.sh
[root@xuegod63 ~]# chmod 4777 b.sh

查找:
[root@xuegod63 ~]# find /root/ -perm 777
[root@xuegod63 ~]# find /root/ -perm 1777
[root@xuegod63 ~]# find /root/ -perm
4777
例:把系统中权限不低于 777 的危险目录查找出来

[root@xuegod63 ~]# find /root/ -perm-777 #至少有 777  权限

例:把系统中权限不低于 777 的危险文件查找出来

[root@xuegod63 ~]# find / -type f -perm-777

例 8:查找的目录深度:

-maxdepth 1 #只查找目录第一层的文件和目录
如:查找/bin 目录下权限等于 644 的文件

[root@xuegod63 ~]# find /etc/ -maxdepth 1 -perm 644 | more
[root@xuegod63 ~]# find /bin/ -maxdepth 1 -perm 755   #/bin 后面要有/
[root@xuegod63 ~]# find /bin -maxdepth 1 -perm 755     #没加/无法满足我们的需求

例 9:查找系统中所有属于用户 user1 的文件,并把这个文件,放到/root/findresults 目录下

注意:/root/findresults 这个需要提前创建好。

root@xuegod63 ~]# mkdir /root/findresults
[root@xuegod63 ~]# useradd user1
[root@xuegod63 ~]# find / -user user1 -exec cp -a {} /root/findresults/

参数: -a #复制时,保留原来文件的所有属性

报错:

find:  ‘/proc/43475/task/43475/fd/6’: 没有那个文件或目录
find:  ‘/proc/43475/task/43475/fdinfo/6’: 没有那个文件或目录
find:  ‘/proc/43475/fd/6’: 没有那个文件或目录
find:  ‘/proc/43475/fdinfo/6’: 没有那个文件或目录
cp:  无法以目录"/home/user1" 来覆盖非目录"/root/findresults/user1"

同一个目录下,可以创建文件 user1 和文件夹 user1 吗?同一个目录下创建的文件名和目录
名一样吗? 不可以

[root@xuegod63 ~]# touch abc
[root@xuegod63 ~]# mkdir abc
mkdir:  无法创建目录"abc": 文件已存在

解决:

[root@xuegod63 ~]# find / -user user1   #发现
[root@xuegod63 ~]# ll /var/spool/mail/user1   #查看这个文件
[root@xuegod63 ~]# ll /home/user1
发现/var/spool/mail/user1  和/home/user1 的名字是一样的。  而两者都要复制到
/root/findresults/下,先复制了/var/spool/mail/user1,所以/home/user1  就不能复制了。
[root@xuegod63 ~]# mv /var/spool/mail/user1
[root@xuegod63 ~]# rm -rf /root/findresults/ *
/var/spool/mail/user1.mail
[root@xuegod63 ~]# find / -user mk -exec cp -a {} /root/findresults/ \;
[root@xuegod63 ~]# mv /var/spool/mail/user1.mail
/var/spool/mail/user1
#再修改过来
                                    文章到此结束

想要了解更多的技术+
Linux文件查找常用命令-详细笔记

点赞
收藏
评论区
推荐文章
blmius blmius
4年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
美凌格栋栋酱 美凌格栋栋酱
7个月前
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Jacquelyn38 Jacquelyn38
4年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
Jira 使用手册
<tablestyle"width:100%;margin:200px0300px0;"<tr<thDate</th<thRevisionversion</th<thDescription</th<thauthor</th</tr<tr<td20180614</td<tdV1.0.0</td
Wesley13 Wesley13
3年前
FLV文件格式
1.        FLV文件对齐方式FLV文件以大端对齐方式存放多字节整型。如存放数字无符号16位的数字300(0x012C),那么在FLV文件中存放的顺序是:|0x01|0x2C|。如果是无符号32位数字300(0x0000012C),那么在FLV文件中的存放顺序是:|0x00|0x00|0x00|0x01|0x2C。2.  
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这