14日目ファイルの検索検索

見つける方法を探します

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.ファイルの種類によって型検索

F 簡易ファイル
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

シンボル 効果
-a
-o 若しくは
-not!

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

おすすめ

転載: www.cnblogs.com/baozexu/p/11372850.html