系统管理-Linux系统文件查找

简介: 系统管理-Linux系统文件查找
  • 文件查找概述
  • find名称查找
  • find大小查找
  • find时间查找
  • find用户查找
  • find类型查找
  • find权限查找
  • find处理动作

文件查找概述

Linux系统中的find命令在查找文件时非常有用而且方便

它可以根据不同的条件来进行查找文件:例如权限、拥有者、修改日期/时间、文件大小等等

同时find命令是Linux下必须掌握的

find 命令的基本语法如下

image.png

find名称查找

创建文件
[root@liza ~]# touch /etc/sysconfig/network-scripts/{ifcfg-eth1,IFCFG-ETH1}
查找/etc目录下包含ifcfg-eth0名称的文件
[root@liza ~]# find /etc -name "ifcfg-eth1"
/etc/sysconfig/network-scripts/ifcfg-eth1
-i 忽略大小写
[root@liza ~]# find /etc -iname "ifcfg-eth1"
/etc/sysconfig/network-scripts/ifcfg-eth1
/etc/sysconfig/network-scripts/IFCFG-ETH1
查找/etc目录下包含ifcfg-eth名称所有文件
[root@liza ~]# find /etc/ -name "ifcfg-eth*"
/etc/sysconfig/network-scripts/ifcfg-eth1
[root@liza ~]# find /etc -iname "ifcfg-eth*"
/etc/sysconfig/network-scripts/ifcfg-eth1
/etc/sysconfig/network-scripts/IFCFG-ETH1

find大小查找

查找大于5M
[root@liza ~]# find /etc -size +5M
/etc/udev/hwdb.bin
查找等于5M
[root@liza ~]# find /etc -size 5M
查找小于5M
[root@liza ~]# find /etc -size 5M

find时间查找

创建测试文件
[root@liza ~]# for i in {01..28};do date -s  201802$i && touch file-$i;done
查找7天以前的文件(不会打印当天的文件)
[root@liza ~]# find ./ -iname "file-*" -mtime +7
查找最近7天的文件,不建议使用(会打印当天的文件)
[root@liza ~]# find ./ -iname "file-*" -mtime -7
查找第7天文件(不会打印当天的文件)
[root@liza ~]# find ./ -iname "file-*" -mtime 7
本地文件保留最近7天的备份文件, 备份服务器保留3个月的备份文件
[root@liza ~]# find /backup/ -iname "*.bak" -mtime +7 -delete
[root@liza ~]# find /backup/ -iname "*.bak" -mtime +90 -delete

find用户查找

查找属主是jack
[root@liza ~]# find /home -user jack
查找属组是admin
[root@liza ~]# find /home -group admin
查找属主是jack, 属组是admin
[root@liza ~]# find /home -user jack -group admin
查找属主是jack, 并且属组是admin
[root@liza ~]# find /home -user jack -a -group admin
查找属主是jack, 或者属组是admin
[root@liza ~]# find /home -user jack -o -group admin
查找没有属主
[root@liza ~]# find /home -nouser
查找没有属组
[root@liza ~]# find /home -nogroup
查找没有属主或属组
[root@liza ~]# find /home -nouser -o -nogroup

find类型查找

f 文件
[root@liza ~]# find /dev -type f
d 目录
[root@liza ~]# find /dev -type d
l 链接
[root@liza ~]# find /dev -type l
b 块设备
[root@liza ~]# find /dev -type b
c 字符设备
[root@liza ~]# find /dev -type c
s 套接字
[root@liza ~]# find /dev -type s
p 管道文件
[root@liza ~]# find /dev -type p

find权限查找

精切匹配644权限
[root@liza ~]# find . -perm 644 -ls
拥有者至少有011(-wx),组010(-w-),其他人100(r–)
[root@liza ~]# find /home -perm -324 
查找全局可写(没位权限必须高于2 -w-)
[root@liza ~]# find . -perm -222 -ls
拥有者至少有r权限, 或者拥有组至少有r权限, 或者匿名至少有w权限
[root@liza ~]# find /home -perm /442 
包含set uid
[root@liza ~]# find  /usr/sbin -perm -4000 -ls
包含set gid
[root@liza ~]# find  /usr/sbin -perm -2000 -ls
包含sticky
[root@liza ~]# find  /usr/sbin -perm -1000 -ls

find处理动作

当查找到一个文件后, 需要对文件进行如何处理, 默认动作 -print

-print //打印

-ls //以长格式打印显示

-delete //删除查找到的文件(仅能删除空目录)

exec //后面跟自定义的 shell 命令(标准写法 -exec ;)

-ok //后面跟自定义的 shell 命令(会提示是否操作)

打印查询到的文件
[root@liza ~]# find /etc -name "ifcfg*"
/etc/sysconfig/network-scripts/ifcfg-lo
/etc/sysconfig/network-scripts/ifcfg-ens33
/etc/sysconfig/network-scripts/ifcfg-eth1
[root@liza ~]# find /etc -name "ifcfg*" -print
/etc/sysconfig/network-scripts/ifcfg-lo
/etc/sysconfig/network-scripts/ifcfg-ens33
/etc/sysconfig/network-scripts/ifcfg-eth1
[root@liza ~]# find /etc -name "ifcfg*" -ls
50756098    4 -rw-r--r--   1 root     root          254 May  3  2017 /etc/sysconfig/network-scripts/ifcfg-lo
51336699    4 -rw-r--r--   1 root     root          310 Jan  3 22:59 /etc/sysconfig/network-scripts/ifcfg-ens33
51343497    0 -rw-r--r--   1 root     root            0 Jan 15 11:38 /etc/sysconfig/network-scripts/ifcfg-eth1
拷贝文件
[root@liza ~]# find /etc -name "ifcfg*" -exec cp -rvf {} /tmp \;
‘/etc/sysconfig/network-scripts/ifcfg-lo’ -> ‘/tmp/ifcfg-lo’
‘/etc/sysconfig/network-scripts/ifcfg-ens33’ -> ‘/tmp/ifcfg-ens33’
‘/etc/sysconfig/network-scripts/ifcfg-eth1’ -> ‘/tmp/ifcfg-eth1’
-ok会不断提示
[root@liza ~]# find /etc -name "ifcfg*" -ok cp -rvf {} /tmp \;
< cp ... /etc/sysconfig/network-scripts/ifcfg-lo > ? y
‘/etc/sysconfig/network-scripts/ifcfg-lo’ -> ‘/tmp/ifcfg-lo’
< cp ... /etc/sysconfig/network-scripts/ifcfg-ens33 > ? y
‘/etc/sysconfig/network-scripts/ifcfg-ens33’ -> ‘/tmp/ifcfg-ens33’
< cp ... /etc/sysconfig/network-scripts/ifcfg-eth1 > ? y
‘/etc/sysconfig/network-scripts/ifcfg-eth1’ -> ‘/tmp/ifcfg-eth1’
删除文件
[root@liza ~]# find /etc -name "ifcfg*" -exec rm -f {} \;
[root@liza ~]# find /etc -name "ifcfg*" -delete
find结合xargs

xargs将查找到结果一个一个的处理

[root@liza ~]# touch file.txt
[root@liza ~]# find . -name "file.txt" |xargs rm -f
[root@liza ~]# find . -name "file.txt" |xargs -I {} cp -rvf {} /var/tmp
相关文章
|
1月前
|
Ubuntu Linux
计算机基础知识:linux系统怎么安装?
在虚拟机软件中创建一个新的虚拟机,并选择相应操作系统类型和硬盘空间大小等参数。将下载的 ISO 镜像文件加载到虚拟机中。启动虚拟机,进入安装界面,并按照步骤进行安装。安装完成后,可以在虚拟机中使用 Linux 系统。
|
25天前
|
缓存 监控 Linux
Linux系统清理缓存(buff/cache)的有效方法。
总结而言,在大多数情形下你不必担心Linux中buffer与cache占用过多内存在影响到其他程序运行;因为当程序请求更多内存在没有足够可用资源时,Linux会自行调整其占有量。只有当你明确知道当前环境与需求并希望立即回收这部分资源给即将运行重负载任务之前才考虑上述方法去主动干预。
346 10
|
29天前
|
安全 Linux 数据安全/隐私保护
为Linux系统的普通账户授予sudo访问权限的过程
完成上述步骤后,你提升的用户就能够使用 `sudo`命令来执行管理员级别的操作,而无需切换到root用户。这是一种更加安全和便捷的权限管理方式,因为它能够留下完整的权限使用记录,并以最小权限的方式工作。需要注意的是,随意授予sudo权限可能会使系统暴露在风险之中,尤其是在用户不了解其所执行命令可能带来的后果的情况下。所以在配置sudo权限时,必须谨慎行事。
204 0
|
1月前
|
Ubuntu Linux 开发者
国产 Linux 发行版再添新成员,CutefishOS 系统简单体验
当然,系统生态构建过程并不简单,不过为了帮助国产操作系统优化生态圈,部分企业也开始用国产操作系统替代 Windows,我们相信肯定会有越来越多的精品软件登录 Linux 平台。
80 0
|
1月前
|
Ubuntu 安全 Linux
Linux系统入门指南:从零开始学习Linux
Shell脚本是一种强大的自动化工具,可以帮助您简化重复的任务或创建复杂的脚本程序。了解Shell脚本的基本语法和常用命令,以及编写和运行Shell脚本的步骤,将使您更高效地处理日常任务。
123 0
|
1月前
|
Ubuntu Linux 图形学
Linux学习之Linux桌面系统有哪些?
Cinnamon:与MATE类似,Cinnamon 拥有 GNOME 和 Unity 等其它桌面环境所没有的种种功能,是高度可定制的桌面环境,不需要任何外部插件、窗口组件和调整工具来定制桌面。
80 0
|
1月前
|
Ubuntu 安全 Linux
十款常用Linux系统介绍
本文不是什么大盘点。市面上有好几百款发行版,每款发行版在某个方面都与众不同。不可能在此全部罗列,本文只罗列了十款最常见的Linux发行版(世界上只有两种人,一种是懂二进制的,另一种是不懂二进制的)。请宣传Linux的魅力或威力。
|
1月前
|
Ubuntu 安全 Linux
linux系统|Ubuntu 18.10 如期正式发布,新面孔新技术都来了
微软公司也终于沉不住气要在linux开源系统开疆扩土了。mscode这样的工具的确好用,虽然差第一名那么一点儿,但是最老版的公司出版的软件的确很是让人动心!
|
1月前
|
Ubuntu Linux 数据安全/隐私保护
Win10安装Linux子系统教程!如何在Win10系统中安装Ubuntu!
登录系统后,输入cd /返回上一级,然后再输入“ls”查看一下系统文件目录,看看对不对!
|
1月前
|
Web App开发 安全 Linux
Linux 比起其他系统的5 个优点和 5 个缺点
对Linux系统感兴趣的朋友,可以点击下方书籍进行学习。