見つける方法を探します
1.名前で検索
[root@oldboyedu ~]# find ./ -name "*eth0"
名前を見つけます(大文字と小文字を区別しません)
[root@oldboyedu ~]# find ./ -iname "*eth0"
/ディレクトリの5Mより大きい3.検索/ etcファイル
[root@oldboyedu ~]# find /etc/ -size +5M
4.ファイルが5Mの/ etc /ディレクトリよりも小さい検索
[root@oldboyedu ~]# find /etc/ -size -5M
5.下に等しい5M、ファイル/ etc /ディレクトリを探します
[root@oldboyedu ~]# find /etc/ -size 5M
6.ファイルの種類によって型検索
D |
ディレクトリのファイル |
S |
ソケットソケットファイル |
リットル |
リンクファイル |
C |
キャラクタデバイス |
B |
ブロックデバイス |
7修正時刻によって-mtime検索
1.現在のディレクトリは、ファイルの種類で検索して、eth0を関連付けられた名前が記載されています
[root@oldboyedu ~]# find ./ -type f -iname "*eth0" | xargs ls -l
2.ファイルの種類の下に/ etc /ディレクトリを検索し、大きさは、その名前が.binファイルで終わる、5M以上であります
[root@oldboyedu ~]# find /etc/ -type f -size +5M name "*.bin"
3.ファイルタイプの下に/ etc /ディレクトリを検索し、名前はの.repoの終わりです
[root@oldboyedu ~]# find /etc/ -type f -name "*.repo"
4.検索/ devがデバイスのブロック型で、最初SDAの名前
[root@oldboyedu ~]# find /dev/ -type b -name "sda*" | xargs ls -l
5.検索/ devが、デバイス内の文字型であり、名前はTTYの始まりです
[root@oldboyedu ~]# find /dev/ -type c -name "tty*"
[root@oldboyedu ~]# for i in {1..31}; do date -s "2019/08/$i" ; touch file-$i ; done
6.デー7
[root@oldboyedu ~]# find ./ -type f -mtime 7
5.ユーザーとグループ-nogroupで-user -group -nouserを探します
6.find後の処理動作を見つけますか?
ファイルを見つけた後、ファイルが、どのように対処することが、デフォルトのアクションは、印刷にある見つける必要があります
-print |
印刷コンテンツ(デフォルト)を検索
|
-ls |
印刷コンテンツのフォーマットを見つけるための長い道のり
|
-delete |
見つかったファイルを削除します(唯一の空のディレクトリを削除します)
|
-OK |
バック自己定義されたシェルコマンドを持つ(あなたが運転するかどうかを求めるメッセージが表示されます)
|
-exec |
自己と、シェルコマンドの定義(-exec書かれた標準)の後ろ |
2.7日以前の内容をろ過した後、最後の7日の予約済みの内容を削除します
[root@oldboyedu ~]# find ./ -type f -mtime +7 -name "file-*"
3.コンテンツの最後の7日間は除外されます
[root@oldboyedu ~]# find ./ -type f -mtime -7 -name "file-*"
5.ローカルファイルはバックアップファイル(プログラムの実際の使用)の3ヶ月を保持するバックアップファイル、バックアップサーバーの最後の7日間残ります
find /backup/ -iname "*.bak" -mtime +7 -delete find /backup/ -iname "*.bak" -mtime +180 -delete
所有者はジャッキで検索
[root@xuliangwei ~]# find /home -user jack #查找属组是admin [root@xuliangwei ~]# find /home -group admin
所有者はジャッキーで見つけ、そのジャックのグループであります
[root@oldboyedu ~]# find /home/ -type d -user jacky group jack
何の所有者を見つけるん
[root@xuliangwei ~]# find /home -nouser #查找没有属组
[root@xuliangwei ~]# find /home -nogroup #查找没有属主或属组
[root@xuliangwei ~]# find / -nouser -nogroup
-print印刷コンテンツ(デフォルト)の意味を見つけるために---無視アクション
---無視のやり方長い形式のコンテンツを見つけるために、-ls印刷を
xargsのLSとディレクトリを削除(ファイルを見つけるために、-lを削除するには、[削除]を、のみ|を)空のディレクトリを削除---無視
|カスタムシェルコマンド(あなたが運転するかどうかのプロンプトが表示されます)---無視すると-okの後ろにxargsのRM -f
-exec書かれた(-execは、カスタムシェルコマンドに続く標準;)| xargsの
[ルート〜@oldboyedu]型F ./#時間-name "ファイルの検索" -f {} -exec RM、
レアル0m6.585sユーザーは0m3.617s
SYSが0m3.532s
./ -type時間を見つける[ルート@ oldboyedu〜]#を-name F "ファイル " | RM -f xargsの
実がユーザー0m0.016s SYS 0m0.146sを0m0.152s
ファイルのは/ var / log /タイプ検索、および名前は.logのを終了し、7日前にされ、その後、削除します
[root@oldboyedu ~]# #find /var/log/ -type f -name "*.log" -mtime +7 -exec rm -f {} \;
[root@oldboyedu ~]# #find /var/log/ -type f -name "*.log" -mtime +7 -delete
[root@oldboyedu ~]# #find /var/log/ -type f -name "*.log" -mtime +7 | xargs rm -f
論理演算子4.find
5.find練習
クエリファイル#grepフィルタコンテンツを見つけます
クエリの結果は、パラメータのgrepなどのファイルをifnd
[root@oldboyedu ~]# find /etc/ -type f | xargs grep "log_group" --color=auto /etc/audit/auditd.conf:log_group = root
カレントディレクトリを検索1.、すべてのマスターファイルのルートではありません
[root@oldboyedu ~]# find /home/ ! -user root -ls
[root@oldboyedu ~]# find /home/ -not -user root -ls # 使用较少
2.それはジャックの主要部分である、現在のディレクトリを検索し、ファイルのサイズよりも大きい1K
[root@oldboyedu ~]# find /home/ -type f -a -user jacky -a -size +1k
3.最後にルートまたはXMLに現在のディレクトリ内の通常のファイルの所有者を探します
[root@xuliangwei ~]# find . -type f -a \( -user hdfs o -name '*.xml' \)
1. / varディレクトリを見つけ、所有者がルートではなく、ファイル名が「F」のファイルで始まりません
[root@oldboyedu ~]# find /var/ -type f ! -user root a ! -name "f*"
2.查找/var目录下属主为root,且属组为mail的所有文件
[root@oldboyedu ~]# find /var/ -type f -user root -a group mail
3.查找/var目录下不属于root、lp的所有文件
[root@oldboyedu ~]# find /var/ -type f ! -user root -a ! -user lp
4.查找/var目录下最近一周内产生的文件,同时属主不为root,也不是 postfix的文件
[root@oldboyedu ~]# find /var/ -type f -mtime -7 ! user root ! -name "postfix"
5.查找/etc目录下大于1M且类型为普通文件的所有文件
[root@oldboyedu ~]# find /etc/ -type f -size +1M
6.将/etc/中的所有目录(仅目录)复制到/tmp下,目录结构不变
[root@oldboyedu ~]# find /etc/ -type d -exec mkdir -p /tmp/{} \;
7.将/etc目录复制到/var/tmp/,/var/tmp/etc的所有目录权限 777/var/tmp/etc目录中所有文件权限666
[root@oldboyedu ~]# cp /etc/ /var/tmp/ -rp [root@oldboyedu ~]# find /var/tmp/etc/ -type d -exec chmod 777 {} \;
[root@oldboyedu ~]# find /var/tmp/etc/ -type f -exec chmod 666 {} \;
8.保留/var/log/下最近7天的日志文件,其他全部删除
[root@oldboyedu ~]# find /var/log/ -type f -mtime +7 -exec rm -f {} \;
2 今日总结
1.find 查找文件 文件名称 文件大小 文件类型 修改时间 用户用户组
2.find处理动作 -print 忽略 默认送 -ls 长格式显示,不能加参数,所以忽略 -delete 删除文件,删除目录必须确保目录为空 -ok 执行command命令,但会提示,忽略 -exec 执行command命令
klk