您好,登錄后才能下訂單哦!
下面介紹的是程序包管理的前端工具yum、程序包管理器編譯安裝、sed命令、find文件查找。
一、Linux程序包管理:程序包管理的【前端工具】
1、yum軟件包倉庫簡介
CentOS系的管理工具有yum和dnf。yum是一款發行版的Linux,其使用的默認程序包管理工具為rpm。
URL是yum定位軟件包倉庫和倉庫中程序文件的主要標識方式,表示如下:
例如:schema://[username@]hostname/PATH/TO/DOCUMENT[paramers][methord]
(例子中的Web站點可以表示為http/https,即具體實例可以為:http://www.163.com)
yum是【C/S】架構,其中的服務器稱為軟件倉庫,即yum倉庫。yum在客戶端需要書寫URL以指定服務器及程序包路徑;在服務器上,軟件倉庫就是一個目錄,在此目錄中包含了程序包文件和元數據文件。而元數據文件統一存放在repodate的目錄中,也可以說成,repodate目錄所在的路徑即為軟件倉庫的命令。
常用的第三方yum倉庫有Fedora和EPEL,可以到官方站點或鏡像站點中,下載epel-release程序包,并且使用rpm命令安裝至對應的Linux發行版本,在/etc/yum.repos.d目錄中,會多出一個epel.repo的文件,更新repolist即可使用。其中,要求Linux虛擬機能夠連接互聯網;
2、創建本地yum倉庫:createrepo命令
createrepo:(createrepo - Create repomd (xml-rpm-metadata) repository)
格式:createrepo [options] <directory>
格式中的 <directory> 存放程序包的目錄
例如:createrepo /PATH/TO/PACKAGES
# yum-config-manager --add-repo=URL
顯示:已加載插件:fastestmirror, refresh-packagekit
adding repo from: URL
[URL]
name=added from: URL
baseurl=URL
enabled=1
3、yum的C/S架構中【客戶機】的使用
用戶自定義的repository的指向信息,可以寫在主配置文件中;也可以將用戶自定義的repository的指向信息,以.repo為文件后綴名,并且存放于/etc/yum.repos.d目錄中。
(1)、主配置文件
主配置文件:/etc/yum.conf;其只提供yum倉庫指向信息的公共配置內容。
注意:該文件一般情況下,不進行任何修改。
yum的【主配置文件】在下列目錄文件中:/etc/yum.conf。其中的信息是ini風格的配置信息模式,即分段式配置內容,具體分段式如下所示:
[repositoryid]
statements
注意:所有的配置語句,其生效范圍是從第一個[]開始,帶下一個[]結束,具體示例如下所示:
[repo1]
statements
[repo2]
statements
注意:a.repository必須全局唯一
b.repository不能包括.和_之外的任何特殊字符,可以包含字母和數字,字母嚴格區分大小寫機制。
yum主配置文件具體代碼顯示如下:
# yum /etc/yum.conf
[main]
cachedir=/var/cache/yum/$basearch/$releasever
keepcache=0
debuglevel=2
logfile=/var/log/yum.log
exactarch=1
obsoletes=1
gpgcheck=1
plugins=1
installonly_limit=5
bugtracker_url=http://bugs.centos.org/set_project.php?project_id=23&ref=http://bugs.centos.org/bug_report_page.php?category=yum
distroverpkg=centos-release
例中的$releasever、$basearch為yum配置文件的變量,具體如下:
$releasever:當前操作系統的發行版本的主版本號;
例如:CentOS 7.2-1511,其發行版本的主版本號是7,即$releasever為7
CentOS 6.7,其發行版本的主版本號是6,即$releasever為6
$basearch:當前計算機所使用的基礎平臺架構類型;
例如:Intel兼容機$basearch如下兩種:
i686
x86_64
apple計算機設備$basearch如下兩種:
ppc
ppc64
(2)、片段配置文件:/etc/yum.repos.d/*.repo
片段配置文件中,每一個以.repo為后綴名的文件,即為一個倉庫文件;這樣的每個文件中可以配置指向一個或多個yum倉庫。
yum程序在【查找yum倉庫】的時候,是根據這些配置文件來查找的;每一次可能會找到多個yum倉庫,從所有可以使用的倉庫中查找最新版本的程序包并緩存到本地進行安裝,升級等操作。
同類的多個倉庫被稱為鏡像,只要有一個可用即可;不同類的倉庫也可以同時存在多個,yum可以同時使用這些倉庫。
4、.repo文件的定義
.repo定義格式如下:
[repositoryid]
name=Full name of repository
baseurl=schema1://hostname/PATH/TO/REPODATA
schema2://hostname/PATH/TO/REPODATA
schema3://hostname/PATH/TO/REPODATA
schema4://hostname/PATH/TO/REPODATA
#mirrorlist=mirror_url
enabled={0|1}
gpgcheck={0|1}
gpgkey=schema://hostname/PATH/TO/PUBLIC_KEY_FILE
failovermethod={roundrobin|priority}
enablegroups={1|0}
cost=num
定義格式中,各段解釋如下:
schema可以為以下兩類: http[s]、ftp、nfs:網絡服務器指向;
file:本地服務器指向。
enabled={0|1}:0表示禁用此倉庫指向;
1表示啟用;如果沒有enabled語句,默認為啟用狀態。
gpgcheck={0|1}:0表示不進行程序包認證;
1表示認證;如果為1,需要指定認證所需要的公鑰文件,需要使用gpgkey語句。
gpgkey=schema://hostname/PATH/TO/PUBLIC_KEY_FILE
例如:gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-$releasever
failovermethod={roundrobin|priority} 故障倒換方法,兩種模式具體如下:
roundrobin:隨機查找,默認的方法;
priority:按照順序依次選擇
enablegroups={1|0}:0表示禁用;
1表示啟用。
cost=num,默認所有倉庫的開銷值都是1000;
例:baseurl=https://mirrors.aliyun.com/epel/7/x86_64
一般的repo指向內容,具體例子如下:
[repoid]
name=
baseurl=
#mirrorlist=
enbaled=1
gpgcheck=0
#gpgkey=
5、yum命令(CentOS6)
yum:(yum - Yellowdog Updater Modified)
格式:yum [options] [command] [package ...]
(1)、[options]
-y, --assumeyes:對于yum執行過程中與用戶交互的問題,全部以yes回答。
-q, --quiet:安靜模式,在某一次yum執行過程中,沒有任何信息輸出到stdout。
--enablerepo=repoidglob 啟用
--disablerepo=repoidglob 禁用
在某一次yum執行過程中明確的規定啟用或禁用某個repository指向;在使用了這樣的選項之后,倉庫指向文件中的enabled語句的作用將失效。
--noplugins:在某一次yum執行過程中,明確指出不使用任何插件。
--nogpgcheck:在某一次yum執行過程中,明確指出不驗證程序包完整性,在倉庫指向文件中的gpgcheck=1語句會失效。
(2)、[command]
* install package1 [package2] [...] 安裝程序包
注意:a.如果只是給出程序包名稱,yum搜索所有倉庫,并找到最新版本緩存安裝;
b.如果給出程序包的名稱及版本,則查找安裝指定版本的程序包;
c.如果給出的程序包是完整的程序包名,則只是查找某一個程序包;
d.程序包名稱可以使用globbing,(* ? [] [^])
* update [package1] [package2] [...] 程序包升級
* update-to [package1] [package2] [...]
* check-update
* upgrade [package1] [package2] [...]
* upgrade-to [package1] [package2] [...]
* downgrade package1 [package2] [...] 程序包降級
* remove | erase package1 [package2] [...] 卸載程序包
* list [...]
例如:yum list LIST OPTIONS
LIST OPTIONS為:
all: 顯示所有的程序包,包括已經安裝的和尚未安裝但可用的。注意:anaconda:其CentOS系統的安裝器,在安裝操作系統的時候一并安裝的程序包;# yum list all
installed:顯示所有已經安裝的程序包; # yum list install
available:顯示所有尚未安裝但可以安裝的程序包; # yum list available
updates:顯示所有可以升級更新的程序包; # yum list updates
* info [...] 詳細信息
例如:yum info LIST OPTIONS
LIST OPTIONS為:
all: 顯示所有的程序包,包括已經安裝的和尚未安裝但可用的。注意:anaconda:為CentOS系統的安裝器,在安裝操作系統的時候一并安裝的程序包; # yum info all
installed:顯示所有已經安裝的程序包; # yum info install
available:顯示所有尚未安裝但可以安裝的程序包; # yum info available
updates:顯示所有可以升級更新的程序包; # yum info updates
name[globbing]
* provides | whatprovides feature1 [feature2] [...]
【查看指定的特性】是由哪個程序包提供的;
* clean [ packages | metadata | expire-cache | rpmdb | plugins | all ]
清理本地緩存信息
* makecache 構建緩存
* groupinstall group1 [group2] [...] 程序包組安裝
* groupupdate group1 [group2] [...] 程序包組更新
* grouplist [hidden] [groupwildcard] [...] 程序包組顯示
* groupremove group1 [group2] [...] 程序包組刪除
* groupinfo group1 [...] 程序包組詳細信息
* search string1 [string2] [...]
根據關鍵字進行匹配,默認情況下,搜索程序包名稱及匯總信息;這是一種模糊搜索。
* shell [filename]
給yum提供一個【交互式命令的操作界面】
* localinstall rpmfile1 [rpmfile2] [...] 本地程序包安裝
(maintained for legacy reasons only - use install)
* localupdate rpmfile1 [rpmfile2] [...]
(maintained for legacy reasons only - use update)
實現本地程序包安裝,即:不依賴于軟件倉庫,直接對rpm格式包文件進行操作。這兩個命令已經被停用,使用install和update取代。
* reinstall package1 [package2] [...] 重新安裝
* deplist package1 [package2] [...] 顯示每個程序包所有的依賴關系;
* repolist [all|enabled|disabled] 元數據信息
列表顯示yum倉庫的元數據信息;在沒有給出后面的參數的時候,默認為enabled;
* version [ all | installed | available | group-* | nogroups* | grouplist | groupinfo ]
* history [info|list|packages-list|packages-info|summary|addon-info|redo|undo|rollback|new|sync|stats]
查看yum事務的歷史;安裝、升級、卸載等操作的時候,yum會開啟事務;
* load-transaction [txfile]
重新啟動已經停止的事務;
* check 認證
* help [command]
6、CentOS7中的yum命令
CentOS7中的yum命令與CentOS6中的yum命令不同點為,程序包組的管理命令不同:
* groups [...]
groups {install | remove | list | info | update}
別名:groupinstall groupremove grouplist groupinfo groupudpate
* autoremove [package1] [...] 自動卸載
* repoinfo [all|enabled|disabled]
7、yum的repo配置文件中的【變量】:
$releasever:當前操作系統的發行版本的主版本號;
例如:CentOS 7.2-1511,其發行版本的主版本號是7,即$releasever為7
CentOS 6.7,其發行版本的主版本號是6,即$releasever為6
$basearch:當前計算機所使用的基礎平臺架構類型;
例如:Intel兼容機$basearch如下兩種:
i686
x86_64
apple計算機設備$basearch如下兩種:
ppc
ppc64
$arch:平臺架構類型
$YUM0~$YUM9:yum內置的由用戶自定義的10個變量;
例如:.repo中baseurl=https://mirrors.aliyun.com/epel/7/x86_64
8、為什么要用這些變量
因為服務器(repository)必須能夠提供所有的常有發行版本及平臺相關的程序包,但是服務器無法預測任何一個客戶端具體的版本使用情況,所以應用變量來進行替換,讓用戶使用時自行選擇。
二、CentOS程序包管理器之編譯安裝
1、為什么要進行源代碼編譯安裝?
a.對應的程序包并不能直接獲取到;
b.已經編譯好的二進制中,尚不包含我們所需要的功能;
c.已經編譯好的二進制中,包含的功能太多,我們并不需要;
2、兩種源代碼包:
(1)、由程序員直接打包的源代碼:name-VERSION.tar.gz
(2)、由第三方利用rpm工具制作的rpm源代碼包:name-VERIONS-release.src.rpm ;/usr/src/name-VERIONS
3、源代碼的組織形式:
(1)、多文件組成
(2)、文件中的代碼之間,甚至是不同文件的代碼段之間都可能存在依賴關系;
4、源代碼的項目管理工具:
(1)、C/C++項目管理工具:make
(2)、Java項目管理工具:maven
5、源代碼編譯安裝過程:
源代碼 --> 預處理(預處理器,cpp) --> 編譯(編譯器,gcc) --> 匯編(匯編器) --> 鏈接(鏈接器) --> 用于執行操作的二進制文件
6、源代碼文件
針對于每個需要編譯的源代碼文件,都可能會有一個或多個被他依賴的文件或他【所依賴的文件】,這樣的信息會被保存到一個配置文件中;這個配置文件會告訴我們:
(1)、調用哪個預處理器,如何進行預處理;
(2)、調用哪個編譯器,如何進行編譯;
(3)、文件的編譯順序等等;
源代碼文件一般是【makefile文件】,這樣的makefile文件并不是事先存在的,也不是對所有用戶的需求都一視同仁的。程序員可以使用專用的工具,來對于所有的源代碼文件進行【內容分析和抽取】,構建出makefile文件。所有的makefile文件都有一個統一的【模版】,即【Makefile.in】。用戶可以根據自己的需要,自行構建makefile文件,從而實現能夠滿足自己需求的編譯過程。其中,幫助用戶生成makefile文件的,通常是一個名為【configure的腳本文件】。
7、兩種開發工具:
(1)、autoconf:幫助用戶生成configure腳本
(2)、automake:幫助用戶生成Makefile.in的模版文件
對于任何的源代碼包,在解壓縮之后,都會提供INSTALL或README的文檔文件,我們在編譯操作之前,最好先查閱此類文件的內容, 以【確定編譯過程】。
8、開源程序源代碼的兩種獲取方式:
(1)、官方自建的站點:
apache.org(ASF)
mariadb.org
(2)、代碼的托管站點
SourceForge
Github
code.google.com
對源代碼編譯時常用到的編譯器為:gcc (GNU C Complier)
9、【開發環境】的安裝的兩個步驟:
步驟一:
CentOS7:yum groups install "開發工具" 或:yum groups install "Development Tools"
CentOS6:yum groupinstall "Development Tools" "Server Platform Development" "Desktop Platform Development"
步驟二:
yum install make automake autoconf gcc glibc qt ncurses
10、Linux系統中的【編譯安裝程序】的三大步驟:
(1)、configure [options...]
(2)、make
(3)、make install
第一步:./configure [options...] [VAR=VALUE]...
常用選項[options...]:
(1)、安裝路徑的設定:
--prefix=/PATH/TO/SOMEWHERE
指定默認的程序安裝路徑,如果不給該選項,默認路徑/usr/local/
--sysconfdir=DIR
指定配置文件的安裝路徑
(2)、系統類型:
(3)、可選特性:
--disable-FEATURE
在編譯過程中禁用某種特性或功能
--enable-FEATURE[=ARG]
在編譯過程中啟用某個特性或功能
(4)、可選程序包:
--with-PACKAGE[=ARG]
在編譯過程中,選擇使用額外的程序包
--without-PACKAGE
在編譯過程中,不使用額外的程序包
第二步:make
第三步:make install
11、編譯收尾工作:
編譯安裝之后,/usr/local/apache2里面會包含bin, sbin, etc, lib, lib64, include, man, ...,需要進行收尾工作,分別導出,具體如下。
(1)、導出二進制文件:
創建一個文件: /etc/profile.d/httpd.sh
export PATH=/usr/local/apache2/bin:/usr/local/apache2/sbin:$PATH
(2)、導出庫文件:
創建一個文件:/etc/ld.so.conf.d/httpd.conf
/usr/local/apache2/lib64
ldconfig [-v]
(3)、導出頭文件:
在/usr/include目錄中,為編譯安裝的軟件創建頭文件的符號鏈接:
ln -sv /usr/local/apache2/include /usr/include/httpd
(4)、導出幫助文件:
CentOS6: /etc/man.config
新添加一行:MANPATH=/usr/local/apache2/man
CentOS7: /etc/man_db.conf
新添加一行:MANPATH_MAP=/usr/local/apache2/bin /usr/local/apache2/man
示例:寫一個腳本,要求:
1.為用戶提供所有磁盤的列表;
2.當用戶選定磁盤之后,提示用戶該操作有風險,詢問是否繼續;
3.如果用戶選擇no,則退出腳本;
4.如果用戶選擇yes,【抹除該磁盤上的所有分區】;
#!/bin/bash
#
select I in fdisk -l | grep -o "/dev/sd[a-z]\>" quit ; do
case $I in
/dev/sd[a-z])
read -p "操作有風險,是否繼續? " CHOICE
[ -z $CHOICE ] && CHOICE=no
case $CHOICE in
yes)
dd if=/dev/zero of=$I bs=512 count=1
sync
sleep 1
sync
sleep 1
sync
;;
no)
break
;;
esac
;;
quit)
break
;;
*)
continue
;;
esac
done
12、舉例安裝httpd-2.4.18
(1)、首先要解決開發工具環境;
yum groupinstall "Development tools"
(2)、使用適合httpd-2.4.18版本的apr及apr-util工具;
安裝apr工具
~]# tar xf apr-1.5.2.tar.bz2 -C /usr/src
~]# cd /usr/src/apr-1.5.2
~]# ./configure --prefix=/usr/local/apr-1.5.2
~]# make
~]# make install
(3)、安裝arp-util工具
~]# tar xf apr-util-1.5.4.tar.bz2 -C /usr/src
~]# cd /usr/src/apr-util-1.5.4
~]# ./configure --prefix=/usr/local/apr-util-1.5.4 --with-apr=/usr/local/apr-1.5.2
~]# make
~]# make install
(4)、需要安裝pcre-devel以滿足httpd的正則表達式使用需求;
yum -y install pcre-devel
(5)、編譯安裝httpd:
# tar xf httpd-2.4.18.tar.gz -C /usr/src
# cd /usr/src/httpd-2.4.18
# ./configure --with-apr=/usr/local/apr-1.5.2 --with-apr-util=/usr/local/apr-util-1.5.4
# make
# make install
(6)、收尾:
a.導出二進制文件:
vim /etc/profile.d/httpd.sh
export PATH=/usr/local/apache2/bin:$PATH
source /etc/profile.d/httpd.sh
b.導出庫文件:
vim /etc/ld.so.conf.d/httpd-x86_64.conf
/usr/local/apache2/modules
ldconfig -v
c.導出頭文件:
ln -sv /usr/local/apache2/include /usr/include/httpd
三、sed命令
1、sed簡介
sed:Stream EDitor,即流編輯器,以行為單位對一個或多個文件進行編輯處理;每一次sed都會處理給定文件中的【一行內容】。
在sed處理文本時,將正在處理的當前行存儲到臨時的緩沖區中,稱為“模式空間”;用當前行去匹配給定的PATTERN,如果能匹配,則使用command編輯處理;如果不匹配,則默認輸出至標準輸出;然后繼續處理下一行,直到文件的末尾。
默認情況下,sed的所有處理行為不會影響源文件的內容。我們一般會使用sed命令來自動編輯一個或多個文件,簡化對文件的【循環操作】。
2、sed命令
(sed - stream editor for filtering and transforming text)
格式:sed [OPTION]... 'script' [input-file]...
(1)、常用選項[OPTION]:
-n, --quiet, --silent:對于不能匹配模式的行,默認不輸出到屏幕;
-e script, --expression=script:多條件編輯;
-f script-file, --file=script-file:從指定的script-file中讀取腳本
注意:script-file為一個能夠定位到腳本文件的路徑,最好為絕對路徑
-i[SUFFIX], --in-place[=SUFFIX]:原文件直接編輯操作;
-r, --regexp-extended:使sed支持擴展正則表達式;
(2)、script部分:'AddressesCommand'
Addresses(地址定界):
1.空地址:對所有文件的所有行進行處理;
2.單地址:sed對于能夠匹配該地址的那唯一一行進行處理;
num:表示行號;
/pattern/:能夠匹配該模式的所有行;
$:表示文檔最后一行
3.地址范圍:
addr1,addr2:從addr1開始到addr2結束的中間所有行;
例如:2,8
first~step:從first標記的行號開始,以step所代表的數字為步長;
例如:1~2, 2~2
addr1,+N:從addr1開始,包括addr1所在行,并繼續向后計算N行;
例如:2,+7相當于2,2+7
addr1,~N:從addr1開始,包括addr1所在行,向后計算addr1*N行;
例如:2,~5相當于2,2*5
/pattern1/,/pattern2/:從被pattern1匹配的第一行開始計算,一直到被/pattern2/匹配到的第一行結束;
Command(處理命令):
=:顯示被模式匹配的行的行號
例如:sed -n '/^$/=' /etc/grub2.cfg
a \text:在被模式匹配的行的后面追加text的內容,支持使用\n換行,從而實現多行追加;
i \text:在被模式匹配的行的前面插入text的內容,支持使用\n換行,從而實現多行插入;
c \text:將被模式匹配的行的修改為text的內容,支持使用\n換行,從而實現一行變多行;
d:在模式空間中刪除被模式匹配的行;這樣的行不能再進行標準輸出;
注意:在使用d命令的時候,不宜使用-n選項;
p:顯示模式空間中被模式匹配的行;
注意:在使用p命令的時候,通常會搭配-n選項;
w filepath:將模式空間中被模式匹配的行,另存到filepath文件中;
r filepath:將filepath文件的內容追加至模式空間中被模式匹配的行之后;
!Command:在模式空間中被模式匹配的行,不執行Command命令;相反,未被模式匹配的行,參會執行Command命令
s///:查找替換,分隔符可以任意更換,只要相同即可;
s@@@, s###, s,,,
s/pattern/text/[control]
s@/etc/fstab@/etc/mtab@
pattern:計劃查找并替換的內容
text:要替換的結果
control:如何進行替換
g:行內全部替換
p:顯示替換成功的行
w: filepath:將替換成功的行另存到filepath文件中;
s///支持后向引用:
s/\(string\)/&/
s/\(string\)/\1/
(3)、高級編輯命令:
h: 把模式空間中的內容覆蓋至保持空間中
H:把模式空間中的內容追加至保持空間中
g: 從保持空間取出數據覆蓋至模式空間
G:從保持空間取出內容追加至模式空間
x: 把模式空間中的內容與保持空間中的內容進行互換
n: 讀取匹配到的行的下一行覆蓋至模式空間
N:追加匹配到的行的下一行至模式空間
d: 刪除模式空間中的行
D:刪除多行模式空間中的所有行
示例:sed -n 'n;p' FILE
sed '1!G;h;$!d' FILE
sed '$!N;$!D' FILE
sed '$!d' FILE
sed ‘G’ FILE
sed ‘g’ FILE
sed ‘/^$/d;G’ FILE
sed 'n;d' FILE
sed -n '1!G;h;$p' FILE
四、文件查找:按照文件名或文件屬性來搜索文件
1、locate命令
locate是【模糊查找】,其不是掃描這個系統,而是基于專用的數據庫進行查找,這個數據庫應該事先創建,并且定期更新。locate查找速度非常快,查找精確度非常有限。
可以使用updatedb命令手動更新locate數據庫。
2、find命令
find是【精確查找】,查找精度高,速度慢。在指定的位置進行文件名或文件屬性進行遍歷掃描,強烈不建議對操作根目錄進行find。
find是實時查找,使用find命令只能搜索當前用戶具有讀取和執行權限的命令
find命令:
(find - search for files in a directory hierarchy)
格式:find [OPTIONS……] [查找路徑] [查找條件] [處理動作]
[查找路徑]:默認為當前工作目錄,可以指定具體的命令路徑。
[查找條件]:進行本次搜索的標準,可以是文件名、文件大小、文件類型、文件權限等等:默認是指定
目錄中的所有文件。
[處理動作]:對于符合條件的文件進行某個處理操作;默認將查找結果輸出到顯示器。
[查找條件]
(1)、根據文件名查找:
-name 文件名稱,支持使用Globbing,(*, ?, [], [^])
-iname 文件名稱,忽略字母大小寫,支持使用Globbing,(*, ?, [], [^])
(2)、根據文件的inode編號進行查找:
-inum inode編號:通過給定的inode編號查找對應的文件名及路徑;
-samefile name:通過給定的文件名查找對應的inode編號,進而確定所有具有該inode編號的文件名及路徑;
-links n:查找鏈接數為n的所有文件;
# find / -inum 802210
# find / -samefile test
# find / -link 3 查找所有鏈接為3的文件
(3)、根據正則表達式來查找:
-regex pattern:以pattern匹配整個文件路徑字符串,而不僅僅是給定文件的名稱;
(4)、根據文件的屬主和屬組進行查找:
-user uname:根據屬主為指定用戶的用戶名進行查找
-uid UID:根據屬主為某個UID進行查找
-group gname:根據屬組名查找
-gid GID:根據屬組GID查找
-nogroup:在文件的屬組上沒有組對應的組名;在文件的屬組上沒有組對應的組名,但是依舊有數字化UID和GID。
-nouser:在文件的屬主上沒有用戶對應的用戶名;
(5)、根據文件類型查找:
格式1:-type 文件類型
具體文件類型如下:
b:塊設備
c:字符設備
d:目錄文件
f:普通文件
l:符號鏈接文件
p:管道文件
s:套接字文件
格式2:-xtype 文件類型 :符號鏈接文件到的匹配需要配合其他選項,其余與type相似。
(6)、根據時間戳進行查找:
以天為單位:
-atime [+|-]n:根據訪問時間查找
-ctime [+|-]n:根據改變時間查找
-mtime [+|-]n:根據修改時間查找
n: 即[n,n+1],表示前(n+1)天和前n天之內這段期間————中段
+n:即[n+1,無窮],表示前(n+1)天以前的事————前段
-n:即[now,n],表示前n天到現在這段時間————后段
以分鐘為單位:
-amin [+|-]n:根據訪問時間查找
-cmin [+|-]n:根據改變時間查找
-mmin [+|-]n:根據修改時間查找
例子:5-28-11-18
-mtime -3
5-25-11-18
-mtime 3
5-24-11-18
-mtime +3
(7)、根據文件大小進行查找:
-size [+|-]n[cwbkMG]
n:(n-1,n]
-n:[0,n-1],表示比n小的部分
+n:(n,+∞)
例子:find -size +2k
當前目錄下所有大于2KB的文件;
find -size 2k
當前目錄下所有1KB-2KB之間的文件;
find -size -2k
當前目錄下所有小于1KB的文件
(8)、根據權限進行查找:
-perm [/|-]mode
mode:精確匹配指定的權限
/mode:隱含了邏輯或的關系,任何一個權限位的權限中只要能有一個權限匹配,即可滿足條件;
-mode:隱含了邏輯與的關系,每一個權限位的權限中都必須同時包含指定權限位,才能滿足條件
# find -perm 640
# find -perm /444 只要一個有讀權限就匹配
# find -perm /540 即 # find -perm /444 -a -perm /100
# find -perm -444 三個讀權限必須同時存在才匹配
# find -not -perm /222 沒有寫權限才匹配
組合條件:
-a:邏輯與,默認可以省略;
-o:邏輯或
-not, !:邏輯非
# find -nouser -nogroup
# find -nouser -o -nogroup
[處理動作]
(1)、-print
-print:輸出到顯示屏幕,默認的動作
(2)、-ls
-ls:對與查找到的結果執行ls -li命令顯示
(3)、-exec COMMAND {} \; 對于查找到的結果執行COMMAND命令
區別:-exec是非交互式的;
-ok是交互式的;
{}:占位符,用來引用被find命令查找到的所有的文件的路徑信息;
-exec和-ok的取代執行操作:
chmod a-r $(find -perm -444 -type f)
find -perm -444 -type f | xargs chmod a-r
注意:管道輸送的是純字符串信息,所以如果管道之后的命令不是處理字符串的命令,需要使用xargs命令將其轉換成能夠被后面命令處理的參數;
# find -perm -444 -type f -exec chmod a-r {} \;
即:# chmod a-r $(find -perm -444 -type f)
# find -not -perm /444 -type f -exec chmod a+r \;
即:# chmod a+r $(find -not -perm /444 -type f)
# find -perm -444 -type f | chmod a-r 運行【失敗】,因為chmod處理的不是字符串
# find -perm -444 -type f | tr 'a-z' 'A-Z' 運行【正確】,因為tr處理的本來就是字符串。grep處理的也是字符串,所以也可以運行成功。
注意:管道輸送的是純字符串信息,所以如果管道之后的命令不是處理字符串的命令,需要使用xargs命令將其轉換成能夠被后面命令處理的參數
(4)、-ok
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。