linux常用命令詳解

回首笑人間發表於2019-07-26

引言: 做開發好多年,收集了一堆的Linux命令,每次用的時候都得現翻各種帖子,抽空做了個常用的命令總結,後續將繼續補全,有空再做個chm文件出來,希望喜歡的朋友點個贊再走

目錄

軟體包管理
    yum                 查詢/新增/刪除/更新RPM包,自動解決包的依賴問題以及系統更新升級
檔案管理
    rm                  刪除(單個/多個)檔案/資料夾
    mv                  移動檔案或修改檔名
    cp                  檔案複製
    cat                 顯示、建立、合併檔案
    more                逐頁閱讀檔案內容
    less                可以隨意瀏覽檔案,支援向後檢視
    head                用來顯示檔案的開頭
    tail                用來顯示檔案的末尾
    which               檢視可執行檔案的位置,以及檢視該檔案是否存在
    whereis             用於程式名的搜尋
    locate              快速查詢檔案
    find                用於在檔案樹中查詢檔案,並作出相應的處理
    grep                管道過濾
    chmod               檔案/資料夾授權、剝權
    ln                  用於建立檔案間的連結,檔案掛載
    chown               將指定檔案的擁有者改為指定的使用者或組
    wc                  統計指定的檔案中位元組數、字數、行數,並將統計結果輸出
備份壓縮    
    tar                 用來壓縮和解壓檔案
磁碟管理
    ls                  檢視檔案許可權(包括目錄、資料夾、檔案許可權)資訊等   
    cd                  目錄切換
    pwd                 顯示當前路徑
    mkdir               建立資料夾
    rmdir               刪除資料夾 
    df                  顯示磁碟空間使用情況
    du                  對檔案和目錄磁碟使用的空間的檢視
系統設定
    date                顯示和設定日期
    export              環境變數顯示、設定
    vim /etc/profile
系統管理
    service             用於對系統服務進行管理
    chkconfig           命令檢查、設定系統的各種服務
    systemctl           系統服務管理器指令,它是service和chkconfig命令的組合體
    useradd             對系統使用者的建立、刪除等管理
    ps                  用來檢視當前執行的程式狀態
網路管理
    telnet              用於登入遠端、伺服器ping通
    netstat             檢視網路系統的狀態資訊
其他
    cal                 日曆
    free                顯示系統記憶體使用情況
    kill                殺死程式
好用的學習網址    

軟體包管理

yum

用於查詢/新增/刪除/更新RPM包,自動解決包的依賴問題以及系統更新升級

語法

yum(選項)(引數)

選項

-h:顯示幫助資訊;
-y:對所有的提問都回答“yes”;
-c:指定配置檔案;
-q:安靜模式;
-v:詳細模式;
-d:設定除錯等級(0-10);
-e:設定錯誤等級(0-10);
-R:設定yum處理一個命令的最大等待時間;
-C:完全從快取中執行,而不去下載或者更新任何標頭檔案。

引數

install:安裝rpm軟體包;
update:更新rpm軟體包;
check-update:檢查是否有可用的更新rpm軟體包;
remove:刪除指定的rpm軟體包;
list:顯示軟體包的資訊;
search:檢查軟體包的資訊;
info:顯示指定的rpm軟體包的描述資訊和概要資訊;
clean:清理yum過期的快取;
shell:進入yum的shell提示符;
resolvedep:顯示rpm軟體包的依賴關係;
localinstall:安裝本地的rpm軟體包;
localupdate:顯示本地rpm軟體包進行更新;
deplist:顯示rpm軟體包的所有依賴關係。

例項

部分常用的命令包括:

  • 自動搜尋最快映象外掛:yum install yum-fastestmirror
  • 安裝yum圖形視窗外掛:yum install yumex
  • 檢視可能批量安裝的列表:yum grouplist

安裝

yum install #全部安裝
yum install package1 #安裝指定的安裝包package1
yum groupinsall group1 #安裝程式組group1

更新和升級

yum update #全部更新
yum update package1 #更新指定程式包package1
yum check-update #檢查可更新的程式
yum upgrade package1 #升級指定程式包package1
yum groupupdate group1 #升級程式組group1

查詢和顯示

yum info package1 #顯示安裝包資訊package1
yum list #顯示所有已經安裝和可以安裝的程式包
yum list package1 #顯示指定程式包安裝情況package1
yum groupinfo group1 #顯示程式組group1資訊yum search string 根據關鍵字string查詢安裝包

刪除程式

yum remove | erase package1 #刪除程式包package1
yum groupremove group1 #刪除程式組group1
yum deplist package1 #檢視程式package1依賴情況

清除快取

yum clean packages #清除快取目錄下的軟體包
yum clean headers #清除快取目錄下的 headers
yum clean oldheaders #清除快取目錄下舊的 headers

檔案管理

rm

     刪除一個目錄中的一個或多個檔案或目錄,如果沒有使用- r選項,則rm不會刪除目錄。如果使用              rm 來刪除檔案,通常仍可以將該檔案恢復原狀

     rm [選項] 檔案…

例項:

(1)刪除任何.log檔案;刪除前逐一詢問確認

rm -i *.log

(2)刪除test子目錄及子目錄中所有檔案刪除,並且不用一一確認

rm -rf test

(3)刪除以-f開頭的檔案

rm -- -f*

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 * ../

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

cat

     cat主要有三大功能:

     1.一次顯示整個檔案:cat filename

     2.從鍵盤建立一個檔案:cat > filename 只能建立新檔案,不能編輯已有檔案.

     3.將幾個檔案合併為一個檔案:cat file1 file2 > file

     -b對非空輸出行號

     -n輸出所有行號

例項:
(1)檢視系統版本

cat /etc/issue

(3)把 log2012.log 的檔案內容加上行號後輸入 log2013.log 這個檔案裡

cat -n log2012.log log2013.log

(3)把 log2012.log 和 log2013.log 的檔案內容加上行號(空白行不加)之後將內容附加到 log.log 裡

cat -b log2012.log log2013.log log.log

(4)使用here doc生成新檔案

cat >log.txt <<EOF

 >Hello

 >World

 >PWD=$(pwd)

 >EOF

 ls -l log.txt

cat log.txt

Hello

World

PWD=/opt/soft/test

(5)反向列示

tac log.txt

 PWD=/opt/soft/test

 World

 Hello

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行

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檢視前一個

     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

tail

     用於顯示指定檔案末尾內容,不指定檔案時,作為輸入資訊進行處理。常用檢視日誌檔案。

     常用引數:

     -f 迴圈讀取(常用於檢視遞增的日誌檔案)

     -n<行數> 顯示行數(從後向前)

(1)迴圈讀取逐漸增加的檔案內容

ping 127.0.0.1 > ping.log &(後臺執行:可使用jobs -l檢視,也可使用fg將其移到前臺執行) tail -f ping.log(檢視日誌)

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檢視所有環境變數及對應值

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

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$'(其中.表示一個字元,表示任務多個;.*表示任意多個字元)

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

grep

grep(global search regular expression(RE) and print out the line,全面搜尋正規表示式並把行列印出來)是一種強大的文字搜尋工具,它能使用正規表示式搜尋文字,並把匹配的行列印出來

選項

-a 不要忽略二進位制資料。
-A<顯示列數> 除了顯示符合範本樣式的那一行之外,並顯示該行之後的內容。
-b 在顯示符合範本樣式的那一行之外,並顯示該行之前的內容。
-c 計算符合範本樣式的列數。
-C<顯示列數>或-<顯示列數>  除了顯示符合範本樣式的那一列之外,並顯示該列之前後的內容。
-d<進行動作> 當指定要查詢的是目錄而非檔案時,必須使用這項引數,否則grep命令將回報資訊並停止動作。
-e<範本樣式> 指定字串作為查詢檔案內容的範本樣式。
-E 將範本樣式為延伸的普通表示法來使用,意味著使用能使用擴充套件正規表示式。
-f<範本檔案> 指定範本檔案,其內容有一個或多個範本樣式,讓grep查詢符合範本條件的檔案內容,格式為每一列的範本樣式。
-F 將範本樣式視為固定字串的列表。
-G 將範本樣式視為普通的表示法來使用。
-h 在顯示符合範本樣式的那一列之前,不標示該列所屬的檔名稱。
-H 在顯示符合範本樣式的那一列之前,標示該列的檔名稱。
-i 忽略字元大小寫的差別。
-l 列出檔案內容符合指定的範本樣式的檔名稱。
-L 列出檔案內容不符合指定的範本樣式的檔名稱。
-n 在顯示符合範本樣式的那一列之前,標示出該列的編號。
-q 不顯示任何資訊。
-R/-r 此引數的效果和指定“-d recurse”引數相同。
-s 不顯示錯誤資訊。
-v 反轉查詢。
-w 只顯示全字元合的列。
-x 只顯示全列符合的列。
-y 此引數效果跟“-i”相同。
-o 只輸出檔案中匹配到的部分。

grep命令常見用法

在檔案中搜尋一個單詞,命令會返回一個包含“match_pattern”的文字行:

grep match_pattern file_name
grep "match_pattern" file_name

在多個檔案中查詢:

grep "match_pattern" file_1 file_2 file_3 ...

輸出除之外的所有行 -v 選項:

grep -v "match_pattern" file_name

標記匹配顏色 --color=auto 選項:

grep "match_pattern" file_name --color=auto

使用正規表示式 -E 選項:

grep -E "[1-9]+"

egrep "[1-9]+"

只輸出檔案中匹配到的部分 -o 選項:

echo this is a test line. | grep -o -E "[a-z]+."
line.

echo this is a test line. | egrep -o "[a-z]+."
line.

統計檔案或者文字中包含匹配字串的行數 -c 選項:

grep -c "text" file_name

輸出包含匹配字串的行數 -n 選項:

grep "text" -n file_name

cat file_name | grep "text" -n

多個檔案

grep "text" -n file_1 file_2

列印樣式匹配所位於的字元或位元組偏移:

echo gun is not unix | grep -b -o "not"
7:not

一行中字串的字元便宜是從該行的第一個字元開始計算,起始值為0。選項 -b -o 一般總是配合使用。

搜尋多個檔案並查詢匹配文字在哪些檔案中:

grep -l "text" file1 file2 file3...

grep遞迴搜尋檔案

在多級目錄中對文字進行遞迴搜尋:

grep "text" . -r -n  
# .表示當前目錄。

忽略匹配樣式中的字元大小寫

echo "hello world" | grep -i "HELLO"
hello

選項 -e 制動多個匹配樣式:

echo this is a text line | grep -e "is" -e "line" -o
is
line

#也可以使用-f選項來匹配多個樣式,在樣式檔案中逐行寫出需要匹配的字元。
cat patfile
aaa
bbb

echo aaa bbb ccc ddd eee | grep -f patfile -o

在grep搜尋結果中包括或者排除指定檔案:

#只在目錄中所有的.php和.html檔案中遞迴搜尋字元"main()"
grep "main()" . -r --include *.{php,html}

#在搜尋結果中排除所有README檔案
grep "main()" . -r --exclude "README"

#在搜尋結果中排除filelist檔案列表裡的檔案
grep "main()" . -r --exclude-from filelist

使用0值位元組字尾的grep與xargs:

#測試檔案:
echo "aaa" > file1
echo "bbb" > file2
echo "aaa" > file3

grep "aaa" file* -lZ | xargs -0 rm

#執行後會刪除file1和file3,grep輸出用-Z選項來指定以0值位元組作為終結符檔名(\0),xargs -0 讀取輸入並用0值位元組終結符分隔檔名,然後刪除匹配檔案,-Z通常和-l結合使用。

grep靜默輸出:

grep -q "test" filename

#不會輸出任何資訊,如果命令執行成功返回0,失敗則返回非0值。一般用於條件測試。

列印出匹配文字之前或者之後的行:

#顯示匹配某個結果之後的3行,使用 -A 選項:
seq 10 | grep "5" -A 3
5
6
7
8

#顯示匹配某個結果之前的3行,使用 -B 選項:
seq 10 | grep "5" -B 3
2
3
4
5

#顯示匹配某個結果的前三行和後三行,使用 -C 選項:
seq 10 | grep "5" -C 3
2
3
4
5
6
7
8

#如果匹配結果有多個,會用“--”作為各匹配結果之間的分隔符:
echo -e "a\nb\nc\na\nb\nc" | grep a -A 1
a
b
--
a
b

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

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

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)改變檔案

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

檔案傳輸

備份壓縮

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

磁碟管理

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

(6) 檢視當前資料夾的隱藏檔案

ls -al

cd命令

     (changeDirectory),命令語法:cd [目錄名]。說明:切換當前目錄至dirName

例項:

(1)進入要目錄

cd /

(2)進入"家"目錄

cd ~

(3)進入上一次工作路徑

cd -

(4)把上個命令的引數作為cd引數使用。

cd !$

pwd

     檢視當前工作目錄路徑

例項:

(1)檢視當前路徑

pwd

(2)檢視軟連結的實際路徑

pwd -P

mkdir

     建立資料夾

     可用選項:

     -m: 對新建目錄設定存取許可權,也可以用chmod命令設定;

         -p: 可以是一個路徑名稱。此時若路徑中的某些目錄尚不存在,加上此選項後,系統將自動建立好那                      些尚不在的目錄,即一次可以建立多個目錄;

例項:

(1)當前工作目錄下建立名為t的資料夾

mkdir t

(2)在tmp目錄下建立路徑為test/t1/t的目錄,若不存在,則建立

mkdir -p /tmp/test/t1/t

rmdir

     從一個目錄中刪除一個或多個子目錄項,刪除某目錄時也必須具有對其父目錄的寫許可權。

     注意:不能刪除非空目錄

例項:

(1)當parent子目錄被刪除後使它也成為空目錄的話,則順便一併刪除

rmdir -p parent/child/child11

df

     顯示磁碟空間使用情況。獲取硬碟被佔用了多少空間,目前還剩下多少空間等資訊,如果沒有檔名被指定,則所有當前被掛載的檔案系統的可用空間將被顯示。預設情況下,磁碟空間將以 1KB 為單位進行顯示,除非環境變數 POSIXLY_CORRECT 被指定,那樣將以512位元組為單位進行顯示

     -a 全部檔案系統列表

     -h 以方便閱讀的方式顯示資訊

     -i 顯示inode資訊

     -k 區塊為1024位元組

     -l 只顯示本地磁碟

     -T 列出檔案系統型別

例項:

(1)顯示磁碟使用情況

df -l

(2)以易讀方式列出所有檔案系統及其型別

df -haT

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/

系統設定

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引數使用
今年的 11 月 22 日是星期三

date -d "nov 22"

2周後的日期

date -d '2 weeks'

(下週一的日期)

date -d 'next monday'

(明天的日期)或者:date -d tomorrow +%Y%m%d

date -d next-day +%Y%m%d

(昨天的日期) 或者:date -d yesterday +%Y%m%d

date -d last-day +%Y%m%d

(上個月是幾月)

date -d last-month +%Y%m

(下個月是幾月)

date -d next-month +%Y%m

export

export命令用於將shell變數輸出為環境變數,或者將shell函式輸出為環境變數。

一個變數建立時,它不會自動地為在它之後建立的shell程式所知。而命令export可以向後面的shell傳遞變數的值。當一個shell指令碼呼叫並執 行時,它不會自動得到原為指令碼(呼叫者)裡定義的變數的訪問權,除非這些變數已經被顯式地設定為可用。export命令可以用於傳遞一個或多個變數的值到任何後繼指令碼。

語法

export(選項)(引數)

選項

-f:代表[變數名稱]中為函式名稱;
-n:刪除指定的變數。變數實際上並未刪除,只是不會輸出到後續指令的執行環境中;
-p:列出所有的shell賦予程式的環境變數。

引數

變數:指定要輸出或者刪除的環境變數。

例項

一般來說,配置交叉編譯工具鏈的時候需要指定編譯工具的路徑,此時就需要設定環境變數。

  1. 檢視已經存在的環境變數:
[root@localhost ~]# export
declare -x G_BROKEN_FILENAMES="1"
declare -x HISTSIZE="1000"
declare -x HOME="/root"
declare -x hostname="localhost"
declare -x INPUTRC="/etc/inputrc"
declare -x LANG="zh_CN.UTF-8"
declare -x LESSOPEN="|/usr/bin/lesspipe.sh %s"
declare -x logname="root"
declare -x LS_COLORS="no=00:fi=00:di=01;34:ln=01;36:pi=40;33:so=01;35:bd=40;33;01:cd=40;33;01:or=01;05;37;41:mi=01;05;37;41:ex=01;32:*.cmd=01;32:*.exe=01;32:*.com=01;32:*.btm=01;32:*.bat=01;32:*.sh=01;32:*.csh=01;32:*.tar=01;31:*.tgz=01;31:*.arj=01;31:*.taz=01;31:*.lzh=01;31:*.zip=01;31:*.z=01;31:*.Z=01;31:*.gz=01;31:*.bz2=01;31:*.bz=01;31:*.tz=01;31:*.rpm=01;31:*.cpio=01;31:*.jpg=01;35:*.gif=01;35:*.bmp=01;35:*.xbm=01;35:*.xpm=01;35:*.png=01;35:*.tif=01;35:"
declare -x mail="/var/spool/mail/root"
declare -x OLDPWD
declare -x PATH="/usr/kerberos/sbin:/usr/kerberos/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin"
declare -x pwd="/root"
declare -x SHELL="/bin/bash"
declare -x SHLVL="1"
declare -x SSH_CLIENT="192.168.2.111 2705 22"
declare -x SSH_CONNECTION="192.168.2.111 2705 192.168.2.2 22"
declare -x SSH_TTY="/dev/pts/0"
declare -x TERM="linux"
declare -x USER="root"
  1. 單獨檢視PATH環境變數,可用
[root@localhost u-boot-sh4]#echo $PATH
/usr/kerberos/sbin:/usr/kerberos/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin
  1. 新增PATH環境變數(臨時),可用:
[root@localhost u-boot-sh4]#export PATH=/opt/STM/STLinux-2.3/devkit/sh4/bin:$PATH

再次檢視

[root@localhost u-boot-sh4]# echo $PATH
/opt/STM/STLinux-2.3/devkit/sh4/bin:/usr/kerberos/sbin:/usr/kerberos/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin

說明新增PATH成功。

上述方法的PATH 在終端關閉 後就會消失。

  1. 永久新增環境變數(影響當前使用者)
#vim ~/.bashrc
export PATH="/opt/STM/STLinux-2.3/devkit/sh4/bin:$PATH"
  1. 永久新增環境變數(影響所有使用者)

    vim /etc/profile

在文件最後,新增:

export PATH="/opt/STM/STLinux-2.3/devkit/sh4/bin:$PATH"

儲存,退出,然後執行:

source /etc/profile

不報錯則成功。

注意事項:
做了各實驗,在/etc/profile, ~/.profile, ~/.bashrc中加入新PATH,重啟都沒有效果,只有使用source才可以,ubunt12.04找到原因,~/.zshrc導致的,因為在zshrc中直接對PATH重新賦值,而沒有繼承之前的$PATH,導致啟動載入完/etc/profile後,PATH又被重新賦值。

系統管理

service

service命令用於對系統服務進行管理,比如啟動(start)、停止(stop)、重啟(restart)、重新載入配置(reload)、檢視狀態(status)等。

語法

service < option > | --status-all | [ service_name [ command | --full-restart ] ]

選項(option)

-h:顯示幫助資訊;
--status-all:顯示所服務的狀態。

引數

  • 服務名:自動要控制的服務名,即/etc/init.d目錄下的指令碼檔名;
  • 控制命令:系統服務指令碼支援的控制命令。

例項
當修改了主機名、ip地址等資訊時,經常需要把網路重啟使之生效。

service network status
配置裝置:
lo eth0
當前的活躍裝置:
lo eth0

service network restart
正在關閉介面 eth0:                                        [  確定  ]
關閉環回介面:                                             [  確定  ]
設定網路引數:                                             [  確定  ]
彈出環回介面:                                             [  確定  ]
彈出介面 eth0:                                            [  確定  ]

重啟docker

[root@localhost bin]# service docker status
Redirecting to /bin/systemctl status  docker.service
● docker.service - Docker Application Container Engine
   Loaded: loaded (/usr/lib/systemd/system/docker.service; enabled; vendor preset: disabled)
   Active: active (running) since 一 2019-05-27 09:12:31 CST; 1 months 28 days ago
     Docs: https://docs.docker.com
 Main PID: 4305 (dockerd)
   Memory: 117.6M
   CGroup: /system.slice/docker.service
           ├─ 4305 /usr/bin/dockerd -H unix:///var/run/docker.sock -H tcp://0.0.0.0:5678
           ├─ 4823 /usr/bin/docker-proxy -proto tcp -host-ip 0.0.0.0 -host-port 16379 -container-ip 172.17.0.7 -container-port 6379
           ├─38986 /usr/bin/docker-proxy -proto tcp -host-ip 0.0.0.0 -host-port 13306 -container-ip 172.17.0.6 -container-port 3306
           ├─55861 /usr/bin/docker-proxy -proto tcp -host-ip 0.0.0.0 -host-port 5000 -container-ip 172.17.0.2 -container-port 8081
           ├─85749 /usr/bin/docker-proxy -proto tcp -host-ip 0.0.0.0 -host-port 5001 -container-ip 172.17.0.4 -container-port 8081
           └─88167 /usr/bin/docker-proxy -proto tcp -host-ip 0.0.0.0 -host-port 8081 -container-ip 172.17.0.3 -container-port 8081


service docker restart
停止 MySQL:                                               [  確定  ]
啟動 MySQL:                                               [  確定  ]

------關閉、開啟防火牆(臨時生效,重啟後復原)

開啟:

service iptables start

關閉:

service iptables stop

檢視防火牆狀態(綠的running表示防火牆開啟)

systemctl status firewalld.service

chkconfig

chkconfig命令檢查、設定系統的各種服務。這是Red Hat公司遵循GPL規則所開發的程式,它可查詢作業系統在每一個執行等級中會執行哪些系統服務,其中包括各類常駐服務。謹記chkconfig不是立即自動禁止或啟用一個服務,它只是簡單的改變了符號連線。

systemctl

systemctl命令是系統服務管理器指令,它實際上將 service 和 chkconfig 這兩個命令組合到一起。

任務 舊指令 新指令
使某服務自動啟動 chkconfig --level 3 httpd on systemctl enable httpd.service
使某服務不自動啟動 chkconfig --level 3 httpd off systemctl disable httpd.service
檢查服務狀態 service httpd status systemctl status httpd.service (服務詳細資訊) systemctl is-active httpd.service (僅顯示是否 Active)
顯示所有已啟動的服務 chkconfig --list systemctl list-units --type=service
啟動某服務 service httpd start systemctl start httpd.service
停止某服務 service httpd stop systemctl stop httpd.service
重啟某服務 service httpd restart systemctl restart httpd.service

例項

注: nfs-server為系統服務名稱

  1. 啟動nfs服務

    systemctl start nfs-server.service

  2. 設定開機自啟動

    systemctl enable nfs-server.service

  3. 停止開機自啟動

    systemctl disable nfs-server.service

  4. 檢視服務當前狀態

    systemctl status nfs-server.service

  5. 重新啟動某服務

    systemctl restart nfs-server.service

  6. 檢視所有已啟動的服務

    systemctl list -units --type=service

  7. 開啟防火牆22埠

    iptables -I INPUT -p tcp --dport 22 -j accept

如果仍然有問題,就可能是SELinux導致的

關閉SElinux:

修改/etc/selinux/config檔案中的SELINUX=””為disabled,然後重啟。

  1. 永久關閉防火牆

執行檢視防火牆命令

sudo systemctl status firewalld.service

永久關閉防火牆

sudo systemctl stop firewalld.service

執行開機禁用防火牆自啟命令

sudo systemctl disable firewalld.service

  1. 啟動防火牆

    systemctl start firewalld.service

防火牆隨系統開啟啟動

systemctl enable firewalld.service

useradd

useradd命令用於Linux中建立的新的系統使用者。useradd可用來建立使用者帳號。帳號建好之後,再用passwd設定帳號的密碼.而可用userdel刪除帳號。使用useradd指令所建立的帳號,實際上是儲存在/etc/passwd文字檔案中。

在Slackware中,adduser指令是個script程式,利用交談的方式取得輸入的使用者帳號資料,然後再交由真正建立帳號的useradd命令建立新使用者,如此可方便管理員建立使用者帳號。在Red Hat Linux中,adduser命令則是useradd命令的符號連線,兩者實際上是同一個指令。

語法

useradd(選項)(引數)

選項

-c<備註>:加上備註文字。備註文字會儲存在passwd的備註欄位中;
-d<登入目錄>:指定使用者登入時的啟始目錄;
-D:變更預設值;
-e<有效期限>:指定帳號的有效期限;
-f<緩衝天數>:指定在密碼過期後多少天即關閉該帳號;
-g<群組>:指定使用者所屬的群組;
-G<群組>:指定使用者所屬的附加群組;
-m:自動建立使用者的登入目錄;
-M:不要自動建立使用者的登入目錄;
-n:取消建立以使用者名稱稱為名的群組;
-r:建立系統帳號;
-s<shell>:指定使用者登入後所使用的shell;
-u<uid>:指定使用者id。

引數

使用者名稱:要建立的使用者名稱。

例項
新建使用者加入組

useradd –g sales jack –G company,employees //-g:加入主要組、-G:加入次要組

建立一個新使用者賬戶,並設定ID

useradd caojh -u 544

需要說明的是,設定ID值時儘量要大於500,以免衝突。因為Linux安裝後會建立一些特殊使用者,一般0到499之間的值留給bin、mail這樣的系統賬號。

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)使用管道過濾檢視mysql的程式

ps -ef | grep icweb

(3)顯示當前所有程式

ps -A

(4)與grep聯用查詢某程式

ps -aux | grep apache

(5)找出與 cron 與 syslog 這兩個服務有關的 PID 號碼

ps aux | grep '(cron|syslog)'

文件編輯

網路管理

telnet

telnet命令用於登入遠端主機,對遠端主機進行管理。

telnet因為採用明文傳送報文,安全性不好,很多Linux伺服器都不開放telnet服務,而改用更安全的ssh方式了。但仍然有很多別的系統可能採用了telnet方式來提供遠端登入,因此弄清楚telnet客戶端的使用方式仍是很有必要的。

語法

telnet(選項)(引數)

選項

-8:允許使用8位字元資料,包括輸入與輸出;
-a:嘗試自動登入遠端系統;
-b<主機別名>:使用別名指定遠端主機名稱;
-c:不讀取使用者專屬目錄裡的.telnetrc檔案;
-d:啟動排錯模式;
-e<脫離字元>:設定脫離字元;
-E:濾除脫離字元;
-f:此引數的效果和指定"-F"引數相同;
-F:使用Kerberos V5認證時,加上此引數可把本地主機的認證資料上傳到遠端主機;
-k<域名>:使用Kerberos認證時,加上此引數讓遠端主機採用指定的領域名,而非該主機的域名;
-K:不自動登入遠端主機;
-l<使用者名稱稱>:指定要登入遠端主機的使用者名稱稱;
-L:允許輸出8位字元資料;
-n<記錄檔案>:指定檔案記錄相關資訊;
-r:使用類似rlogin指令的使用者介面;
-S<服務型別>:設定telnet連線所需的ip TOS資訊;
-x:假設主機有支援資料加密的功能,就使用它;
-X<認證形態>:關閉指定的認證形態。

引數

  • 遠端主機:指定要登入進行管理的遠端主機;
  • 埠:指定TELNET協議使用的埠號。

例項

判斷ip埠是否能ping通:

telnet ip 埠

telnet 192.168.2.10
Trying 192.168.2.10...
Connected to 192.168.2.10 (192.168.2.10).
Escape character is '^]'.

    localhost (Linux release 2.6.18-274.18.1.el5 #1 SMP Thu Feb 9 12:45:44 EST 2012) (1)

login: root
Password: 
Login incorrect

netstat

netstat命令用來列印Linux中網路系統的狀態資訊,可讓你得知整個Linux系統的網路情況。

語法

netstat(選項)

選項

-a或--all:顯示所有連線中的Socket;
-A<網路型別>或--<網路型別>:列出該網路型別連線中的相關地址;
-c或--continuous:持續列出網路狀態;
-C或--cache:顯示路由器配置的快取資訊;
-e或--extend:顯示網路其他相關資訊;
-F或--fib:顯示FIB;
-g或--groups:顯示多重廣播功能群組組員名單;
-h或--help:線上幫助;
-i或--interfaces:顯示網路介面資訊表單;
-l或--listening:顯示監控中的伺服器的Socket;
-M或--masquerade:顯示偽裝的網路連線;
-n或--numeric:直接使用ip地址,而不通過域名伺服器;
-N或--netlink或--symbolic:顯示網路硬體外圍裝置的符號連線名稱;
-o或--timers:顯示計時器;
-p或--programs:顯示正在使用Socket的程式識別碼和程式名稱;
-r或--route:顯示Routing Table;
-s或--statistice:顯示網路工作資訊統計表;
-t或--tcp:顯示TCP傳輸協議的連線狀況;
-u或--udp:顯示UDP傳輸協議的連線狀況;
-v或--verbose:顯示指令執行過程;
-V或--version:顯示版本資訊;
-w或--raw:顯示RAW傳輸協議的連線狀況;
-x或--unix:此引數的效果和指定"-A unix"引數相同;
--ip或--inet:此引數的效果和指定"-A inet"引數相同。

例項
列出所有埠 (包括監聽和未監聽的)

netstat -a #列出所有埠
netstat -at #列出所有tcp埠
netstat -au #列出所有udp埠

列出所有處於監聽狀態的 Sockets

netstat -l #只顯示監聽埠
netstat -lt #只列出所有監聽 tcp 埠
netstat -lu #只列出所有監聽 udp 埠
netstat -lx #只列出所有監聽 UNIX 埠

顯示每個協議的統計資訊

netstat -s 顯示所有埠的統計資訊
netstat -st 顯示TCP埠的統計資訊
netstat -su 顯示UDP埠的統計資訊

在netstat輸出中顯示 PID 和程式名稱

netstat -pt

檢視埠號為60080的服務

[root@localhost nodejs]# netstat -anp |grep 60080
tcp6       0      0 :::60080                :::*                    LISTEN      91260/basechain 

其他

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

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

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)

好用的學習網址

Linux常用命令大全(非常全!!!)
https://www.cnblogs.com/yjd_hycf_space/p/7730690.html

Linux命令手冊
http://linux.51yip.com

Linux命令大全
http://man.linuxde.net

軟體測試人員必備Linux命令(初、中、高階)
https://www.cnblogs.com/Javame/p/3968343.html

相關文章