學(xué)習(xí)啦 > 學(xué)習(xí)電腦 > 網(wǎng)絡(luò)知識 > 網(wǎng)絡(luò)技術(shù) >

Linux如何使用locate命令查找數(shù)據(jù)搜索數(shù)據(jù)庫

時間: 加城1195 分享

  通常在Linux查找數(shù)據(jù)庫我們都使用find,那么除了find命令我們還可以用locate命令,可以在搜尋數(shù)據(jù)庫時快速找到檔案,具體怎么使用呢?下面小編就給大家詳細(xì)介紹下locate命令的用法。

  Linux如何使用locate命令查找數(shù)據(jù)

  1.命令格式:

  Locate [選擇參數(shù)] [樣式]

  2.命令功能:

  locate命令可以在搜尋數(shù)據(jù)庫時快速找到檔案,數(shù)據(jù)庫由updatedb程序來更新,updatedb是由cron daemon周期性建立的,locate命令在搜尋數(shù)據(jù)庫時比由整個由硬盤資料來搜尋資料來得快,但較差勁的是locate所找到的檔案若是最近才建立或 剛更名的,可能會找不到,在內(nèi)定值中,updatedb每天會跑一次,可以由修改crontab來更新設(shè)定值。(etc/crontab)

  locate指定用在搜尋符合條件的檔案,它會去儲存檔案與目錄名稱的數(shù)據(jù)庫內(nèi),尋找合乎范本樣式條件的檔案或目錄錄,可以使用特殊字元(如”*” 或”?”等)來指定范本樣式,如指定范本為kcpa*ner, locate會找出所有起始字串為kcpa且結(jié)尾為ner的檔案或目錄,如名稱為kcpartner若目錄錄名稱為kcpa_ner則會列出該目錄下包括 子目錄在內(nèi)的所有檔案。

  locate指令和find找尋檔案的功能類似,但locate是透過update程序?qū)⒂脖P中的所有檔案和目錄資料先建立一個索引數(shù)據(jù)庫,在 執(zhí)行l(wèi)oacte時直接找該索引,查詢速度會較快,索引數(shù)據(jù)庫一般是由操作系統(tǒng)管理,但也可以直接下達(dá)update強迫系統(tǒng)立即修改索引數(shù)據(jù)庫。

  3.命令參數(shù):

  -e 將排除在尋找的范圍之外。

  -1 如果 是 1.則啟動安全模式。在安全模式下,使用者不會看到權(quán)限無法看到 的檔案。這會始速度減慢,因為 locate 必須至實際的檔案系統(tǒng)中取得檔案的 權(quán)限資料。

  -f 將特定的檔案系統(tǒng)排除在外,例如我們沒有到理要把 proc 檔案系統(tǒng)中的檔案 放在資料庫中。

  -q 安靜模式,不會顯示任何錯誤訊息。

  -n 至多顯示 n個輸出。

  -r 使用正規(guī)運算式 做尋找的條件。

  -o 指定資料庫存的名稱。

  -d 指定資料庫的路徑

  -h 顯示輔助訊息

  -V 顯示程式的版本訊息

  4.使用實例:

  實例1:查找和pwd相關(guān)的所有文件

  命令:

  locate pwd

  輸出:

  代碼如下:

  peida-VirtualBox ~ # locate pwd

  /bin/pwd

  /etc/.pwd.lock

  /sbin/unix_chkpwd

  /usr/bin/pwdx

  /usr/include/pwd.h

  /usr/lib/python2.7/dist-packages/twisted/python/fakepwd.py

  /usr/lib/python2.7/dist-packages/twisted/python/fakepwd.pyc

  /usr/lib/python2.7/dist-packages/twisted/python/test/test_fakepwd.py

  /usr/lib/python2.7/dist-packages/twisted/python/test/test_fakepwd.pyc

  /usr/lib/syslinux/pwd.c32

  /usr/share/help/C/empathy/irc-join-pwd.page

  /usr/share/help/ca/empathy/irc-join-pwd.page

  /usr/share/help/cs/empathy/irc-join-pwd.page

  /usr/share/help/de/empathy/irc-join-pwd.page

  /usr/share/help/el/empathy/irc-join-pwd.page

  實例2: 搜索etc目錄下所有以sh開頭的文件

  命令:

  locate /etc/sh

  輸出:

  代碼如下:

  peida-VirtualBox ~ # locate /etc/sh

  /etc/shadow

  /etc/shadow-

  /etc/shells

  peida-VirtualBox ~ #

  補充:MySQL 數(shù)據(jù)庫常用命令

  create database name; 創(chuàng)建數(shù)據(jù)庫

  use databasename; 進(jìn)入數(shù)據(jù)庫

  drop database name 直接刪除數(shù)據(jù)庫,不提醒

  show tables; 顯示表

  describe tablename; 查看表的結(jié)構(gòu)

  select 中加上distinct去除重復(fù)字段

  mysqladmin drop databasename 刪除數(shù)據(jù)庫前,有提示。

  顯示當(dāng)前mysql版本和當(dāng)前日期

  select version(),current_date;

  數(shù)據(jù)庫維護方法

  在MySQL使用的過程中,在系統(tǒng)運行一段時間后,可能會產(chǎn)生碎片,造成空間的浪費,所以有必要定期的對MySQL進(jìn)行碎片整理。

  當(dāng)刪除id=2的記錄時候,發(fā)生的現(xiàn)象

  這個時候發(fā)現(xiàn)磁盤的空間并沒有減少。這種現(xiàn)象就叫做碎片化(有一部分的磁盤空間在數(shù)據(jù)刪除以后(空),還是無法被操作系統(tǒng)所使用。)

  常見的優(yōu)化:

  # alter table xxx engine myisam;

  # optimize table t1;

  注意: 在實際開發(fā)的過程中,上面兩個語句盡量少使用,因為在使用的過程中,MySQL的表的結(jié)構(gòu)會整體全部重新整理,需要消耗很多的資源,建議在凌晨兩三點鐘的時候執(zhí)行。(在linux下有定時器腳本可以執(zhí)行,crontab)


4015157