https://www.runoob.com/linux/linux-command-manual.html
1、ls指令
就是list的縮寫,通過ls 指令不僅可以檢視linux檔案夾包含的檔案,而且可以檢視檔案權限(包括目錄、檔案夾、檔案權限)檢視目錄資訊等等
常用參數搭配:
ls -a 列出目錄所有檔案,包含以.開始的隐藏檔案
ls -A 列出除.及..的其它檔案
ls -r 反序排列
ls -t 以檔案修改時間排序
ls -S 以檔案大小排序
ls -h 以易讀大小顯示
ls -l 除了檔案名之外,還将檔案的權限、所有者、檔案大小等資訊詳細列出來
執行個體:
(1) 按易讀方式按時間反序排序,并顯示檔案詳細資訊
ls -lhrt
(2) 按大小反序顯示檔案詳細資訊
ls -lrS
(3)列出目前目錄中所有以“t”開頭的目錄的詳細内容
ls -l t*
(4) 列出檔案絕對路徑(不包含隐藏檔案)
ls | sed "s:^:`pwd`/:"
(5) 列出檔案絕對路徑(包含隐藏檔案)
find $pwd -maxdepth 1 | xargs ls -ld
2、cd指令
(changeDirectory),指令文法:cd [目錄名]。說明:切換目前目錄至dirName
(1)進入要目錄
cd /
(2)進入"家"目錄
cd ~
(3)進入上一次工作路徑
cd -
(4)把上個指令的參數作為cd參數使用。
cd !$
3、pwd指令
檢視目前工作目錄路徑
(1)檢視目前路徑
pwd
(2)檢視軟連結的實際路徑
pwd -P
4、mkdir指令
建立檔案夾
可用選項:
-m: 對建立目錄設定存取權限,也可以用chmod指令設定;
-p: 可以是一個路徑名稱。此時若路徑中的某些目錄尚不存在,加上此選項後,系統将自動建立好那 些尚不在的目錄,即一次可以建立多個目錄;
(1)目前工作目錄下建立名為t的檔案夾
mkdir t
(2)在tmp目錄下建立路徑為test/t1/t的目錄,若不存在,則建立
mkdir -p /tmp/test/t1/t
5、rm指令
删除一個目錄中的一個或多個檔案或目錄,如果沒有使用- r選項,則rm不會删除目錄。如果使用 rm 來删除檔案,通常仍可以将該檔案恢複原狀
rm [選項] 檔案…
(1)删除任何.log檔案;删除前逐一詢問确認
rm -i *.log
(2)删除test子目錄及子目錄中所有檔案删除,并且不用一一确認
rm -rf test
(3)删除以-f開頭的檔案
rm -- -f*
6、rmdir指令
從一個目錄中删除一個或多個子目錄項,删除某目錄時也必須具有對其父目錄的寫權限。
注意:不能删除非空目錄
(1)當parent子目錄被删除後使它也成為空目錄的話,則順便一并删除
rmdir -p parent/child/child11
7、mv指令
移動檔案或修改檔案名,根據第二參數類型(如目錄,則移動檔案;如為檔案則重指令該檔案)。
當第二個參數為目錄時,可剛多個檔案以空格分隔作為第一參數,移動多個檔案到參數2指定的目錄中
(1)将檔案test.log重命名為test1.txt
mv test.log test1.txt
(2)将檔案log1.txt,log2.txt,log3.txt移動到根的test3目錄中
mv llog1.txt log2.txt log3.txt /test3
(3)将檔案file1改名為file2,如果file2已經存在,則詢問是否覆寫
mv -i log1.txt log2.txt
(4)移動目前檔案夾下的所有檔案到上一級目錄
mv * ../
8、cp指令
将源檔案複制至目标檔案,或将多個源檔案複制至目标目錄。
注意:指令行複制,如果目标檔案已經存在會提示是否覆寫,而在shell腳本中,如果不加-i參數,則不會提示,而是直接覆寫!
-i 提示
-r 複制目錄及目錄内所有項目
-a 複制的檔案與原檔案時間一樣
(1)複制a.txt到test目錄下,保持原檔案時間,如果原檔案存在提示是否覆寫
cp -ai a.txt test
(2)為a.txt建議一個連結(快捷方式)
cp -s a.txt link_a.txt
9、cat指令
cat主要有三大功能:
1.一次顯示整個檔案:cat filename
2.從鍵盤建立一個檔案:cat > filename 隻能建立新檔案,不能編輯已有檔案.
3.将幾個檔案合并為一個檔案:cat file1 file2 > file
-b對非空輸出行号
-n輸出所有行号
(1)把 log2012.log 的檔案内容加上行号後輸入 log2013.log 這個檔案裡
cat -n log2012.log log2013.log
(2)把 log2012.log 和 log2013.log 的檔案内容加上行号(空白行不加)之後将内容附加到 log.log 裡
cat -b log2012.log log2013.log log.log
(3)使用here doc生成新檔案
cat >log.txt <<EOF
>Hello
>World
>PWD=$(pwd)
>EOF
ls -l log.txt
cat log.txt
Hello
World
PWD=/opt/soft/test
(4)反向列示
tac log.txt
10、more指令
功能類似于cat, more會以一頁一頁的顯示友善使用者逐頁閱讀,而最基本的指令就是按空白鍵(space)就往下一頁顯示,按 b 鍵就會往回(back)一頁顯示
->>指令參數:
+n 從笫n行開始顯示
-n 定義螢幕大小為n行
+/pattern 在每個檔案顯示前搜尋該字串(pattern),然後從該字串前兩行之後開始顯示
-c 從頂部清屏,然後顯示
-d 提示“Press space to continue,’q’ to quit(按空格鍵繼續,按q鍵退出)”,禁用響鈴功能
-l 忽略Ctrl+l(換頁)字元
-p 通過清除視窗而不是滾屏來對檔案進行換頁,與-c選項相似
-s 把連續的多個空行顯示為一行
-u 把檔案内容中的下畫線去掉
->>常用操作指令:
Enter 向下n行,需要定義。預設為1行
Ctrl+F 向下滾動一屏
空格鍵 向下滾動一屏
Ctrl+B 傳回上一屏
= 輸出目前行的行号
:f 輸出檔案名和目前行的行号
V 調用vi編輯器
!指令 調用Shell,并執行指令
q 退出more
(1)顯示檔案中從第3行起的内容
more +3 text.txt
(2)在所列出檔案目錄詳細資訊,借助管道使每次顯示5行
ls -l | more -5
按空格顯示下5行
11、less指令
less 與 more 類似,但使用 less 可以随意浏覽檔案,而 more 僅能向前移動,卻不能向後移動,而且 less 在檢視之前不會加載整個檔案。
常用指令參數
-i 忽略搜尋時的大小寫
-N 顯示每行的行号
-o <檔案名> 将less 輸出的内容在指定檔案中儲存起來
-s 顯示連續空行為一行
/字元串:向下搜尋“字元串”的功能
?字元串:向上搜尋“字元串”的功能
n:重複前一個搜尋(與 / 或 ? 有關)
N:反向重複前一個搜尋(與 / 或 ? 有關)
-x <數字> 将“tab”鍵顯示為規定的數字空格
b 向後翻一頁
d 向後翻半頁
h 顯示幫助界面
Q 退出less 指令
u 向前滾動半頁
y 向前滾動一行
空格鍵 滾動一行
Enter鍵 滾動一頁
[pagedown]: 向下翻動一頁
[pageup]: 向上翻動一頁
(1)ps檢視程序資訊并通過less分頁顯示
ps -aux | less -N
(2)檢視多個檔案
less 1.log 2.log
可以使用n檢視下一個,使用p檢視前一個
12、head指令
head 用來顯示檔案的開頭至标準輸出中,預設head指令列印其相應檔案的開頭10行。
常用參數:
-n<行數> 顯示的行數(行數為複數表示從最後向前數)
(1)顯示1.log檔案中前20行
head 1.log -n 20
(2)顯示1.log檔案前20位元組
head -c 20 log2014.log
(3)顯示t.log最後10行
head -n -10 t.log
13、tail指令
用于顯示指定檔案末尾内容,不指定檔案時,作為輸入資訊進行處理。常用檢視日志檔案。
-f 循環讀取(常用于檢視遞增的日志檔案)
-n<行數> 顯示行數(從後向前)
(1)循環讀取逐漸增加的檔案内容
ping 127.0.0.1 > ping.log &(背景運作:可使用jobs -l檢視,也可使用fg将其移到前台運作)
tail -f ping.log(檢視日志)
14、which指令
在linux要查找某個檔案,但不知道放在哪裡了,可以使用下面的一些指令來搜尋:
which 檢視可執行檔案的位置。
whereis 檢視檔案的位置。
locate 配合資料庫檢視檔案位置。
find 實際搜尋硬碟查詢檔案名稱。
which是在PATH就是指定的路徑中,搜尋某個系統指令的位置,并傳回第一個搜尋結果。使用which指令,就可以看到某個系統指令是否存在,以及執行的到底是哪一個位置的指令。
-n 指定檔案名長度,指定的長度必須大于或等于所有檔案中最長的檔案名。
(1)檢視ls指令是否存在,執行哪個
which ls
(2)檢視which
which which
(3)檢視cd
which cd(顯示不存在,因為cd是内建指令,而which查找顯示是PATH中的指令)
檢視目前PATH配置:echo $PATH;或使用env檢視所有環境變量及對應值
15、whereis指令
whereis指令隻能用于程式名的搜尋,而且隻搜尋二進制檔案(參數-b)、man說明檔案(參數-m)和源代碼檔案(參數-s)。如果省略參數,則傳回所有資訊。whereis及locate都是基于系統内建的資料庫進行搜尋,是以效率很高,而find則是周遊硬碟查找檔案。
-b 定位可執行檔案。
-m 定位幫助檔案。
-s 定位源代碼檔案。
-u 搜尋預設路徑下除可執行檔案、源代碼檔案、幫助檔案以外的其它檔案。
(1)查找locate程式相關檔案
whereis locate
(2)查找locate的源碼檔案
whereis -s locate
(3)查找lcoate的幫助檔案
whereis -m locate
16、locate指令
locate通過搜尋系統内建文檔資料庫達到快速找到檔案,資料庫由updatedb程式來更新,updatedb是由cron daemon周期性調用的。預設情況下locate指令在搜尋資料庫時比由整個由硬碟資料來搜尋資料來得快,但較差勁的是locate所找到的檔案若是最近才建立或 剛更名的,可能會找不到,在内定值中,updatedb每天會跑一次,可以由修改crontab來更新設定值。(etc/crontab)。
locate與find指令相似,可以使用如*、?等進行正則比對查找
-l num(要顯示的行數)
-f 将特定的檔案系統排除在外,如将proc排除在外
-r 使用正則運算式做為尋找條件
(1)查找和pwd相關的所有檔案(檔案名中包含pwd)
locate pwd
(2)搜尋etc目錄下所有以sh開頭的檔案
locate /etc/sh
(3)查找/var目錄下,以reason結尾的檔案
locate -r '^/var.*reason$'(其中.表示一個字元,*表示任務多個;.*表示任意多個字元)
17、find指令
用于在檔案樹中查找檔案,并作出相應的處理
指令格式:
find pathname -options [-print -exec -ok ...]
指令參數:
pathname: find指令所查找的目錄路徑。例如用.來表示目前目錄,用/來表示系統根目錄。
-print: find指令将比對的檔案輸出到标準輸出。
-exec: find指令對比對的檔案執行該參數所給出的shell指令。相應指令的形式為'command' { } \;,注意{ }和\;之間的空格。
-ok: 和-exec的作用相同,隻不過以一種更為安全的模式來執行該參數所給出的shell指令,在執行每一個指令之前,都會給出提示,讓使用者來确定是否執行。
指令選項:
-name 按照檔案名查找檔案
-perm 按檔案權限查找檔案
-user 按檔案屬主查找檔案
-group 按照檔案所屬的組來查找檔案。
-type 查找某一類型的檔案,諸如:
b - 塊裝置檔案
d - 目錄
c - 字元裝置檔案
l - 符号連結檔案
p - 管道檔案
f - 普通檔案
-size n :[c] 查找檔案長度為n塊檔案,帶有c時表檔案位元組大小
-amin n 查找系統中最後N分鐘通路的檔案
-atime n 查找系統中最後n*24小時通路的檔案
-cmin n 查找系統中最後N分鐘被改變檔案狀态的檔案
-ctime n 查找系統中最後n*24小時被改變檔案狀态的檔案
-mmin n 查找系統中最後N分鐘被改變檔案資料的檔案
-mtime n 查找系統中最後n*24小時被改變檔案資料的檔案
(用減号-來限定更改時間在距今n日以内的檔案,而用加号+來限定更改時間在距今n日以前的檔案。 )
-maxdepth n 最大查找目錄深度
-prune選項來指出需要忽略的目錄。在使用-prune選項時要當心,因為如果你同時使用了-depth選項,那麼-prune選項就會被find指令忽略
-newer 如果希望查找更改時間比某個檔案新但比另一個檔案舊的所有檔案,可以使用-newer選項
(1)查找48小時内修改過的檔案
find -atime -2
(2)在目前目錄查找 以.log結尾的檔案。 ". "代表目前目錄
find ./ -name '*.log'
(3)查找/opt目錄下 權限為 777的檔案
find /opt -perm 777
(4)查找大于1K的檔案
find -size +1000c
find -size 1000c 查找等于1000字元的檔案
-exec 參數後面跟的是command指令,它的終止是以;為結束标志的,是以這句指令後面的分号是不可缺少的,考慮到各個系統中分号會有不同的意義,是以前面加反斜杠。{} 花括号代表前面find查找出來的檔案名。
(5)在目前目錄中查找更改時間在10日以前的檔案并删除它們(無提醒)
find . -type f -mtime +10 -exec rm -f {} \;
(6)目前目錄中查找所有檔案名以.log結尾、更改時間在5日以上的檔案,并删除它們,隻不過在删除之前先給出提示。 按y鍵删除檔案,按n鍵不删除
find . -name '*.log' mtime +5 -ok -exec rm {} \;
(7)目前目錄下查找檔案名以passwd開頭,内容包含"pkg"字元的檔案
find . -f -name 'passwd*' -exec grep "pkg" {} \;
(8)用exec選項執行cp指令
find . -name '*.log' -exec cp {} test3 \;
-xargs find指令把比對到的檔案傳遞給xargs指令,而xargs指令每次隻擷取一部分檔案而不是全部,不像-exec選項那樣。這樣它可以先處理最先擷取的一部分檔案,然後是下一批,并如此繼續下去。
(9)查找目前目錄下每個普通檔案,然後使用xargs來判斷檔案類型
find . -type f -print | xargs file
(10)查找目前目錄下所有以js結尾的并且其中包含'editor'字元的普通檔案
find . -type f -name "*.js" -exec grep -lF 'ueditor' {} \;
find -type f -name '*.js' | xargs grep -lF 'editor'
(11)利用xargs執行mv指令
find . -name "*.log" | xargs -i mv {} test4
(12)用grep指令在目前目錄下的所有普通檔案中搜尋hostnames這個詞,并标出所在行
find . -name \*(轉義) -type f -print | xargs grep -n 'hostnames'
(13)查找目前目錄中以一個小寫字母開頭,最後是4到9加上.log結束的檔案
find . -name '[a-z]*[4-9].log' -print
(14)在test目錄查找不在test4子目錄查找
find test -path 'test/test4' -prune -o -print
(15)執行個體1:查找更改時間比檔案log2012.log新但比檔案log2017.log舊的檔案
find -newer log2012.log ! -newer log2017.log
使用depth選項:
depth選項可以使find指令向錄音帶上備份檔案系統時,希望首先備份所有的檔案,其次再備份子目錄中的檔案。
執行個體:find指令從檔案系統的根目錄開始,查找一個名為CON.FILE的檔案。 它将首先比對所有的檔案然後再進入子目錄中查找
find / -name "CON.FILE" -depth -print
18、chmod指令
用于改變linux系統檔案或目錄的通路權限。用它控制檔案或目錄的通路權限。該指令有兩種用法。一種是包含字母和操作符表達式的文字設定法;另一種是包含數字的數字設定法。
每一檔案或目錄的通路權限都有三組,每組用三位表示,分别為檔案屬主的讀、寫和執行權限;與屬主同組的使用者的讀、寫和執行權限;系統中其他使用者的讀、寫和執行權限。可使用ls -l test.txt查找
以檔案log2012.log為例:
-rw-r--r-- 1 root root 296K 11-13 06:03 log2012.log
第一列共有10個位置,第一個字元指定了檔案類型。在通常意義上,一個目錄也是一個檔案。如果第一個字元是橫線,表示是一個非目錄的檔案。如果是d,表示是一個目錄。從第二個字元開始到第十個共9個字元,3個字元一組,分别表示了3組使用者對檔案或者目錄的權限。權限字元用橫線代表空許可,r代表隻讀,w代表寫,x代表可執行。
-c 當發生改變時,報告處理資訊
-R 處理指定目錄以及其子目錄下所有檔案
權限範圍:
u :目錄或者檔案的目前的使用者
g :目錄或者檔案的目前的群組
o :除了目錄或者檔案的目前使用者或群組之外的使用者或者群組
a :所有的使用者及群組
權限代号:
r :讀權限,用數字4表示
w :寫權限,用數字2表示
x :執行權限,用數字1表示
- :删除權限,用數字0表示
s :特殊權限
(1)增加檔案t.log所有使用者可執行權限
chmod a+x t.log
(2)撤銷原來所有的權限,然後使擁有者具有可讀權限,并輸出處理資訊
chmod u=r t.log -c
(3)給file的屬主配置設定讀、寫、執行(7)的權限,給file的所在組配置設定讀、執行(5)的權限,給其他使用者配置設定執行(1)的權限
chmod 751 t.log -c(或者:chmod u=rwx,g=rx,o=x t.log -c)
(4)将test目錄及其子目錄所有檔案添加可讀權限
chmod u+r,g+r,o+r -R text/ -c
19、tar指令
用來壓縮和解壓檔案。tar本身不具有壓縮功能,隻具有打包功能,有關壓縮及解壓是調用其它的功能來完成。
弄清兩個概念:打包和壓縮。打包是指将一大堆檔案或目錄變成一個總的檔案;壓縮則是将一個大的檔案通過一些壓縮算法變成一個小檔案
-c 建立新的壓縮檔案
-f 指定壓縮檔案
-r 添加檔案到已經壓縮檔案包中
-u 添加改了和現有的檔案到壓縮包中
-x 從壓縮包中抽取檔案
-t 顯示壓縮檔案中的内容
-z 支援gzip壓縮
-j 支援bzip2壓縮
-Z 支援compress解壓檔案
-v 顯示操作過程
有關gzip及bzip2壓縮
gzip執行個體:壓縮gzip fileName .tar.gz和.tgz 解壓:gunzip filename.gz或gzip -d filename.gz
對應:tar zcvf filename.tar.gz tar zxvf filename.tar.gz
bz2執行個體:壓縮bzip2 -z filename .tar.bz2 解壓:bunzip filename.bz2或bzip -d filename.bz2
對應:tar jcvf filename.tar.gz 解壓:tar jxvf filename.tar.bz2
(1)将檔案全部打包成tar包
tar -cvf log.tar 1.log,2.log 或tar -cvf log.*
(2)将/etc下的所有檔案及目錄打包到指定目錄,并使用gz壓縮
tar -zcvf /tmp/etc.tar.gz /etc
(3)檢視剛打包的檔案内容(一定加z,因為是使用gzip壓縮的)
tar -ztvf /tmp/etc.tar.gz
(4)要壓縮打包/home, /etc ,但不要 /home/dmtsai
tar --exclude /home/dmtsai -zcvf myfile.tar.gz /home/* /etc
20、chown指令
chown将指定檔案的擁有者改為指定的使用者或組,使用者可以是使用者名或者使用者ID;組可以是組名或者組ID;檔案是以空格分開的要改變權限的檔案清單,支援通配符
-c 顯示更改的部分的資訊
-R 處理指定目錄及子目錄
(1)改變擁有者和群組 并顯示改變資訊
chown -c mail:mail log2012.log
(2)改變檔案群組
chown -c :mail t.log
(3)改變檔案夾及子檔案目錄屬主及屬組為mail
chown -cR mail: test/
(4)改變檔案
21、df指令
顯示磁盤空間使用情況。擷取硬碟被占用了多少空間,目前還剩下多少空間等資訊,如果沒有檔案名被指定,則所有目前被挂載的檔案系統的可用空間将被顯示。預設情況下,磁盤空間将以 1KB 為機關進行顯示,除非環境變量 POSIXLY_CORRECT 被指定,那樣将以512位元組為機關進行顯示
-a 全部檔案系統清單
-h 以友善閱讀的方式顯示資訊
-i 顯示inode資訊
-k 區塊為1024位元組
-l 隻顯示本地磁盤
-T 列出檔案系統類型
(1)顯示磁盤使用情況
df -l
(2)以易讀方式列出所有檔案系統及其類型
df -haT
22、du指令
du指令也是檢視使用空間的,但是與df指令不同的是Linux du指令是對檔案和目錄磁盤使用的空間的檢視
du [選項] [檔案]
-a 顯示目錄中所有檔案大小
-k 以KB為機關顯示檔案大小
-m 以MB為機關顯示檔案大小
-g 以GB為機關顯示檔案大小
-h 以易讀方式顯示檔案大小
-s 僅顯示總計
-c或--total 除了顯示個别目錄或檔案的大小外,同時也顯示所有目錄或檔案的總和
(1)以易讀方式顯示檔案夾内及子檔案夾大小
du -h scf/
(2)以易讀方式顯示檔案夾内所有檔案大小
du -ah scf/
(3)顯示幾個檔案或目錄各自占用磁盤空間的大小,還統計它們的總和
du -hc test/ scf/
(4)輸出目前目錄下各個子目錄所使用的空間
du -hc --max-depth=1 scf/
23、ln指令
功能是為檔案在另外一個位置建立一個同步的連結,當在不同目錄需要該問題時,就不需要為每一個目錄建立同樣的檔案,通過ln建立的連結(link)減少磁盤占用量。
連結分類:軟體連結及硬連結
軟連結:
1.軟連結,以路徑的形式存在。類似于Windows作業系統中的快捷方式
2.軟連結可以 跨檔案系統 ,硬連結不可以
3.軟連結可以對一個不存在的檔案名進行連結
4.軟連結可以對目錄進行連結
硬連結:
1.硬連結,以檔案副本的形式存在。但不占用實際空間。
2.不允許給目錄建立硬連結
3.硬連結隻有在同一個檔案系統中才能建立
需要注意:
第一:ln指令會保持每一處連結檔案的同步性,也就是說,不論你改動了哪一處,其它的檔案都會發生相同的變化;
第二:ln的連結又分軟連結和硬連結兩種,軟連結就是ln –s 源檔案 目标檔案,它隻會在你標明的位置上生成一個檔案的鏡像,不會占用磁盤空間,硬連結 ln 源檔案 目标檔案,沒有參數-s, 它會在你標明的位置上生成一個和源檔案大小相同的檔案,無論是軟連結還是硬連結,檔案都保持同步變化。
第三:ln指令用在連結檔案或目錄,如同時指定兩個以上的檔案或目錄,且最後的目的地是一個已經存在的目錄,則會把前面指定的所有檔案或目錄複制到該目錄中。若同時指定多個檔案或目錄,且最後的目的地并非是一個已存在的目錄,則會出現錯誤資訊。
-b 删除,覆寫以前建立的連結
-s 軟連結(符号連結)
-v 顯示詳細處理過程
(1)給檔案建立軟連結,并顯示操作資訊
ln -sv source.log link.log
(2)給檔案建立硬連結,并顯示操作資訊
ln -v source.log link1.log
(3)給目錄建立軟連結
ln -sv /opt/soft/test/test3 /opt/soft/test/test5
24、date指令
顯示或設定系統的日期與時間
-d<字元串> 顯示字元串所指的日期與時間。字元串前後必須加上雙引号。
-s<字元串> 根據字元串來設定日期與時間。字元串前後必須加上雙引号。
-u 顯示GMT。
%H 小時(00-23)
%I 小時(00-12)
%M 分鐘(以00-59來表示)
%s 總秒數。起算時間為1970-01-01 00:00:00 UTC。
%S 秒(以本地的慣用法來表示)
%a 星期的縮寫。
%A 星期的完整名稱。
%d 日期(以01-31來表示)。
%D 日期(含年月日)。
%m 月份(以01-12來表示)。
%y 年份(以00-99來表示)。
%Y 年份(以四位數來表示)。
(1)顯示下一天
date +%Y%m%d --date="+1 day" //顯示下一天的日期
(2)-d參數使用
date -d "nov 22" 今年的 11 月 22 日是星期三
date -d '2 weeks' 2周後的日期
date -d 'next monday' (下周一的日期)
date -d next-day +%Y%m%d(明天的日期)或者:date -d tomorrow +%Y%m%d
date -d last-day +%Y%m%d(昨天的日期) 或者:date -d yesterday +%Y%m%d
date -d last-month +%Y%m(上個月是幾月)
date -d next-month +%Y%m(下個月是幾月)
25、cal指令
可以使用者顯示公曆(陽曆)月曆如隻有一個參數,則表示年份(1-9999),如有兩個參數,則表示月份和年份
-3 顯示前一月,目前月,後一月三個月的月曆
-m 顯示星期一為第一列
-j 顯示在目前年第幾天
-y [year]顯示目前年[year]份的月曆
(1)顯示指定年月日期
cal 9 2012
(2)顯示2013年每個月月曆
cal -y 2013
(3)将星期一做為第一列,顯示前中後三月
cal -3m
26、grep指令
強大的文本搜尋指令,grep(Global Regular Expression Print)全局正規表達式搜尋
grep的工作方式是這樣的,它在一個或多個檔案中搜尋字元串模闆。如果模闆包括空格,則必須被引用,模闆後的所有字元串被看作檔案名。搜尋的結果被送到标準輸出,不影響原檔案内容。
grep [option] pattern file|dir
-A n --after-context顯示比對字元後n行
-B n --before-context顯示比對字元前n行
-C n --context 顯示比對字元前後n行
-c --count 計算符合樣式的列數
-i 忽略大小寫
-l 隻列出檔案内容符合指定的樣式的檔案名稱
-f 從檔案中讀取關鍵詞
-n 顯示比對内容的所在檔案中行數
-R 遞歸查找檔案夾
grep的規則表達式:
^ #錨定行的開始 如:'^grep'比對所有以grep開頭的行。
$ #錨定行的結束 如:'grep$'比對所有以grep結尾的行。
. #比對一個非換行符的字元 如:'gr.p'比對gr後接一個任意字元,然後是p。
* #比對零個或多個先前字元 如:'*grep'比對所有一個或多個空格後緊跟grep的行。
.* #一起用代表任意字元。
[] #比對一個指定範圍内的字元,如'[Gg]rep'比對Grep和grep。
[^] #比對一個不在指定範圍内的字元,如:'[^A-FH-Z]rep'比對不包含A-R和T-Z的一個字母開頭,緊跟rep的行。
\(..\) #标記比對字元,如'\(love\)',love被标記為1。
\< #錨定單詞的開始,如:'\<grep'比對包含以grep開頭的單詞的行。
\> #錨定單詞的結束,如'grep\>'比對包含以grep結尾的單詞的行。
x\{m\} #重複字元x,m次,如:'0\{5\}'比對包含5個o的行。
x\{m,\} #重複字元x,至少m次,如:'o\{5,\}'比對至少有5個o的行。
x\{m,n\} #重複字元x,至少m次,不多于n次,如:'o\{5,10\}'比對5--10個o的行。
\w #比對文字和數字字元,也就是[A-Za-z0-9],如:'G\w*p'比對以G後跟零個或多個文字或數字字元,然後是p。
\W #\w的反置形式,比對一個或多個非單詞字元,如點号句号等。
\b #單詞鎖定符,如: '\bgrep\b'隻比對grep。
(1)查找指定程序
ps -ef | grep svn
(2)查找指定程序個數
ps -ef | grep svn -c
(3)從檔案中讀取關鍵詞
cat test1.txt | grep -f key.log
(4)從檔案夾中遞歸查找以grep開頭的行,并隻列出檔案
grep -lR '^grep' /tmp
(5)查找非x開關的行内容
grep '^[^x]' test.txt
(6)顯示包含ed或者at字元的内容行
grep -E 'ed|at' test.txt
27、wc指令
wc(word count)功能為統計指定的檔案中位元組數、字數、行數,并将統計結果輸出
wc [option] file..
-c 統計位元組數
-l 統計行數
-m 統計字元數
-w 統計詞數,一個字被定義為由空白、跳格或換行字元分隔的字元串
(1)查找檔案的 行數 單詞數 位元組數 檔案名
wc text.txt 結果:7 8 70 test.txt
(2)統計輸出結果的行數
cat test.txt | wc -l
28、ps指令
ps(process status),用來檢視目前運作的程序狀态,一次性檢視,如果需要動态連續結果使用top
linux上程序有5種狀态:
1. 運作(正在運作或在運作隊列中等待)
2. 中斷(休眠中, 受阻, 在等待某個條件的形成或接受到信号)
3. 不可中斷(收到信号不喚醒和不可運作, 程序必須等待直到有中斷發生)
4. 僵死(程序已終止, 但程序描述符存在, 直到父程序調用wait4()系統調用後釋放)
5. 停止(程序收到SIGSTOP, SIGSTP, SIGTIN, SIGTOU信号後停止運作運作)
ps工具辨別程序的5種狀态碼:
D 不可中斷 uninterruptible sleep (usually IO)
R 運作 runnable (on run queue)
S 中斷 sleeping
T 停止 traced or stopped
Z 僵死 a defunct (”zombie”) process
-A 顯示所有程序
a 顯示所有程序
-a 顯示同一終端下所有程序
c 顯示程序真實名稱
e 顯示環境變量
f 顯示程序間的關系
r 顯示目前終端運作的程序
-aux 顯示所有包含其它使用的程序
(1)顯示目前所有程序環境變量及程序間關系
ps -ef
(2)顯示目前所有程序
ps -A
(3)與grep聯用查找某程序
ps -aux | grep apache
(4)找出與 cron 與 syslog 這兩個服務有關的 PID 号碼
ps aux | grep '(cron|syslog)'
29、top指令
顯示目前系統正在執行的程序的相關資訊,包括程序ID、記憶體占用率、CPU占用率等
-c 顯示完整的程序指令
-s 保密模式
-p <程序号> 指定程序顯示
-n <次數>循環顯示次數
(1)
top - 14:06:23 up 70 days, 16:44, 2 users, load average: 1.25, 1.32, 1.35
Tasks: 206 total, 1 running, 205 sleeping, 0 stopped, 0 zombie
Cpu(s): 5.9%us, 3.4%sy, 0.0%ni, 90.4%id, 0.0%wa, 0.0%hi, 0.2%si, 0.0%st
Mem: 32949016k total, 14411180k used, 18537836k free, 169884k buffers
Swap: 32764556k total, 0k used, 32764556k free, 3612636k cached
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
28894 root 22 0 1501m 405m 10m S 52.2 1.3 2534:16 java
前五行是目前系統情況整體的統計資訊區,
第一行,任務隊列資訊,同 uptime 指令的執行結果,具體參數說明情況如下:
14:06:23 — 目前系統時間
up 70 days, 16:44 — 系統已經運作了70天16小時44分鐘(在這期間系統沒有重新開機過的吆!)
2 users — 目前有2個使用者登入系統
load average: 1.15, 1.42, 1.44 — load average後面的三個數分别是1分鐘、5分鐘、15分鐘的負載情況。
load average資料是每隔5秒鐘檢查一次活躍的程序數,然後按特定算法計算出的數值。如果這個數除以邏輯CPU的數量,結果高于5的時候就表明系統在超負荷運轉了。
第二行,Tasks — 任務(程序),具體資訊說明如下:
系統現在共有206個程序,其中處于運作中的有1個,205個在休眠(sleep),stoped狀态的有0個,zombie狀态(僵屍)的有0個。
第三行,cpu狀态資訊,具體屬性說明如下:
5.9%us — 使用者空間占用CPU的百分比。
3.4% sy — 核心空間占用CPU的百分比。
0.0% ni — 改變過優先級的程序占用CPU的百分比
90.4% id — 空閑CPU百分比
0.0% wa — IO等待占用CPU的百分比
0.0% hi — 硬中斷(Hardware IRQ)占用CPU的百分比
0.2% si — 軟中斷(Software Interrupts)占用CPU的百分比
備注:在這裡CPU的使用比率和windows概念不同,需要了解linux系統使用者空間和核心空間的相關知識!
第四行,記憶體狀态,具體資訊如下:
32949016k total — 實體記憶體總量(32GB)
14411180k used — 使用中的記憶體總量(14GB)
18537836k free — 空閑記憶體總量(18GB)
169884k buffers — 緩存的記憶體量 (169M)
第五行,swap交換分區資訊,具體資訊說明如下:
32764556k total — 交換區總量(32GB)
0k used — 使用的交換區總量(0K)
32764556k free — 空閑交換區總量(32GB)
3612636k cached — 緩沖的交換區總量(3.6GB)
第六行,空行。
第七行以下:各程序(任務)的狀态監控,項目列資訊說明如下:
PID — 程序id
USER — 程序所有者
PR — 程序優先級
NI — nice值。負值表示高優先級,正值表示低優先級
VIRT — 程序使用的虛拟記憶體總量,機關kb。VIRT=SWAP+RES
RES — 程序使用的、未被換出的實體記憶體大小,機關kb。RES=CODE+DATA
SHR — 共享記憶體大小,機關kb
S — 程序狀态。D=不可中斷的睡眠狀态 R=運作 S=睡眠 T=跟蹤/停止 Z=僵屍程序
%CPU — 上次更新到現在的CPU時間占用百分比
%MEM — 程序使用的實體記憶體百分比
TIME+ — 程序使用的CPU時間總計,機關1/100秒
COMMAND — 程序名稱(指令名/指令行)
top互動指令
h 顯示top互動指令幫助資訊
c 切換顯示指令名稱和完整指令行
m 以記憶體使用率排序
P 根據CPU使用百分比大小進行排序
T 根據時間/累計時間進行排序
W 将目前設定寫入~/.toprc檔案中
o或者O 改變顯示項目的順序
30、kill指令
發送指定的信号到相應程序。不指定型号将發送SIGTERM(15)終止指定程序。如果任無法終止該程式可用“-KILL” 參數,其發送的信号為SIGKILL(9) ,将強制結束程序,使用ps指令或者jobs 指令可以檢視程序号。root使用者将影響使用者的程序,非root使用者隻能影響自己的程序。
-l 信号,若果不加信号的編号參數,則使用“-l”參數會列出全部的信号名稱
-a 當處理目前程序時,不限制指令名和程序号的對應關系
-p 指定kill 指令隻列印相關程序的程序号,而不發送任何信号
-s 指定發送信号
-u 指定使用者
(1)先使用ps查找程序pro1,然後用kill殺掉
kill -9 $(ps -ef | grep pro1)
31、free指令
顯示系統記憶體使用情況,包括實體記憶體、互動區記憶體(swap)和核心緩沖區記憶體。
-b 以Byte顯示記憶體使用情況
-k 以kb為機關顯示記憶體使用情況
-m 以mb為機關顯示記憶體使用情況
-g 以gb為機關顯示記憶體使用情況
-s<間隔秒數> 持續顯示記憶體
-t 顯示記憶體使用總合
(1)顯示記憶體使用情況
free
free -k
free -m
(2)以總和的形式顯示記憶體的使用資訊
free -t
(3)周期性查詢記憶體使用情況
free -s 10