常用搜索命令------whereis,which,locate,find

来源:http://www.cnblogs.com/andreking/archive/2016/08/18/5782575.html
-Advertisement-
Play Games

摘自:http://312788172.iteye.com/blog/730280 我們經常在linux要查找某個文件,但不知道放在哪裡了,可以使用下麵的一些命令來搜索。這些是從網上找到的資料,因為有時很長時間不會用到,當要用的時候經常弄混了,所以放到這裡方便使用。 which 查看可執行文件的位置 ...


摘自:http://312788172.iteye.com/blog/730280

我們經常在linux要查找某個文件,但不知道放在哪裡了,可以使用下麵的一些命令來搜索。這些是從網上找到的資料,因為有時很長時間不會用到,當要用的時候經常弄混了,所以放到這裡方便使用。 
which       查看可執行文件的位置 
whereis    查看文件的位置 
locate       配 合資料庫查看文件位置 
find          實際搜尋硬碟查詢文件名稱 

1、which 
語法: 
[root@redhat ~]# which 可執行文件名稱 
例如: 
[root@redhat ~]# which passwd 
/usr/bin/passwd 
which是通過 PATH環境變數到該路徑內查找可執行文件,所以基本的功能是尋找可執行文件 

2、whereis 
語法: 
[root@redhat ~]# whereis [-bmsu] 文件或者目錄名稱 
參數說 明: 
-b : 只找二進位文件 
-m: 只找在說明文件manual路徑下的文件 
-s : 只找source源文件 
-u : 沒有說明文檔的文件 
例如: 
[root@redhat ~]# whereis passwd 
passwd: /usr/bin/passwd /etc/passwd /usr/share/man/man1/passwd.1.gz /usr/share/man/man5/passwd.5.gz 
將和passwd文件相關的文件都查找出來 

[root@redhat ~]# whereis -b passwd 
passwd: /usr/bin/passwd /etc/passwd 
只將二進位文件 查找出來 

和find相比,whereis查找的速度非常快,這是因為linux系統會將 系統內的所有文件都記錄在一個資料庫文件中,當使用whereis和下麵即將介紹的locate時,會從資料庫中查找數據,而不是像find命令那樣,通 過遍歷硬碟來查找,效率自然會很高。 
但是該資料庫文件並不是實時更新,預設情況下時一星期更新一次,因此,我們在用whereis和locate 查找文件時,有時會找到已經被刪除的數據,或者剛剛建立文件,卻無法查找到,原因就是因為資料庫文件沒有被更新,所以在使用前需要先更新資料庫文件,命令為: updatedb

3、 locate 
語法: 
[root@redhat ~]# locate 文件或者目錄名稱 
例 如: 
[root@redhat ~]# locate passwd 
/home/weblogic/bea/user_projects/domains/zhanggongzhe112/myserver/stage/_appsdir_DB_war/DB.war/jsp/as/user/passwd.jsp
/home/weblogic/bea/user_projects/domains/zhanggongzhe112/myserver/stage/_appsdir_admin_war/admin.war/jsp/platform/passwd.jsp
/lib/security/pam_unix_passwd.so 
/lib/security/pam_passwdqc.so 
/usr/include/rpcsvc/yppasswd.x 
/usr/include/rpcsvc/yppasswd.h 
/usr/lib/perl5/5.8.5/i386-linux-thread-multi/rpcsvc/yppasswd.ph 
/usr/lib/kde3/kded_kpasswdserver.la 
/usr/lib/kde3/kded_kpasswdserver.so 
/usr/lib/ruby/1.8/webrick/httpauth/htpasswd.rb 
/usr/bin/vncpasswd 
/usr/bin/userpasswd 
/usr/bin/yppasswd 
………… 

4、 find 
語法: 
[root@redhat ~]# find 路徑 參數 
參 數說明: 
時間查找參數: 
-atime n :將n*24小時記憶體取過的的文件列出來 
-ctime n :將n*24小時內改變、新增的文件或者目錄列出來 
-mtime n :將n*24小時內修改過的文件或者目錄列出來 
-newer file :把比file還要新的文件列出來 
名稱查找參數: 
-gid n       :尋找群組ID為n的文件 
-group name  :尋找群組名稱為name的文件 
-uid n       :尋找擁有者ID為n的文件 
-user name   :尋找用戶者名稱為name的文件 
-name file   :尋找文件名為file的文件(可以使用通配符) 
例 如: 
[root@redhat ~]# find / -name zgz 
/home/zgz 
/home/zgz/zgz 
/home/weblogic/bea/user_projects/domains/zgz 
/home/oracle/product/10g/cfgtoollogs/dbca/zgz 
/home/oracle/product/10g/cfgtoollogs/emca/zgz 
/home/oracle/oradata/zgz 

[root@redhat ~]# find / -name '*zgz*' 
/home/zgz 
/home/zgz/zgz1 
/home/zgz/zgzdirzgz 
/home/zgz/zgz 
/home/zgz/zgzdir 
/home/weblogic/bea/user_projects/domains/zgz 
/home/weblogic/bea/user_projects/domains/zgz/zgz.log00006 
/home/weblogic/bea/user_projects/domains/zgz/zgz.log00002 
/home/weblogic/bea/user_projects/domains/zgz/zgz.log00004 
/home/weblogic/bea/user_projects/domains/zgz/zgz.log 
/home/weblogic/bea/user_projects/domains/zgz/zgz.log00008 
/home/weblogic/bea/user_projects/domains/zgz/zgz.log00005 

當我們用whereis和locate無法查找到我們需要的文件時,可以使用find,但是find是在硬碟上遍歷查 找,因此非常消耗硬碟的資源,而且效率也非常低,因此建議大家優先使用whereis和locate。 
locate 是在資料庫里查找,資料庫大至每天更新一次。 
whereis 可以找到可執行命令和man page 
find 就是根據條件查找文件。 
which 可以找到可執行文件和別名(alias)


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • http://btmiller.com/2015/04/13/get-list-of-keys-from-dictionary-in-python-2-and-3.html Get a List of Keys From a Dictionary in Both Python 2 and Pytho ...
  • SQL Server分頁查詢幾種方式介紹 0. 序言 1. TOP…NOT IN… 2. ROW_NUMBER() 3. OFFSET…FETCH 4. 執行計劃 5. 補充 ...
  • http://askubuntu.com/questions/656610/trying-to-install-mysql-connector-for-python-3?rq=1 trying to install mysql-connector for python 3 trying to ins ...
  • http://stackoverflow.com/questions/4960048/python-3-and-mysql http://stackoverflow.com/questions/4960048/python-3-and-mysql up vote61down votefavorite ...
  • 上一章給大家說的是資料庫的視圖,存儲過程等等操作,這章主要講索引,以及索引註意事項,如果想看前面的文章,url如下: MYSQL入門全套(第一部) MYSQL入門全套(第二部) 索引簡介 索引是對資料庫表中一個或多個列(例如,employee 表的姓名 (name) 列)的值進行排序的結構。如果想按 ...
  • mysql的性能優化包羅甚廣:索引優化,查詢優化,查詢緩存,伺服器設置優化,操作系統和硬體優化,應用層面優化(web伺服器,緩存)等等。這裡的記錄的優化技巧更適用於開發人員,都是從網路上收集和自己整理的,主要是查詢語句上面的優化,其它層面的優化技巧在此不做記錄。查詢的開銷指標:執行時間檢查的行數返回 ...
  • 在傳統製造業,每一次產業結構的升級都是高新技術轉化為生產力的結果。換一句話說,信息化的集成應用水平一定程度左右著企業業務能力的提升和企業的未來發展。 ...
  • 摘自:http://www.cnblogs.com/hopeworld/archive/2011/04/08/2009252.html 在Windows中可以在某些路徑中查找文件,也可以設定不在某些路徑中查找文件,下麵用Linux中的find的命令結合其-path -prune參數來看看在Linux ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...