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 命令,格局如下:
例 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:查找多个类型文件
比拟符的应用:
-a | and 并且 |
---|---|
-o | or 或者 |
+ | 超过 |
– | 低于 |
[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
#再批改过去
文章到此结束
想要理解更多的技术 +