檔案查找
grep: 檔案內容過濾
find: 檔案查找,針對檔案名
一、命令檔案
# which ls //從PATH環境變數 (echo $PATH)
# whereis vim
[root@localhost ~]# echo $PATH
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/usr/local/htop/bin/:/root/bin
二、任意檔案
A. locate (查詢的資料庫: /var/lib/mlocate/mlocate.db)
計劃任務:每天自動更新資料庫 /etc/cron.daily/mlocate.cron
手動更新資料庫:updatedb
# locate ifcfg-eth0
# locate ifcfg-enp0s25
B. find
find [options] [path...] [expression] [action]
===expression===
按檔案名:
[root@CentOS7 ~]# find /etc -name "ifcfg-eth0"
[root@CentOS7 ~]# find /etc -iname "ifcfg-eth0" //-i忽略大小寫
[root@CentOS7 ~]# find /etc -iname "ifcfg-eth*"
按檔案大小:
[root@CentOS7 ~]# find /etc -size +5M //大于5M
[root@CentOS7 ~]# find /etc -size 5M
[root@CentOS7 ~]# find /etc -size -5M
[root@CentOS7 ~]# find /etc -size +5M -ls //-ls找到的處理動作
指定查找的目錄深度:
-maxdepth levels
-mindepth levels
[root@CentOS7 ~]# find / -maxdepth 3 -a -name "ifcfg-eth0"
按時間找(atime,mtime,ctime):
[root@CentOS7 ~]# find /etc -mtime +5 //修改時間超過5天
[root@CentOS7 ~]# find /etc -mtime 5 //修改時間等于5天
[root@CentOS7 ~]# find /etc -mtime -5 //修改時間5天以內
按檔案屬主、屬組找:
[root@CentOS7 ~]# find /home -user jack //屬主是jack的檔案
[root@CentOS7 ~]# find /home -group hr //屬組是hr組的檔案
[root@CentOS7 ~]# find /home -user jack -group hr
[root@CentOS7 ~]# find /home -user jack -a -group hr
[root@CentOS7 ~]# find /home -user jack -o -group hr
[root@CentOS7 ~]# find /home -nouser
[root@CentOS7 ~]# find /home -nogroup
[root@CentOS7 ~]# find /home -nouser -o -nogroup
按檔案型別:
[root@CentOS7 ~]# find /dev -type f //f普通
[root@CentOS7 ~]# find /dev -type d //d目錄
[root@CentOS7 ~]# find /dev -type l //l鏈接
[root@CentOS7 ~]# find /dev -type b //b塊設備
[root@CentOS7 ~]# find /dev -type c //c字符設備
[root@CentOS7 ~]# find /dev -type s //s套接字
[root@CentOS7 ~]# find /dev -type p //p管道檔案
按檔案權限:
[root@CentOS7 ~]# find . -perm 644 -ls
[root@CentOS7 ~]# find . -perm -644 -ls
[root@CentOS7 ~]# find . -perm -600 -ls
[root@CentOS7 ~]# find . -perm -222 -ls //全域可寫
[root@CentOS7 ~]# find /usr/bin /usr/sbin -perm -4000 -ls //包含set uid
[root@CentOS7 ~]# find /usr/bin /usr/sbin -perm -2000 -ls //包含set gid
[root@CentOS7 ~]# find /usr/bin /usr/sbin -perm -1000 -ls //包含sticky
按正則運算式:
-regex pattern
[root@CentOS7 ~]# find /etc -regex '.*ifcfg-eth[0-9]'
.* 任意多個字符
[0-9] 任意一個數字
[root@localhost ~]# find /etc -regex '.*ifcfg-enp0s25'
/etc/sysconfig/network-scripts/ifcfg-enp0s25
[root@localhost ~]# find /etc -regex '.*ifcfg-enp0s[0-9]+'
/etc/sysconfig/network-scripts/ifcfg-enp0s25
==找到后處理的動作 ACTIONS: (默認動作-print)==
-print
-ls
-delete
-exec 后面跟自定義的shell命令
-ok 后面跟自定義的shell命令
[root@CentOS7 ~]# find /etc -name "ifcfg*"
[root@CentOS7 ~]# find /etc -name "ifcfg*" -print
[root@CentOS7 ~]# find /etc -name "ifcfg*" -ls
[root@CentOS7 ~]# find /etc -name "ifcfg*" -exec cp -rvf {} /tmp \;
[root@CentOS7 ~]# find /etc -name "ifcfg*" -ok cp -rvf {} /tmp \;
[root@CentOS7 ~]# find /etc -name "ifcfg*" -exec rm -rf {} \;
[root@CentOS7 ~]# find /etc -name "ifcfg*" -delete
擴展知識:find結合xargs
[root@CentOS7 ~]# find . -name "yang*.txt" |xargs rm -rf
[root@CentOS7 ~]# find /etc -name "ifcfg-eth0" |xargs -I {} cp -rf {} /var/tmp
find作業:
1. 將/etc/中的所有目錄(僅目錄)復制到/tmp下,目錄結構不變
2. 將/etc目錄復制到/var/tmp/
將/var/tmp/etc中的所有目錄設定權限777(僅目錄)
將/var/tmp/etc中所有檔案權限設定為666
3. 以下命令的區別是什么?
[root@CentOS7 ~]# find /etc -name "ifcfg*" -exec rm -rf {} \;
[root@CentOS7 ~]# find /etc -name "ifcfg*" -exec rm -rf {} \+
終結符有兩個:“;”和“+”,
其中“;”會對每一個find到的檔案去執行一次cmd命令,而”+“讓find到的檔案一次性執行完cmd命令,
案例1:
[root@CentOS7 ~]# mkdir dir1
[root@CentOS7 ~]# touch dir1/file{1..20}
[root@CentOS7 ~]# find /root/dir1 -name "file5"
[root@CentOS7 ~]# find /root/dir1 ! -name "file5"
[root@CentOS7 ~]# find /root/dir1 -name "file5" -o -name "file9"
/root/dir1/file5
/root/dir1/file9
[root@CentOS7 ~]# find /root/dir1 -name "file5" -o -name "file9" -ls
1466515 0 -rw-r--r-- 1 root root 0 6月 5 11:15 /root/dir1/file9
[root@CentOS7 ~]# find /root/dir1 -name "file5" -ls -o -name "file9" -ls
1466499 0 -rw-r--r-- 1 root root 0 6月 5 11:15 /root/dir1/file5
1466515 0 -rw-r--r-- 1 root root 0 6月 5 11:15 /root/dir1/file9
[root@CentOS7 ~]# find /root/dir1 \( -name "file5" -o -name "file9" \) -ls
1466499 0 -rw-r--r-- 1 root root 0 6月 5 11:15 /root/dir1/file5
1466515 0 -rw-r--r-- 1 root root 0 6月 5 11:15 /root/dir1/file9
[root@localhost ~]# find /root/dir1 \( -name "file5" -o -name "file9" \) -exec rm -rvf {} \;
removed ‘/root/dir1/file5’
removed ‘/root/dir1/file9’
檔案打包及壓縮
建議針對目錄cd yang
Demo: 復制未打包的檔案到遠程主機
[root@yangs ~]# du -sh /etc
39M /etc
[root@yangs ~]# time scp -r /etc [email protected]:/tmp //將/etc目錄...
===打包,壓縮===
[root@yangs ~]# tar -czf etc1.tar.gz /etc //-z 呼叫gzip
[root@yangs ~]# tar -cjf etc2.tar.bz2 /etc //-j 呼叫bzip2
[root@yangs ~]# tar -cJf etc3.tar.xz /etc //-J 呼叫xz
[root@yangs ~]# ll -h etc*
-rw-r--r--. 1 root root 8.7M 3月 12 00:08 etc1.tar.gz
-rw-r--r--. 1 root root 7.5M 3月 12 00:08 etc2.tar.bz2
-rw-r--r--. 1 root root 4.8M 3月 12 00:09 etc3.tar.xz
===解壓,解包===
[root@yangs ~]# tar -tf sys.tar.xz
[root@yangs ~]# tar -xzvf etc1.tar.gz
[root@yangs ~]# tar -xvf etc1.tar.gz //無需指定解壓工具,tar會自動判斷
[root@yangs ~]# tar -xvf etc2.tar.bz2 -C /tmp //-C重定向到//tmp目錄
[root@yangs ~]# tar xf etc3.tar.xz
==解壓zip
[root@yangs ~]# unzip xxx.zip
====================================================================================
案例1:mysql物理備份及恢復
[root@localhost ~]# tar -cJf /backup/mysql.tar.xz /var/lib/mysql
[root@localhost ~]# tar -xf /backup/mysql.tar.xz -C /
案例2:mysql物理備份及恢復
[root@localhost ~]# cd /var/lib/mysql
[root@localhost mysql]# tar -cJf /backup/mysql.tar.xz *
[root@localhost mysql]# tar -xf /backup/mysql.tar.xz -C /var/lib/mysql
案例3:host A /etc (海量小檔案) --------> host A /tmp
[root@localhost ~]# tar -czf - /etc |tar -xzf - -C /tmp
案例4:host A /etc (海量小檔案) --------> host B /tmp
常規方法:
[root@localhost ~]# scp -r /etc 172.16.20.21:/tmp
建議方法:
==host B 監聽埠==
[root@hostb ~]# systemctl stop firewalld.service
[root@hostb ~]# nc -l 8888 |tar -xzf - -C /tmp
==host A ==
[root@localhost ~]# tar -czf - /etc | nc 172.16.20.21 8888
tar: Removing leading `/' from member names
轉載請註明出處,本文鏈接:https://www.uj5u.com/caozuo/146876.html
標籤:Linux
上一篇:存盤管理
下一篇:軟體包管理
