關注,後臺私信【Linux】分享Linux入門到進階電子書、Linux入門到精通視頻教程(免費)。
文件管理命令
cat 命令
cat 命令用於連接文件並打印到標準輸出設備上。
cat 主要有三大功能:
1.一次顯示整個文件:
<code>cat filename/<code>
2.從鍵盤創建一個文件:
<code>cat > filename/<code>
3.將幾個文件合併為一個文件:
<code>cat file1 file2 > file/<code>
- -b 對非空輸出行號
- -n 輸出所有行號
實例:
(1)把 log2012.log 的文件內容加上行號後輸入 log2013.log 這個文件裡
<code>cat -n log2012.log log2013.log/<code>
(2)把 log2012.log 和 log2013.log 的文件內容加上行號(空白行不加)之後將內容附加到 log.log 裡
<code>cat -b log2012.log log2013.log log.log/<code>
(3)使用 here doc 生成新文件
<code>cat >log.txt <>Hello /<code>
>World
>PWD=$(pwd)
>EOF
ls -l log.txt
cat log.txt
Hello
World
PWD=/opt/soft/test
(4)反向列示
<code>tac log.txt
PWD=/opt/soft/test
World
Hello/<code>
關注,後臺私信【Linux】分享Linux入門到進階電子書、Linux入門到精通視頻教程(免費)。
chmod 命令
Linux/Unix 的文件調用權限分為三級 : 文件擁有者、群組、其他。利用 chmod 可以控制文件如何被他人所調用。
用於改變 linux 系統文件或目錄的訪問權限。用它控制文件或目錄的訪問權限。該命令有兩種用法。一種是包含字母和操作符表達式的文字設定法;另一種是包含數字的數字設定法。
每一文件或目錄的訪問權限都有三組,每組用三位表示,分別為文件屬主的讀、寫和執行權限;與屬主同組的用戶的讀、寫和執行權限;系統中其他用戶的讀、寫和執行權限。可使用 ls -l test.txt 查找。
以文件 log2012.log 為例:
<code>-rw-r--r-- 1 root root 296K 11-13 06:03 log2012.log/<code>
第一列共有 10 個位置,第一個字符指定了文件類型。在通常意義上,一個目錄也是一個文件。如果第一個字符是橫線,表示是一個非目錄的文件。如果是 d,表示是一個目錄。從第二個字符開始到第十個 9 個字符,3 個字符一組,分別表示了 3 組用戶對文件或者目錄的權限。權限字符用橫線代表空許可,r 代表只讀,w 代表寫,x 代表可執行。
常用參數:
<code>-c 當發生改變時,報告處理信息
-R 處理指定目錄以及其子目錄下所有文件/<code>
權限範圍:
<code>u :目錄或者文件的當前的用戶
g :目錄或者文件的當前的群組
o :除了目錄或者文件的當前用戶或群組之外的用戶或者群組
a :所有的用戶及群組/<code>
權限代號:
<code>r :讀權限,用數字4表示
w :寫權限,用數字2表示
x :執行權限,用數字1表示
- :刪除權限,用數字0表示
s :特殊權限/<code>
實例:
(1)增加文件 t.log 所有用戶可執行權限
<code>chmod a+x t.log/<code>
(2)撤銷原來所有的權限,然後使擁有者具有可讀權限,並輸出處理信息
<code>chmod u=r t.log -c/<code>
(3)給 file 的屬主分配讀、寫、執行(7)的權限,給file的所在組分配讀、執行(5)的權限,給其他用戶分配執行(1)的權限
<code>chmod 751 t.log -c(或者:chmod u=rwx,g=rx,o=x t.log -c)/<code>
(4)將 test 目錄及其子目錄所有文件添加可讀權限
<code>chmod u+r,g+r,o+r -R text/ -c/<code>
chown 命令
chown 將指定文件的擁有者改為指定的用戶或組,用戶可以是用戶名或者用戶 ID;組可以是組名或者組 ID;文件是以空格分開的要改變權限的文件列表,支持通配符。
<code>-c 顯示更改的部分的信息
-R 處理指定目錄及子目錄/<code>
實例:
(1)改變擁有者和群組 並顯示改變信息
<code>chown -c mail:mail log2012.log/<code>
(2)改變文件群組
<code>chown -c :mail t.log/<code>
(3)改變文件夾及子文件目錄屬主及屬組為 mail
<code>chown -cR mail: test//<code>
cp 命令
將源文件複製至目標文件,或將多個源文件複製至目標目錄。
注意:命令行復制,如果目標文件已經存在會提示是否覆蓋,而在 shell 腳本中,如果不加 -i 參數,則不會提示,而是直接覆蓋!
<code>-i 提示
-r 複製目錄及目錄內所有項目
-a 複製的文件與原文件時間一樣/<code>
實例:
(1)複製 a.txt 到 test 目錄下,保持原文件時間,如果原文件存在提示是否覆蓋。
<code>cp -ai a.txt test/<code>
(2)為 a.txt 建議一個鏈接(快捷方式)
<code>cp -s a.txt link_a.txt/<code>
find 命令
用於在文件樹中查找文件,並作出相應的處理。
命令格式:
<code>find pathname -options [-print -exec -ok ...]/<code>
命令參數:
<code>pathname: find命令所查找的目錄路徑。例如用.來表示當前目錄,用/來表示系統根目錄。
-print: find命令將匹配的文件輸出到標準輸出。
-exec: find命令對匹配的文件執行該參數所給出的shell命令。相應命令的形式為'command' { } \\;,注意{ }和\\;之間的空格。
-ok: 和-exec的作用相同,只不過以一種更為安全的模式來執行該參數所給出的shell命令,在執行每一個命令之前,都會給出提示,讓用戶來確定是否執行。/<code>
命令選項:
<code>-name 按照文件名查找文件
-perm 按文件權限查找文件
-user 按文件屬主查找文件
-group 按照文件所屬的組來查找文件。
-type 查找某一類型的文件,諸如:
b - 塊設備文件
d - 目錄
c - 字符設備文件
l - 符號鏈接文件
p - 管道文件
f - 普通文件/<code>
實例:
(1)查找 48 小時內修改過的文件
<code>find -atime -2/<code>
(2)在當前目錄查找 以 .log 結尾的文件。 . 代表當前目錄
<code>find ./ -name '*.log'/<code>
(3)查找 /opt 目錄下 權限為 777 的文件
<code>find /opt -perm 777/<code>
(4)查找大於 1K 的文件
<code>find -size +1000c/<code>
查找等於 1000 字符的文件
<code>find -size 1000c /<code>
-exec 參數後面跟的是 command 命令,它的終止是以 ; 為結束標誌的,所以這句命令後面的分號是不可缺少的,考慮到各個系統中分號會有不同的意義,所以前面加反斜槓。{} 花括號代表前面find查找出來的文件名。
head 命令
head 用來顯示檔案的開頭至標準輸出中,默認 head 命令打印其相應文件的開頭 10 行。
常用參數:
<code>-n 顯示的行數(行數為複數表示從最後向前數)/<code>
實例:
(1)顯示 1.log 文件中前 20 行
<code>head 1.log -n 20/<code>
(2)顯示 1.log 文件前 20 字節
<code>head -c 20 log2014.log/<code>
(3)顯示 t.log最後 10 行
<code>head -n -10 t.log/<code>
關注,後臺私信【Linux】分享Linux入門到進階電子書、Linux入門到精通視頻教程(免費)。
less 命令
less 與 more 類似,但使用 less 可以隨意瀏覽文件,而 more 僅能向前移動,卻不能向後移動,而且 less 在查看之前不會加載整個文件。
常用命令參數:
<code>-i 忽略搜索時的大小寫
-N 顯示每行的行號
-o 將less 輸出的內容在指定文件中保存起來
-s 顯示連續空行為一行
/字符串:向下搜索“字符串”的功能
?字符串:向上搜索“字符串”的功能
n:重複前一個搜索(與 / 或 ? 有關)
N:反向重複前一個搜索(與 / 或 ? 有關)
-x 將“tab”鍵顯示為規定的數字空格
b 向後翻一頁
d 向後翻半頁
h 顯示幫助界面
Q 退出less 命令
u 向前滾動半頁
y 向前滾動一行
空格鍵 滾動一行
回車鍵 滾動一頁
[pagedown]: 向下翻動一頁
[pageup]: 向上翻動一頁/<code>
實例:
(1)ps 查看進程信息並通過 less 分頁顯示
<code>ps -aux | less -N/<code>
(2)查看多個文件
<code>less 1.log 2.log/<code>
可以使用 n 查看下一個,使用 p 查看前一個。
ln 命令
功能是為文件在另外一個位置建立一個同步的鏈接,當在不同目錄需要該問題時,就不需要為每一個目錄創建同樣的文件,通過 ln 創建的鏈接(link)減少磁盤佔用量。
鏈接分類:軟件鏈接及硬鏈接
軟鏈接:
1.軟鏈接,以路徑的形式存在。類似於Windows操作系統中的快捷方式
2.軟鏈接可以 跨文件系統 ,硬鏈接不可以
3.軟鏈接可以對一個不存在的文件名進行鏈接
4.軟鏈接可以對目錄進行鏈接
硬鏈接:
1.硬鏈接,以文件副本的形式存在。但不佔用實際空間。
2.不允許給目錄創建硬鏈接
3.硬鏈接只有在同一個文件系統中才能創建
需要注意:
第一:ln命令會保持每一處鏈接文件的同步性,也就是說,不論你改動了哪一處,其它的文件都會發生相同的變化;
第二:ln的鏈接又分軟鏈接和硬鏈接兩種,軟鏈接就是ln –s 源文件 目標文件,它只會在你選定的位置上生成一個文件的鏡像,不會佔用磁盤空間,硬鏈接 ln 源文件 目標文件,沒有參數-s, 它會在你選定的位置上生成一個和源文件大小相同的文件,無論是軟鏈接還是硬鏈接,文件都保持同步變化。
第三:ln指令用在鏈接文件或目錄,如同時指定兩個以上的文件或目錄,且最後的目的地是一個已經存在的目錄,則會把前面指定的所有文件或目錄複製到該目錄中。若同時指定多個文件或目錄,且最後的目的地並非是一個已存在的目錄,則會出現錯誤信息。
常用參數:
<code>-b 刪除,覆蓋以前建立的鏈接
-s 軟鏈接(符號鏈接)
-v 顯示詳細處理過程/<code>
實例:
(1)給文件創建軟鏈接,並顯示操作信息
<code>ln -sv source.log link.log/<code>
(2)給文件創建硬鏈接,並顯示操作信息
<code>ln -v source.log link1.log/<code>
(3)給目錄創建軟鏈接
<code>ln -sv /opt/soft/test/test3 /opt/soft/test/test5/<code>
locate 命令
locate 通過搜尋系統內建文檔數據庫達到快速找到檔案,數據庫由 updatedb 程序來更新,updatedb 是由 cron daemon 週期性調用的。默認情況下 locate 命令在搜尋數據庫時比由整個由硬盤資料來搜尋資料來得快,但較差勁的是 locate 所找到的檔案若是最近才建立或 剛更名的,可能會找不到,在內定值中,updatedb 每天會跑一次,可以由修改 crontab 來更新設定值 (etc/crontab)。
locate 與 find 命令相似,可以使用如 *、? 等進行正則匹配查找
常用參數:
<code>-l num(要顯示的行數)
-f 將特定的檔案系統排除在外,如將proc排除在外
-r 使用正則運算式做為尋找條件/<code>
實例:
(1)查找和 pwd 相關的所有文件(文件名中包含 pwd)
<code>locate pwd/<code>
(2)搜索 etc 目錄下所有以 sh 開頭的文件
<code>locate /etc/sh/<code>
(3)查找 /var 目錄下,以 reason 結尾的文件
<code>locate -r '^/var.*reason$'(其中.表示一個字符,*表示任務多個;.*表示任意多個字符)/<code>
more 命令
功能類似於 cat, more 會以一頁一頁的顯示方便使用者逐頁閱讀,而最基本的指令就是按空白鍵(space)就往下一頁顯示,按 b 鍵就會往回(back)一頁顯示。
命令參數:
<code>+n 從笫 n 行開始顯示
-n 定義屏幕大小為n行
+/pattern 在每個檔案顯示前搜尋該字串(pattern),然後從該字串前兩行之後開始顯示
-c 從頂部清屏,然後顯示
-d 提示“Press space to continue,’q’ to quit(按空格鍵繼續,按q鍵退出)”,禁用響鈴功能
-l 忽略Ctrl+l(換頁)字符
-p 通過清除窗口而不是滾屏來對文件進行換頁,與-c選項相似
-s 把連續的多個空行顯示為一行
-u 把文件內容中的下畫線去掉/<code>
常用操作命令:
<code>Enter 向下 n 行,需要定義。默認為 1 行
Ctrl+F 向下滾動一屏
空格鍵 向下滾動一屏
Ctrl+B 返回上一屏
= 輸出當前行的行號
:f 輸出文件名和當前行的行號
V 調用vi編輯器
!命令 調用Shell,並執行命令
q 退出more/<code>
實例:
(1)顯示文件中從第3行起的內容
<code>more +3 text.txt/<code>
(2)在所列出文件目錄詳細信息,藉助管道使每次顯示 5 行
<code>ls -l | more -5/<code>
按空格顯示下 5 行。
mv 命令
移動文件或修改文件名,根據第二參數類型(如目錄,則移動文件;如為文件則重命令該文件)。
當第二個參數為目錄時,第一個參數可以是多個以空格分隔的文件或目錄,然後移動第一個參數指定的多個文件到第二個參數指定的目錄中。
實例:
(1)將文件 test.log 重命名為 test1.txt
<code>mv test.log test1.txt/<code>
(2)將文件 log1.txt,log2.txt,log3.txt 移動到根的 test3 目錄中
<code>mv llog1.txt log2.txt log3.txt /test3/<code>
(3)將文件 file1 改名為 file2,如果 file2 已經存在,則詢問是否覆蓋
<code>mv -i log1.txt log2.txt/<code>
(4)移動當前文件夾下的所有文件到上一級目錄
<code>mv * ..//<code>
rm 命令
刪除一個目錄中的一個或多個文件或目錄,如果沒有使用 -r 選項,則 rm 不會刪除目錄。如果使用 rm 來刪除文件,通常仍可以將該文件恢復原狀。
<code>rm [選項] 文件…/<code>
實例:
(1)刪除任何 .log 文件,刪除前逐一詢問確認:
<code>rm -i *.log/<code>
(2)刪除 test 子目錄及子目錄中所有檔案刪除,並且不用一一確認:
<code>rm -rf test/<code>
(3)刪除以 -f 開頭的文件
<code>rm -- -f*/<code>
tail 命令
用於顯示指定文件末尾內容,不指定文件時,作為輸入信息進行處理。常用查看日誌文件。
常用參數:
<code>-f 循環讀取(常用於查看遞增的日誌文件)
-n 顯示行數(從後向前)/<code>
(1)循環讀取逐漸增加的文件內容
<code>ping 127.0.0.1 > ping.log &/<code>
後臺運行:可使用 jobs -l 查看,也可使用 fg 將其移到前臺運行。
<code>tail -f ping.log/<code>
(查看日誌)
touch 命令
Linux touch命令用於修改文件或者目錄的時間屬性,包括存取時間和更改時間。若文件不存在,系統會建立一個新的文件。
ls -l 可以顯示檔案的時間記錄。
語法
<code>touch [-acfm][-d][-r] [-t][--help][--version][文件或目錄…]/<code>
參數說明:
- a 改變檔案的讀取時間記錄。
- m 改變檔案的修改時間記錄。
- c 假如目的檔案不存在,不會建立新的檔案。與 --no-create 的效果一樣。
- f 不使用,是為了與其他 unix 系統的相容性而保留。
- r 使用參考檔的時間記錄,與 --file 的效果一樣。
- d 設定時間與日期,可以使用各種不同的格式。
- t 設定檔案的時間記錄,格式與 date 指令相同。
- –no-create 不會建立新檔案。
- –help 列出指令格式。
- –version 列出版本訊息。
實例
使用指令"touch"修改文件"testfile"的時間屬性為當前系統時間,輸入如下命令:
<code>$ touch testfile #修改文件的時間屬性 /<code>
首先,使用ls命令查看testfile文件的屬性,如下所示:
<code>$ ls -l testfile #查看文件的時間屬性
#原來文件的修改時間為16:09
-rw-r--r-- 1 hdd hdd 55 2011-08-22 16:09 testfile /<code>
執行指令"touch"修改文件屬性以後,並再次查看該文件的時間屬性,如下所示:
<code>$ touch testfile #修改文件時間屬性為當前系統時間
$ ls -l testfile #查看文件的時間屬性
#修改後文件的時間屬性為當前系統時間
-rw-r--r-- 1 hdd hdd 55 2011-08-22 19:53 testfile /<code>
使用指令"touch"時,如果指定的文件不存在,則將創建一個新的空白文件。例如,在當前目錄下,使用該指令創建一個空白文件"file",輸入如下命令:
<code>$ touch file #創建一個名為“file”的新的空白文件 /<code>
vim 命令
Vim是從 vi 發展出來的一個文本編輯器。代碼補完、編譯及錯誤跳轉等方便編程的功能特別豐富,在程序員中被廣泛使用。
- 打開文件並跳到第 10 行:vim +10 filename.txt 。
- 打開文件跳到第一個匹配的行:vim +/search-term filename.txt 。
- 以只讀模式打開文件:vim -R /etc/passwd 。
基本上 vi/vim 共分為三種模式,分別是命令模式(Command mode),輸入模式(Insert mode)和底線命令模式(Last line mode)。
簡單的說,我們可以將這三個模式想成底下的圖標來表示:
whereis 命令
whereis 命令只能用於程序名的搜索,而且只搜索二進制文件(參數-b)、man說明文件(參數-m)和源代碼文件(參數-s)。如果省略參數,則返回所有信息。whereis 及 locate 都是基於系統內建的數據庫進行搜索,因此效率很高,而find則是遍歷硬盤查找文件。
常用參數:
<code>-b 定位可執行文件。
-m 定位幫助文件。
-s 定位源代碼文件。
-u 搜索默認路徑下除可執行文件、源代碼文件、幫助文件以外的其它文件。/<code>
實例:
(1)查找 locate 程序相關文件
<code>whereis locate/<code>
(2)查找 locate 的源碼文件
<code>whereis -s locate/<code>
(3)查找 lcoate 的幫助文件
<code>whereis -m locate/<code>
which 命令
在 linux 要查找某個文件,但不知道放在哪裡了,可以使用下面的一些命令來搜索:
<code>which 查看可執行文件的位置。
whereis 查看文件的位置。
locate 配合數據庫查看文件位置。
find 實際搜尋硬盤查詢文件名稱。/<code>
which 是在 PATH 就是指定的路徑中,搜索某個系統命令的位置,並返回第一個搜索結果。使用 which 命令,就可以看到某個系統命令是否存在,以及執行的到底是哪一個位置的命令。
常用參數:
<code>-n 指定文件名長度,指定的長度必須大於或等於所有文件中最長的文件名。/<code>
實例:
(1)查看 ls 命令是否存在,執行哪個
<code>which ls/<code>
(2)查看 which
<code>which which/<code>
(3)查看 cd
<code>which cd(顯示不存在,因為 cd 是內建命令,而 which 查找顯示是 PATH 中的命令)/<code>
查看當前 PATH 配置:
<code>echo $PATH/<code>
或使用 env 查看所有環境變量及對應值
grep 命令
強大的文本搜索命令,grep(Global Regular Expression Print) 全局正則表達式搜索。
grep 的工作方式是這樣的,它在一個或多個文件中搜索字符串模板。如果模板包括空格,則必須被引用,模板後的所有字符串被看作文件名。搜索的結果被送到標準輸出,不影響原文件內容。
命令格式:
<code>grep [option] pattern file|dir/<code>
常用參數:
<code>-A n --after-context顯示匹配字符後n行
-B n --before-context顯示匹配字符前n行
-C n --context 顯示匹配字符前後n行
-c --count 計算符合樣式的列數
-i 忽略大小寫
-l 只列出文件內容符合指定的樣式的文件名稱
-f 從文件中讀取關鍵詞
-n 顯示匹配內容的所在文件中行數
-R 遞歸查找文件夾/<code>
grep 的規則表達式:
<code>^ #錨定行的開始 如:'^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結尾的單詞的行。
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。/<grep>/<code>
實例:
(1)查找指定進程
<code>ps -ef | grep svn/<code>
(2)查找指定進程個數
<code>ps -ef | grep svn -c/<code>
(3)從文件中讀取關鍵詞
<code>cat test1.txt | grep -f key.log/<code>
(4)從文件夾中遞歸查找以grep開頭的行,並只列出文件
<code>grep -lR '^grep' /tmp/<code>
(5)查找非x開關的行內容
<code>grep '^[^x]' test.txt/<code>
(6)顯示包含 ed 或者 at 字符的內容行
<code>grep -E 'ed|at' test.txt/<code>
wc 命令
wc(word count)功能為統計指定的文件中字節數、字數、行數,並將統計結果輸出
命令格式:
<code>wc [option] file../<code>
命令參數:
<code>-c 統計字節數
-l 統計行數
-m 統計字符數
-w 統計詞數,一個字被定義為由空白、跳格或換行字符分隔的字符串/<code>
實例:
(1)查找文件的 行數 單詞數 字節數 文件名
<code>wc text.txt/<code>
結果:
<code>7 8 70 test.txt/<code>
(2)統計輸出結果的行數
<code>cat test.txt | wc -l/<code>
磁盤管理命令
cd 命令
cd(changeDirectory) 命令語法:
<code>cd [目錄名]/<code>
說明:切換當前目錄至 dirName。
實例:
(1)進入要目錄
<code>cd //<code>
(2)進入 “home” 目錄
<code>cd ~/<code>
(3)進入上一次工作路徑
<code>cd -/<code>
(4)把上個命令的參數作為cd參數使用。
<code>cd !$/<code>
df 命令
顯示磁盤空間使用情況。獲取硬盤被佔用了多少空間,目前還剩下多少空間等信息,如果沒有文件名被指定,則所有當前被掛載的文件系統的可用空間將被顯示。默認情況下,磁盤空間將以 1KB 為單位進行顯示,除非環境變量 POSIXLY_CORRECT 被指定,那樣將以512字節為單位進行顯示:
<code>-a 全部文件系統列表
-h 以方便閱讀的方式顯示信息
-i 顯示inode信息
-k 區塊為1024字節
-l 只顯示本地磁盤
-T 列出文件系統類型/<code>
實例:
(1)顯示磁盤使用情況
<code>df -l/<code>
(2)以易讀方式列出所有文件系統及其類型
<code>df -haT/<code>
du 命令
du 命令也是查看使用空間的,但是與 df 命令不同的是 Linux du 命令是對文件和目錄磁盤使用的空間的查看:
命令格式:
<code>du [選項] [文件]/<code>
常用參數:
<code>-a 顯示目錄中所有文件大小
-k 以KB為單位顯示文件大小
-m 以MB為單位顯示文件大小
-g 以GB為單位顯示文件大小
-h 以易讀方式顯示文件大小
-s 僅顯示總計
-c或--total 除了顯示個別目錄或文件的大小外,同時也顯示所有目錄或文件的總和/<code>
實例:
(1)以易讀方式顯示文件夾內及子文件夾大小
<code>du -h scf//<code>
(2)以易讀方式顯示文件夾內所有文件大小
<code>du -ah scf//<code>
(3)顯示幾個文件或目錄各自佔用磁盤空間的大小,還統計它們的總和
<code>du -hc test/ scf//<code>
(4)輸出當前目錄下各個子目錄所使用的空間
<code>du -hc --max-depth=1 scf//<code>
ls命令
就是 list 的縮寫,通過 ls 命令不僅可以查看 linux 文件夾包含的文件,而且可以查看文件權限(包括目錄、文件夾、文件權限)查看目錄信息等等。
常用參數搭配:
<code>ls -a 列出目錄所有文件,包含以.開始的隱藏文件
ls -A 列出除.及..的其它文件
ls -r 反序排列
ls -t 以文件修改時間排序
ls -S 以文件大小排序
ls -h 以易讀大小顯示
ls -l 除了文件名之外,還將文件的權限、所有者、文件大小等信息詳細列出來/<code>
實例:
(1) 按易讀方式按時間反序排序,並顯示文件詳細信息
<code>ls -lhrt/<code>
(2) 按大小反序顯示文件詳細信息
<code>ls -lrS/<code>
(3)列出當前目錄中所有以"t"開頭的目錄的詳細內容
<code>ls -l t*/<code>
(4) 列出文件絕對路徑(不包含隱藏文件)
<code>ls | sed "s:^:`pwd`/:"/<code>
(5) 列出文件絕對路徑(包含隱藏文件)
<code>find $pwd -maxdepth 1 | xargs ls -ld/<code>
mkdir 命令
mkdir 命令用於創建文件夾。
可用選項:
- -m: 對新建目錄設置存取權限,也可以用 chmod 命令設置;
- -p: 可以是一個路徑名稱。此時若路徑中的某些目錄尚不存在,加上此選項後,系統將自動建立好那些尚不在的目錄,即一次可以建立多個目錄。
實例:
(1)當前工作目錄下創建名為 t的文件夾
<code>mkdir t/<code>
(2)在 tmp 目錄下創建路徑為 test/t1/t 的目錄,若不存在,則創建:
<code>mkdir -p /tmp/test/t1/t/<code>
pwd 命令
pwd 命令用於查看當前工作目錄路徑。
實例:
(1)查看當前路徑
<code>pwd/<code>
(2)查看軟鏈接的實際路徑
<code>pwd -P/<code>
rmdir 命令
從一個目錄中刪除一個或多個子目錄項,刪除某目錄時也必須具有對其父目錄的寫權限。
注意:不能刪除非空目錄
實例:
(1)當 parent 子目錄被刪除後使它也成為空目錄的話,則順便一併刪除:
<code>rmdir -p parent/child/child11/<code>
網絡通訊命令
ifconfig 命令
- ifconfig 用於查看和配置 Linux 系統的網絡接口。
- 查看所有網絡接口及其狀態:ifconfig -a 。
- 使用 up 和 down 命令啟動或停止某個接口:ifconfig eth0 up 和 ifconfig eth0 down 。
iptables 命令
iptables ,是一個配置 Linux 內核防火牆的命令行工具。功能非常強大,對於我們開發來說,主要掌握如何開放端口即可。例如:
- 把來源 IP 為 192.168.1.101 訪問本機 80 端口的包直接拒絕:iptables -I INPUT -s 192.168.1.101 -p tcp --dport 80 -j REJECT 。
- 開啟 80 端口,因為web對外都是這個端口
<code>iptables -A INPUT -p tcp --dport 80 -j ACCEP/<code>
另外,要注意使用 iptables save 命令,進行保存。否則,服務器重啟後,配置的規則將丟失。
netstat 命令
Linux netstat命令用於顯示網絡狀態。
利用netstat指令可讓你得知整個Linux系統的網絡情況。
語法
<code>netstat [-acCeFghilMnNoprstuvVwx][-A][--ip]/<code>
參數說明:
- -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"參數相同。
實例
如何查看系統都開啟了哪些端口?
<code>[root@centos6 ~ 13:20 #55]# netstat -lnp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN 1035/sshd
tcp 0 0 :::22 :::* LISTEN 1035/sshd
udp 0 0 0.0.0.0:68 0.0.0.0:* 931/dhclient
Active UNIX domain sockets (only servers)
Proto RefCnt Flags Type State I-Node PID/Program name Path
unix 2 [ ACC ] STREAM LISTENING 6825 1/init @/com/ubuntu/upstart
unix 2 [ ACC ] STREAM LISTENING 8429 1003/dbus-daemon /var/run/dbus/system_bus_socket/<code>
如何查看網絡連接狀況?
<code>[root@centos6 ~ 13:22 #58]# netstat -an
Active Internet connections (servers and established)
Proto Recv-Q Send-Q Local Address Foreign Address State
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN
tcp 0 0 192.168.147.130:22 192.168.147.1:23893 ESTABLISHED
tcp 0 0 :::22 :::* LISTEN
udp 0 0 0.0.0.0:68 0.0.0.0:*/<code>
如何統計系統當前進程連接數?
- 輸入命令 netstat -an | grep ESTABLISHED | wc -l 。
- 輸出結果 177 。一共有 177 連接數。
用 netstat 命令配合其他命令,按照源 IP 統計所有到 80 端口的 ESTABLISHED 狀態鏈接的個數?
嚴格來說,這個題目考驗的是對 awk 的使用。
首先,使用 netstat -an|grep ESTABLISHED 命令。結果如下:
<code>tcp 0 0 120.27.146.122:80 113.65.18.33:62721 ESTABLISHED
tcp 0 0 120.27.146.122:80 27.43.83.115:47148 ESTABLISHED
tcp 0 0 120.27.146.122:58838 106.39.162.96:443 ESTABLISHED
tcp 0 0 120.27.146.122:52304 203.208.40.121:443 ESTABLISHED
tcp 0 0 120.27.146.122:33194 203.208.40.122:443 ESTABLISHED
tcp 0 0 120.27.146.122:53758 101.37.183.144:443 ESTABLISHED
tcp 0 0 120.27.146.122:27017 23.105.193.30:50556 ESTABLISHED/<code>
ping 命令
Linux ping命令用於檢測主機。
執行ping指令會使用ICMP傳輸協議,發出要求回應的信息,若遠端主機的網絡功能沒有問題,就會回應該信息,因而得知該主機運作正常。
指定接收包的次數
<code>ping -c 2 www.baidu.com/<code>
telnet 命令
Linux telnet命令用於遠端登入。
執行telnet指令開啟終端機階段作業,並登入遠端主機。
語法
<code>telnet [-8acdEfFKLrx][-b][-e][-k][-l][-n][-S][-X][主機名稱或IP地址]/<code>
參數說明:
- -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 關閉指定的認證形態。
實例
登錄遠程主機
<code># 登錄IP為 192.168.0.5 的遠程主機
telnet 192.168.0.5 /<code>
系統管理命令
date 命令
顯示或設定系統的日期與時間。
命令參數:
<code>-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 年份(以四位數來表示)。/<code>
實例:
(1)顯示下一天
<code>date +%Y%m%d --date="+1 day" //顯示下一天的日期/<code>
(2)-d參數使用
<code>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(下個月是幾月)/<code>
free 命令
顯示系統內存使用情況,包括物理內存、交互區內存(swap)和內核緩衝區內存。
命令參數:
<code>-b 以Byte顯示內存使用情況
-k 以kb為單位顯示內存使用情況
-m 以mb為單位顯示內存使用情況
-g 以gb為單位顯示內存使用情況
-s 持續顯示內存
-t 顯示內存使用總合/<code>
實例:
(1)顯示內存使用情況
<code>free
free -k
free -m/<code>
(2)以總和的形式顯示內存的使用信息
<code>free -t/<code>
(3)週期性查詢內存使用情況
<code>free -s 10/<code>
kill 命令
發送指定的信號到相應進程。不指定型號將發送SIGTERM(15)終止指定進程。如果任無法終止該程序可用"-KILL" 參數,其發送的信號為SIGKILL(9) ,將強制結束進程,使用ps命令或者jobs 命令可以查看進程號。root用戶將影響用戶的進程,非root用戶只能影響自己的進程。
常用參數:
<code>-l 信號,若果不加信號的編號參數,則使用“-l”參數會列出全部的信號名稱
-a 當處理當前進程時,不限制命令名和進程號的對應關係
-p 指定kill 命令只打印相關進程的進程號,而不發送任何信號
-s 指定發送信號
-u 指定用戶/<code>
實例:
(1)先使用ps查找進程pro1,然後用kill殺掉
<code>kill -9 $(ps -ef | grep pro1)/<code>
ps 命令
ps(process status),用來查看當前運行的進程狀態,一次性查看,如果需要動態連續結果使用 top
linux上進程有5種狀態:
- 運行(正在運行或在運行隊列中等待)
- 中斷(休眠中, 受阻, 在等待某個條件的形成或接受到信號)
- 不可中斷(收到信號不喚醒和不可運行, 進程必須等待直到有中斷髮生)
- 僵死(進程已終止, 但進程描述符存在, 直到父進程調用wait4()系統調用後釋放)
- 停止(進程收到SIGSTOP, SIGSTP, SIGTIN, SIGTOU信號後停止運行運行)
ps 工具標識進程的5種狀態碼:
<code>D 不可中斷 uninterruptible sleep (usually IO)
R 運行 runnable (on run queue)
S 中斷 sleeping
T 停止 traced or stopped
Z 僵死 a defunct (”zombie”) process/<code>
命令參數:
<code>-A 顯示所有進程
a 顯示所有進程
-a 顯示同一終端下所有進程
c 顯示進程真實名稱
e 顯示環境變量
f 顯示進程間的關係
r 顯示當前終端運行的進程
-aux 顯示所有包含其它使用的進程/<code>
實例:
(1)顯示當前所有進程環境變量及進程間關係
<code>ps -ef/<code>
(2)顯示當前所有進程
<code>ps -A/<code>
(3)與grep聯用查找某進程
<code>ps -aux | grep apache/<code>
(4)找出與 cron 與 syslog 這兩個服務有關的 PID 號碼
<code>ps aux | grep '(cron|syslog)'/<code>
rpm 命令
Linux rpm 命令用於管理套件。
rpm(redhat package manager) 原本是 Red Hat Linux 發行版專門用來管理 Linux 各項套件的程序,由於它遵循 GPL 規則且功能強大方便,因而廣受歡迎。逐漸受到其他發行版的採用。RPM 套件管理方式的出現,讓 Linux 易於安裝,升級,間接提升了 Linux 的適用度。
<code># 查看系統自帶jdk
rpm -qa | grep jdk
# 刪除系統自帶jdk
rpm -e --nodeps 查看jdk顯示的數據
# 安裝jdk
rpm -ivh jdk-7u80-linux-x64.rpm/<code>
top 命令
顯示當前系統正在執行的進程的相關信息,包括進程 ID、內存佔用率、CPU 佔用率等
常用參數:
<code>-c 顯示完整的進程命令
-s 保密模式
-p 指定進程顯示
-n 循環顯示次數/<code>
實例:
<code>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/<code>
前五行是當前系統情況整體的統計信息區。
第一行,任務隊列信息,同 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狀態信息,具體屬性說明如下:
<code>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的百分比/<code>
備註:在這裡CPU的使用比率和windows概念不同,需要理解linux系統用戶空間和內核空間的相關知識!
第四行,內存狀態,具體信息如下:
<code>32949016k total — 物理內存總量(32GB)
14411180k used — 使用中的內存總量(14GB)
18537836k free — 空閒內存總量(18GB)
169884k buffers — 緩存的內存量 (169M)/<code>
第五行,swap交換分區信息,具體信息說明如下:
<code>32764556k total — 交換區總量(32GB)
0k used — 使用的交換區總量(0K)
32764556k free — 空閒交換區總量(32GB)
3612636k cached — 緩衝的交換區總量(3.6GB)/<code>
第六行,空行。
第七行以下:各進程(任務)的狀態監控,項目列信息說明如下:
<code>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 — 進程名稱(命令名/命令行)/<code>
top 交互命令
<code>h 顯示top交互命令幫助信息
c 切換顯示命令名稱和完整命令行
m 以內存使用率排序
P 根據CPU使用百分比大小進行排序
T 根據時間/累計時間進行排序
W 將當前設置寫入~/.toprc文件中
o或者O 改變顯示項目的順序/<code>
yum 命令
yum( Yellow dog Updater, Modified)是一個在Fedora和RedHat以及SUSE中的Shell前端軟件包管理器。
基於RPM包管理,能夠從指定的服務器自動下載RPM包並且安裝,可以自動處理依賴性關係,並且一次安裝所有依賴的軟體包,無須繁瑣地一次次下載、安裝。
yum提供了查找、安裝、刪除某一個、一組甚至全部軟件包的命令,而且命令簡潔而又好記。
1.列出所有可更新的軟件清單命令:yum check-update
2.更新所有軟件命令:yum update
3.僅安裝指定的軟件命令:yum install <package>
4.僅更新指定的軟件命令:yum update <package>
5.列出所有可安裝的軟件清單命令:yum list
6.刪除軟件包命令:yum remove <package>
7.查找軟件包 命令:yum search
8.清除緩存命令:
yum clean packages: 清除緩存目錄下的軟件包
yum clean headers: 清除緩存目錄下的 headers
yum clean oldheaders: 清除緩存目錄下舊的 headers
yum clean, yum clean all (= yum clean packages; yum clean oldheaders) :清除緩存目錄下的軟件包及舊的headers
實例
安裝 pam-devel
<code>[root@www ~]# yum install pam-devel/<code>
備份壓縮命令
bzip2 命令
創建 *.bz2 壓縮文件:bzip2 test.txt 。
解壓 *.bz2 文件:bzip2 -d test.txt.bz2 。
gzip 命令
創建一個 *.gz 的壓縮文件:gzip test.txt 。
解壓 *.gz 文件:gzip -d test.txt.gz 。
顯示壓縮的比率:gzip -l *.gz 。
tar 命令
用來壓縮和解壓文件。tar 本身不具有壓縮功能,只具有打包功能,有關壓縮及解壓是調用其它的功能來完成。
弄清兩個概念:打包和壓縮。打包是指將一大堆文件或目錄變成一個總的文件;壓縮則是將一個大的文件通過一些壓縮算法變成一個小文件
常用參數:
<code>-c 建立新的壓縮文件
-f 指定壓縮文件
-r 添加文件到已經壓縮文件包中
-u 添加改了和現有的文件到壓縮包中
-x 從壓縮包中抽取文件
-t 顯示壓縮文件中的內容
-z 支持gzip壓縮
-j 支持bzip2壓縮
-Z 支持compress解壓文件
-v 顯示操作過程/<code>
有關 gzip 及 bzip2 壓縮:
<code>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/<code>
實例:
(1)將文件全部打包成 tar 包
<code>tar -cvf log.tar 1.log,2.log 或tar -cvf log.*/<code>
(2)將 /etc 下的所有文件及目錄打包到指定目錄,並使用 gz 壓縮
<code>tar -zcvf /tmp/etc.tar.gz /etc/<code>
(3)查看剛打包的文件內容(一定加z,因為是使用 gzip 壓縮的)
<code>tar -ztvf /tmp/etc.tar.gz/<code>
(4)要壓縮打包 /home, /etc ,但不要 /home/dmtsai
<code>tar --exclude /home/dmtsai -zcvf myfile.tar.gz /home/* /etc/<code>
unzip 命令
解壓 *.zip 文件:unzip test.zip 。
查看 *.zip 文件的內容:unzip -l jasper.zip 。
<code>原文鏈接:https://blog.csdn.net/ThinkWon/article/details/104588679/<code>
閱讀更多 lee哥說架構 的文章