find

作用:查找文件

1.name: 指定文件名

例子1. 找到以du结尾的文件

╭─root@localhost.localdomain ~
╰─➤ find / -name "*du" | head -3
/var/lib/AccountsService/users/du
/var/db/sudo/du
/var/spool/mail/du

例子2:找到包含du的文件

╭─root@localhost.localdomain ~
╰─➤ find / -name "*du*" | head -3
./.oh-my-zsh/themes/duellj.zsh-theme
./.zcompdump-localhost-5.0.2
./apr-1.5.2/file_io/os2/filedup.c

2. perm:指定文件权限

例子1:找到所有644权限的文件

╭─root@localhost.localdomain ~
╰─➤ find / -perm 644 | head -3
/boot/grub/splash.xpm.gz
/boot/.vmlinuz-3.10.0-514.el7.x86_64.hmac
/boot/config-3.10.0-514.el7.x86_64
╭─root@localhost.localdomain ~
╰─➤ ll /boot/grub/splash.xpm.gz
-rw-r--r--. 1 root root 1.4K 11月 16 2011 /boot/grub/splash.xpm.gz

例子2:模糊匹配644权限

╭─root@localhost.localdomain ~
╰─➤ find / -perm -644 | head -3
/boot/grub
/boot/grub/splash.xpm.gz
/boot/.vmlinuz-3.10.0-514.el7.x86_64.hmac

3. exec: 执行命令

例子1:删除无属主的文件

╭─root@localhost.localdomain ~
╰─➤ find / -nouser -exec rm -rf {} \;

3:xargs

╭─root@localhost.localdomain /home
╰─➤ ls
du
╭─root@localhost.localdomain /home
╰─➤ touch {1..20}cjk
╭─root@localhost.localdomain /home
╰─➤ ls
10cjk 12cjk 14cjk 16cjk 18cjk 1cjk 2cjk 4cjk 6cjk 8cjk du
11cjk 13cjk 15cjk 17cjk 19cjk 20cjk 3cjk 5cjk 7cjk 9cjk
╭─root@localhost.localdomain /home
╰─➤ find /home -name "*cjk" | xargs rm -rf
╭─root@localhost.localdomain /home
╰─➤ ls
du

4.find可以使用-a和-o或!

-a 是而且的意思

-o 是或者的意思

例子1:找到所有权限是644的普通文件

╭─root@localhost.localdomain /home
╰─➤ find / -type f -a -perm 644 | head -3
/boot/grub/splash.xpm.gz
/boot/.vmlinuz-3.10.0-514.el7.x86_64.hmac
/boot/config-3.10.0-514.el7.x86_64

例子二:找到以du开头或以du结尾的普通文件

╭─root@localhost.localdomain /home
╰─➤ find / -name "du*" -o -name "*du" -a -type f

必要时可以用(),但是需要用"\"转义

 删除日志文件(9号机桌面有命令)
find /alidata/www/logs/java/ebs/sys -mtime +7 -type f \( -name "task.log.*" -o -name "dubbo.log.*" -o -name "task-removeSnapshot.log.*" -o -name "service.log.*" -o -name "grandcanal_heartbeat,log,*" -o -name "grandcanal_thread.log.*" \) | xargs rm -f ;

5. user:指定属主

例子1:找到etc目录下属主是root的文件

╭─root@localhost.localdomain ~
╰─➤ find /etc -user root | head -3
/etc/
/etc/fstab
/etc/crypttab

6.group:指定属组

例子1:

╭─root@localhost.localdomain ~
╰─➤ find /etc -group root | head -3
/etc
/etc/fstab
/etc/crypttab

7. nouser:指定无属主

例子1:

╭─root@localhost.localdomain ~
╰─➤ find -nouser | head -5
./httpd-2.4.20
./httpd-2.4.20/.deps
./httpd-2.4.20/.gdbinit
./httpd-2.4.20/ABOUT_APACHE
./httpd-2.4.20/acinclude.m4
╭─root@localhost.localdomain ~
╰─➤ ll ./httpd-2.4.20/.deps
-rw-r--r--. 1 501 games 0 5月 23 20:33 ./httpd-2.4.20/.deps

8. nogroup:指定无属主

╭─root@localhost.localdomain ~
╰─➤ find -nogroup

9.type:指定文件类型

-type         #文件类型

主要的文件类型:
f #普通文件
d #目录
b #块设备
s #套接字
c #字符设备
l #链接
p #管道

例子1:找到所有的链接文件

╭─root@localhost.localdomain ~
╰─➤ find / -type l | head -3
/dev/cdrom
/dev/snd/by-path/pci-0000:02:02.0
/dev/initctl
╭─root@localhost.localdomain ~
╰─➤ find -type l | head -3
./.oh-my-zsh/plugins/fedora/fedora.plugin.zsh
./.oh-my-zsh/plugins/go/go.plugin.zsh
./.oh-my-zsh/plugins/gradle/_gradle
╭─root@localhost.localdomain ~
╰─➤ ll ./.oh-my-zsh/plugins/fedora/fedora.plugin.zsh
lrwxrwxrwx. 1 root root 21 4月 19 11:20 ./.oh-my-zsh/plugins/fedora/fedora.plugin.zsh -> ../dnf/dnf.plugin.zsh

例子2: 找到所有普通文件

╭─root@localhost.localdomain ~
╰─➤ find -type f | head -3
./.bash_logout
./.bash_profile
./.bashrc

10. size:指定文件大小

例子1:找到大于100M的文件

╭─root@localhost.localdomain ~
╰─➤ find / -size +100M
/proc/kcore
/run/media/root/CentOS 7 x86_64/LiveOS/squashfs.img
/sys/devices/pci0000:00/0000:00:0f.0/resource1_wc
/sys/devices/pci0000:00/0000:00:0f.0/resource1
/usr/lib/locale/locale-archive
╭─root@localhost.localdomain ~
╰─➤ ls -lh /usr/lib/locale/locale-archive
-rw-r--r--. 1 root root 102M 4月 18 21:35 /usr/lib/locale/locale-archive

11. mtime: (modify time)指文件修改时间(天)

例子1:找到文件修改时间一天以上的

[root@ken ~]# find / -mtime +1 | head -3
/boot
/boot/efi
/boot/efi/EFI
[root@ken ~]# stat /boot
File: ‘/boot’
Size: 4096 Blocks: 8 IO Block: 4096 directory
Device: 801h/2049d Inode: 64 Links: 5
Access: (0555/dr-xr-xr-x) Uid: ( 0/ root) Gid: ( 0/ root)
Access: 2019-05-24 19:31:37.453000000 +0800
Modify: 2019-02-26 22:25:57.574000000 +0800
Change: 2019-03-14 18:49:48.066000000 +0800
Birth: –

12. atime:(access time)指定文件访问时间(天)

例子:找到访问时间1天以上的

[root@ken ~]# find / -atime +1 | head -3
/boot/grub2/device.map
/boot/grub2/i386-pc/gcry_rmd160.mod
/boot/grub2/i386-pc/acpi.mod
^C
[root@ken ~]# stat /boot/grub2/device.map
File: ‘/boot/grub2/device.map’
Size: 64 Blocks: 8 IO Block: 4096 regular file
Device: 801h/2049d Inode: 1572929 Links: 1
Access: (0644/-rw-r–r–) Uid: ( 0/ root) Gid: ( 0/ root)
Access: 2019-02-26 22:25:05.730000000 +0800
Modify: 2019-02-26 22:25:05.582000000 +0800
Change: 2019-02-26 22:25:05.582000000 +0800
Birth: –

13.ctime:(create time)指定创建时间(天)

例子1:指定文件创建时间一天以上

[root@ken ~]# find / -ctime +1 | head -3
/boot
/boot/efi
/boot/efi/EFI
^C^
[root@ken ~]# stat /boot
File: ‘/boot’
Size: 4096 Blocks: 8 IO Block: 4096 directory
Device: 801h/2049d Inode: 64 Links: 5
Access: (0555/dr-xr-xr-x) Uid: ( 0/ root) Gid: ( 0/ root)
Access: 2019-05-24 19:31:37.453000000 +0800
Modify: 2019-02-26 22:25:57.574000000 +0800
Change: 2019-03-14 18:49:48.066000000 +0800
Birth: –

linux系统find命令详解+xargs命令 、exec命令的更多相关文章

  1. linux命令详解——xargs

    1. 简介 之所以能用到这个命令,关键是由于很多命令不支持|管道来传递参数,而日常工作中有有这个必要,所以就有了xargs命令,例如: find /sbin -perm +700 |ls -l     ...

  2. Linux命令详解:[7]获得命令帮助

    在维护和使用Linux系统时,常常会忘记命令的使用方法,如果旁边又没有相应的资料,那怎么办呢?不用担心,系统本身提供了详细的手册供使用者查询,下面小编就以CentOS6.4系统为例演示如何获得命令帮助 ...

  3. Linux系统僵尸进程详解

    大安好,我是良许. 本文我们将来讨论一下什么是僵尸进程,僵尸进程是怎么产生的,如何杀死一个僵尸进程. Linux中的进程是什么? 讲到进程,我们要先了解一下另一个概念:程序. 程序说白了就是躺在电脑硬 ...

  4. MySQL在Linux系统下配置文件详解

    在日常的的开发过程中接触到了SQLServer和MySQL数据库的操作性问题,可能是以前接触的都是SQL Server,才开始接触MySQL,总感觉使用MySQL没有使用SQLserver那么顺手,一 ...

  5. linux系统开机流程详解

    今天,我们主要来谈谈计算机系统的启动流程 1.BIOS启动 BIOS是写入到主板上的一个韧体(韧体就是写入到硬件上的一个软件程序).开机的时候,BIOS是计算机系统会主动执行的第一个程序.BIOS主要 ...

  6. Linux常用命令详解(二) -- 查找常用命令

    locate:    作用:在后台数据库中按文件名搜索,搜索速度更快    命令格式:locate 文件名    选项或参数:            -l    num(要显示的行数)         ...

  7. Linux命令详解一:基础命令新建、删除、拷贝~~~

    此处跟大家分享一些Linux文件类的基本命令,应该可以满足日常基本操作了. 底部分享了一个链接,介绍的比较全面,也可以参照. 1.创建目录: 1)创建单级目录:mkdir soft: 2)创建层级目录 ...

  8. Linux系统的信号详解

    一.信号类型 1) SIGHUP       2) SIGINT       3) SIGQUIT     4) SIGILL        5) SIGTRAP 6) SIGABRT      7) ...

  9. centos top 命令详解及退出top命令-使用p键及free命令

    1.作用 top命令用来显示执行中的程序进程,使用权限是所有用户. 2.格式 top [-] [d delay] [q] [c] [S] [s] [i] [n] 3.主要参数 d:指定更新的间隔,以秒 ...

随机推荐

  1. SpringBoot整合Shiro权限框架实战

    什么是ACL和RBAC ACL Access Control list:访问控制列表 优点:简单易用,开发便捷 缺点:用户和权限直接挂钩,导致在授予时的复杂性,比较分散,不便于管理 例子:常见的文件系 ...

  2. 短信平台软件开发,短信发送平台销售,短信软件源码,G客短信发送平台

    一:web短信平台组成  需要短信软件平台源码的联系QQ:290615413 vx:290615413  整套短信系统平台还是由B/S(客户端+后台,取消了以前C/S的管理后台) ,C/S发送服务端和 ...

  3. netty核心组件之channel、handler、ChannelHandlerContext、pipeline

    channel介绍: netty中channel分为NioServerScoketChannel和NioSocketChannel,分别对应java nio中的ServerScoketChannel和 ...

  4. flask socketio 踩坑记录

    在使用python3的flask-socketio+socket.io.js的时候报错 在使用python3的flask-socketio+socket.io.js的时候报错"unsuppo ...

  5. java进阶(29)--HashMap集合

    一.HashMap简介 1.HashMap底层是哈希表结构,类似字典,初始化如下: 2.哈希表结构: 是一个数组+单向链表的结构体 数组:查询效率较高,随机增删效率很低 单向链表:在随机增删方面效率较 ...

  6. git文件操作

    git下载地址: https://git-scm.com/download mac 直接使用brew下载brew install git 1Git一般工作流程: 1.在工作目录创建版本库 2.在工作目 ...

  7. JavaScript入门-对象

    js对象 本篇主要介绍js里如何创建对象,以及for循环访问对象的成员... 什么是对象? 对象,并不是中文里有男女朋友意思,它是从英文里翻译来的,英文叫[Object],目标,物体,物品的意思. 在 ...

  8. 软碟通制作win10镜像,无法打开install.wim的问题

    打开软碟通,单击左上角"文件"→"打开",选择.iso文件的存放目录,再选择.iso映像文件打开,即可看到映像文件全部加载到UltraISO了,如下图.   将 ...

  9. 【ORA】ORA-32004: 问题分析和解决

    今天做一个特殊的实验,需要重启数据库 数据库关闭没有问题 SQL> shutdown immediate; Database closed. Database dismounted. ORACL ...

  10. 奇技淫巧,还是正统功夫? - Python推导式最全用法

    前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,如有问题请及时联系我们以作处理. PS:如有需要Python学习资料的小伙伴可以加点击下方链接自行获取 python免费学习资 ...