1、cd命令 這是一個非常基本,也是大家經常需要使用的命令,它用於切換當前目錄,它的參數是要切換到的目錄的路徑,可以是絕對路徑,也可以是相對路徑。如: cd /root/Docements # 切換到目錄/root/Docements cd /root/Docements # 切換到目錄/root/ ...
1、cd命令
這是一個非常基本,也是大家經常需要使用的命令,它用於切換當前目錄,它的參數是要切換到的目錄的路徑,可以是絕對路徑,也可以是相對路徑。如:
- cd /root/Docements # 切換到目錄/root/Docements
- cd ./path # 切換到當前目錄下的path目錄中,“.”表示當前目錄
- cd ../path # 切換到上層目錄中的path目錄中,“..”表示上一層目錄
2、ls命令
這是一個非常有用的查看文件與目錄的命令,list之意,它的參數非常多,下麵就列出一些我常用的參數吧,如下:
- -l :列出長數據串,包含文件的屬性與許可權數據等
- -a :列出全部的文件,連同隱藏文件(開頭為.的文件)一起列出來(常用)
- -d :僅列出目錄本身,而不是列出目錄的文件數據
- -h :將文件容量以較易讀的方式(GB,kB等)列出來
- -R :連同子目錄的內容一起列出(遞歸列出),等於該目錄下的所有文件都會顯示出來
註:這些參數也可以組合使用,下麵舉兩個例子:
- ls -l #以長數據串的形式列出當前目錄下的數據文件和目錄
- ls -lR #以長數據串的形式列出當前目錄下的所有文件
3、grep命令
該命令常用於分析一行的信息,若當中有我們所需要的信息,就將該行顯示出來,該命令通常與管道命令一起使用,用於對一些命令的輸出進行篩選加工等等,它的簡單語法為
grep [-acinv] [--color=auto] '查找字元串' filename
它的常用參數如下:
- -a :將binary文件以text文件的方式查找數據
- -c :計算找到‘查找字元串’的次數
- -i :忽略大小寫的區別,即把大小寫視為相同
- -v :反向選擇,即顯示出沒有‘查找字元串’內容的那一行
- grep --color=auto 'MANPATH' /etc/man.config
- ls -l | grep -i file
4、find命令
find是一個基於查找的功能非常強大的命令,相對而言,它的使用也相對較為複雜,參數也比較多,所以在這裡將給把它們分類列出,它的基本語法如下:
- find [PATH] [option] [action]
- # 與時間有關的參數:
- -mtime n : n為數字,意思為在n天之前的“一天內”被更改過的文件;
- -mtime +n : 列出在n天之前(不含n天本身)被更改過的文件名;
- -mtime -n : 列出在n天之內(含n天本身)被更改過的文件名;
- -newer file : 列出比file還要新的文件名
- # 例如:
- find /root -mtime 0 # 在當前目錄下查找今天之內有改動的文件
- # 與用戶或用戶組名有關的參數:
- -user name : 列出文件所有者為name的文件
- -group name : 列出文件所屬用戶組為name的文件
- -uid n : 列出文件所有者為用戶ID為n的文件
- -gid n : 列出文件所屬用戶組為用戶組ID為n的文件
- # 例如:
- find /home/ljianhui -user ljianhui # 在目錄/home/ljianhui中找出所有者為ljianhui的文件
- # 與文件許可權及名稱有關的參數:
- -name filename :找出文件名為filename的文件
- -size [+-]SIZE :找出比SIZE還要大(+)或小(-)的文件
- -tpye TYPE :查找文件的類型為TYPE的文件,TYPE的值主要有:一般文件(f)、設備文件(b、c)、
- 目錄(d)、連接文件(l)、socket(s)、FIFO管道文件(p);
- -perm mode :查找文件許可權剛好等於mode的文件,mode用數字表示,如0755;
- -perm -mode :查找文件許可權必須要全部包括mode許可權的文件,mode用數字表示
- -perm +mode :查找文件許可權包含任一mode的許可權的文件,mode用數字表示
- # 例如:
- find / -name passwd # 查找文件名為passwd的文件
- find . -perm 0755 # 查找當前目錄中文件許可權的0755的文件
- find . -size +12k # 查找當前目錄中大於12KB的文件,註意c表示byte
5、cp命令
該命令用於複製文件,copy之意,它還可以把多個文件一次性地複製到一個目錄下,它的常用參數如下:
- -a :將文件的特性一起複制
- -p :連同文件的屬性一起複制,而非使用預設方式,與-a相似,常用於備份
- -i :若目標文件已經存在時,在覆蓋時會先詢問操作的進行
- -r :遞歸持續複製,用於目錄的複製行為
- -u :目標文件與源文件有差異時才會複製
例如 :
- cp -a file1 file2 #連同文件的所有特性把文件file1複製成文件file2
- cp file1 file2 file3 dir #把文件file1、file2、file3複製到目錄dir中
6、mv命令
該命令用於移動文件、目錄或更名,move之意,它的常用參數如下:
- -f :force強制的意思,如果目標文件已經存在,不會詢問而直接覆蓋
- -i :若目標文件已經存在,就會詢問是否覆蓋
- -u :若目標文件已經存在,且比目標文件新,才會更新
註:該命令可以把一個文件或多個文件一次移動一個文件夾中,但是最後一個目標文件一定要是“目錄”。
例如:
- mv file1 file2 file3 dir # 把文件file1、file2、file3移動到目錄dir中
- mv file1 file2 # 把文件file1重命名為file2
7、rm命令
該命令用於刪除文件或目錄,remove之間,它的常用參數如下:
- -f :就是force的意思,忽略不存在的文件,不會出現警告消息
- -i :互動模式,在刪除前會詢問用戶是否操作
- -r :遞歸刪除,最常用於目錄刪除,它是一個非常危險的參數
例如:
- rm -i file # 刪除文件file,在刪除之前會詢問是否進行該操作
- rm -fr dir # 強制刪除目錄dir中的所有文件
8、ps命令
該命令用於將某個時間點的進程運行情況選取下來並輸出,process之意,它的常用參數如下:
- -A :所有的進程均顯示出來
- -a :不與terminal有關的所有進程
- -u :有效用戶的相關進程
- -x :一般與a參數一起使用,可列出較完整的信息
- -l :較長,較詳細地將PID的信息列出
其實我們只要記住ps一般使用的命令參數搭配即可,它們並不多,如下:
- ps aux # 查看系統所有的進程數據
- ps ax # 查看不與terminal有關的所有進程
- ps -lA # 查看系統所有的進程數據
- ps axjf # 查看連同一部分進程樹狀態
9、kill命令
該命令用於向某個工作(%jobnumber)或者是某個PID(數字)傳送一個信號,它通常與ps和jobs命令一起使用,它的基本語法如下:
kill -signal PID
signal的常用參數如下:
註:最前面的數字為信號的代號,使用時可以用代號代替相應的信號。
- 1:SIGHUP,啟動被終止的進程
- 2:SIGINT,相當於輸入ctrl+c,中斷一個程式的進行
- 9:SIGKILL,強制中斷一個進程的進行
- 15:SIGTERM,以正常的結束進程方式來終止進程
- 17:SIGSTOP,相當於輸入ctrl+z,暫停一個進程的進行
例如:
- # 以正常的結束進程方式來終於第一個後臺工作,可用jobs命令查看後臺中的第一個工作進程
- kill -SIGTERM %1
- # 重新改動進程ID為PID的進程,PID可用ps命令通過管道命令加上grep命令進行篩選獲得
- kill -SIGHUP PID
10、killall命令
該命令用於向一個命令啟動的進程發送一個信號,它的一般語法如下:
killall [-iIe] [command name]
它的參數如下:
- -i :互動式的意思,若需要刪除時,會詢問用戶
- -e :表示後面接的command name要一致,但command name不能超過15個字元
- -I :命令名稱忽略大小寫
- # 例如:
- killall -SIGHUP syslogd # 重新啟動syslogd
11、file命令
該命令用於判斷接在file命令後的文件的基本數據,因為在Linux下文件的類型並不是以尾碼為分的,所以這個命令對我們來說就很有用了,它的用法非常簡單,基本語法如下:
- file filename
- #例如:
- file ./test
12、tar命令
該命令用於對文件進行打包,預設情況並不會壓縮,如果指定了相應的參數,它還會調用相應的壓縮程式(如gzip和bzip等)進行壓縮和解壓。它的常用參數如下:
- -c :新建打包文件
- -t :查看打包文件的內容含有哪些文件名
- -x :解打包或解壓縮的功能,可以搭配-C(大寫)指定解壓的目錄,註意-c,-t,-x不能同時出現在同一條命令中
- -j :通過bzip2的支持進行壓縮/解壓縮
- -z :通過gzip的支持進行壓縮/解壓縮
- -v :在壓縮/解壓縮過程中,將正在處理的文件名顯示出來
- -f filename :filename為要處理的文件
- -C dir :指定壓縮/解壓縮的目錄dir
上面的解說可以已經讓你暈過去了,但是通常我們只需要記住下麵三條命令即可:
- 壓縮:tar -jcv -f filename.tar.bz2 要被處理的文件或目錄名稱
- 查詢:tar -jtv -f filename.tar.bz2
- 解壓:tar -jxv -f filename.tar.bz2 -C 欲解壓縮的目錄
註:文件名並不定要以尾碼tar.bz2結尾,這裡主要是為了說明使用的壓縮程式為bzip2
13、cat命令
該命令用於查看文本文件的內容,後接要查看的文件名,通常可用管道與more和less一起使用,從而可以一頁頁地查看數據。例如:
- cat text | less
14、chgrp命令
該命令用於改變文件所屬用戶組,它的使用非常簡單,它的基本用法如下:
- chgrp [-R] dirname/filename
- -R :進行遞歸的持續對所有文件和子目錄更改
- # 例如:
- chgrp users -R ./dir # 遞歸地把dir目錄下中的所有文件和子目錄下所有文件的用戶組修改為users
15、chown命令
該命令用於改變文件的所有者,與chgrp命令的使用方法相同,只是修改的文件屬性不同,不再詳述。
16、chmod命令
(1)文檔類型:
d 表示目錄 ,l 表示軟連接 – 表示文件,c表示串列埠字元設備文件,b表示可供存儲的塊設備文件。餘下的字元3個字元為一組。r 只讀,w 可寫,x可執行,- 表示無此許可權為空。
chmod 數字設定法
數字設定法中數字表示的含義,0表示沒有任何許可權,1表示有可執行=x,2表示有可執行許可權=w,4表示有可讀許可權=r。
該命令用於改變文件的許可權,一般的用法如下:
- chmod [-R] xyz 文件或目錄
- -R:進行遞歸的持續更改,即連同子目錄下的所有文件都會更改
同時,chmod還可以使用u(user)、g(group)、o(other)、a(all)和+(加入)、-(刪除)、=(設置)跟rwx搭配來對文件的許可權進行更改。
- # 例如:
- chmod 0755 file # 把file的文件許可權改變為-rxwr-xr-x
- chmod g+w file # 向file的文件許可權中加入用戶組可寫許可權
18、vim命令
該命令主要用於文本編輯,它接一個或多個文件名作為參數,如果文件存在就打開,如果文件不存在就以該文件名創建一個文件。vim是一個非常好用的文本編輯器,它裡面有很多非常好用的命令,在這裡不再多說。你可以從這裡下載vim常用操作的詳細說明。
19、gcc命令
對於一個用Linux開發C程式的人來說,這個命令就非常重要了,它用於把C語言的源程式文件,編譯成可執行程式,由於g++的很多參數跟它非常相似,所以這裡只介紹gcc的參數,它的常用參數如下:
- -o :output之意,用於指定生成一個可執行文件的文件名
- -c :用於把源文件生成目標文件(.o),並阻止編譯器創建一個完整的程式
- -I :增加編譯時搜索頭文件的路徑
- -L :增加編譯時搜索靜態連接庫的路徑
- -S :把源文件生成彙編代碼文件
- -lm:表示標準庫的目錄中名為libm.a的函數庫
- -lpthread :連接NPTL實現的線程庫
- -std= :用於指定把使用的C語言的版本
- # 例如:
- # 把源文件test.c按照c99標準編譯成可執行程式test
- gcc -o test test.c -lm -std=c99
- #把源文件test.c轉換為相應的彙編程式源文件test.s
- gcc -S test.c
該命令用於測算一個命令(即程式)的執行時間。它的使用非常簡單,就像平時輸入命令一樣,不過在命令的前面加入一個time即可,例如:
- time ./process
- time ps aux
在程式或命令運行結束後,在最後輸出了三個時間,它們分別是:
user:用戶CPU時間,命令執行完成花費的用戶CPU時間,即命令在用戶態中執行時間總和;
system:系統CPU時間,命令執行完成花費的系統CPU時間,即命令在核心態中執行時間總和;
real:實際時間,從command命令行開始執行到運行終止的消逝時間;
原博客:https://blog.csdn.net/ljianhui/article/details/11100625 1、cd命令 這是一個非常基本,也是大家經常需要使用的命令,它用於切換當前目錄,它的參數是要切換到的目錄的路徑,可以是絕對路徑,也可以是相對路徑。如:
- cd /root/Docements # 切換到目錄/root/Docements
- cd ./path # 切換到當前目錄下的path目錄中,“.”表示當前目錄
- cd ../path # 切換到上層目錄中的path目錄中,“..”表示上一層目錄
- -l :列出長數據串,包含文件的屬性與許可權數據等
- -a :列出全部的文件,連同隱藏文件(開頭為.的文件)一起列出來(常用)
- -d :僅列出目錄本身,而不是列出目錄的文件數據
- -h :將文件容量以較易讀的方式(GB,kB等)列出來
- -R :連同子目錄的內容一起列出(遞歸列出),等於該目錄下的所有文件都會顯示出來
- ls -l #以長數據串的形式列出當前目錄下的數據文件和目錄
- ls -lR #以長數據串的形式列出當前目錄下的所有文件
grep [-acinv] [--color=auto] '查找字元串' filename
它的常用參數如下:
- -a :將binary文件以text文件的方式查找數據
- -c :計算找到‘查找字元串’的次數
- -i :忽略大小寫的區別,即把大小寫視為相同
- -v :反向選擇,即顯示出沒有‘查找字元串’內容的那一行
- grep --color=auto 'MANPATH' /etc/man.config
- ls -l | grep -i file
- find [PATH] [option] [action]
- # 與時間有關的參數:
- -mtime n : n為數字,意思為在n天之前的“一天內”被更改過的文件;
- -mtime +n : 列出在n天之前(不含n天本身)被更改過的文件名;
- -mtime -n : 列出在n天之內(含n天本身)被更改過的文件名;
- -newer file : 列出比file還要新的文件名
- # 例如:
- find /root -mtime 0 # 在當前目錄下查找今天之內有改動的文件
- # 與用戶或用戶組名有關的參數:
- -user name : 列出文件所有者為name的文件
- -group name : 列出文件所屬用戶組為name的文件
- -uid n : 列出文件所有者為用戶ID為n的文件
- -gid n : 列出文件所屬用戶組為用戶組ID為n的文件
- # 例如:
- find /home/ljianhui -user ljianhui # 在目錄/home/ljianhui中找出所有者為ljianhui的文件
- # 與文件許可權及名稱有關的參數:
- -name filename :找出文件名為filename的文件
- -size [+-]SIZE :找出比SIZE還要大(+)或小(-)的文件
- -tpye TYPE :查找文件的類型為TYPE的文件,TYPE的值主要有:一般文件(f)、設備文件(b、c)、
- 目錄(d)、連接文件(l)、socket(s)、FIFO管道文件(p);
- -perm mode :查找文件許可權剛好等於mode的文件,mode用數字表示,如0755;
- -perm -mode :查找文件許可權必須要全部包括mode許可權的文件,mode用數字表示
- -perm +mode :查找文件許可權包含任一mode的許可權的文件,mode用數字表示
- # 例如:
- find / -name passwd # 查找文件名為passwd的文件
- find . -perm 0755 # 查找當前目錄中文件許可權的0755的文件
- find . -size +12k # 查找當前目錄中大於12KB的文件,註意c表示byte
- -a :將文件的特性一起複制
- -p :連同文件的屬性一起複制,而非使用預設方式,與-a相似,常用於備份
- -i :若目標文件已經存在時,在覆蓋時會先詢問操作的進行
- -r :遞歸持續複製,用於目錄的複製行為
- -u :目標文件與源文件有差異時才會複製
- cp -a file1 file2 #連同文件的所有特性把文件file1複製成文件file2
- cp file1 file2 file3 dir #把文件file1、file2、file3複製到目錄dir中
- -f :force強制的意思,如果目標文件已經存在,不會詢問而直接覆蓋
- -i :若目標文件已經存在,就會詢問是否覆蓋
- -u :若目標文件已經存在,且比目標文件新,才會更新
- mv file1 file2 file3 dir # 把文件file1、file2、file3移動到目錄dir中
- mv file1 file2 # 把文件file1重命名為file2
- -f :就是force的意思,忽略不存在的文件,不會出現警告消息
- -i :互動模式,在刪除前會詢問用戶是否操作
- -r :遞歸刪除,最常用於目錄刪除,它是一個非常危險的參數
- rm -i file # 刪除文件file,在刪除之前會詢問是否進行該操作
- rm -fr dir # 強制刪除目錄dir中的所有文件
- -A :所有的進程均顯示出來
- -a :不與terminal有關的所有進程
- -u :有效用戶的相關進程
- -x :一般與a參數一起使用,可列出較完整的信息
- -l :較長,較詳細地將PID的信息列出
- ps aux # 查看系統所有的進程數據
- ps ax # 查看不與terminal有關的所有進程
- ps -lA # 查看系統所有的進程數據
- ps axjf # 查看連同一部分進程樹狀態
kill -signal PID
signal的常用參數如下:
註:最前面的數字為信號的代號,使用時可以用代號代替相應的信號。
- 1:SIGHUP,啟動被終止的進程
- 2:SIGINT,相當於輸入ctrl+c,中斷一個程式的進行
- 9:SIGKILL,強制中斷一個進程的進行
- 15:SIGTERM,以正常的結束進程方式來終止進程
- 17:SIGSTOP,相當於輸入ctrl+z,暫停一個進程的進行
- # 以正常的結束進程方式來終於第一個後臺工作,可用jobs命令查看後臺中的第一個工作進程
- kill -SIGTERM %1
- # 重新改動進程ID為PID的進程,PID可用ps命令通過管道命令加上grep命令進行篩選獲得
- kill -SIGHUP PID
killall [-iIe] [command name]
它的參數如下:
- -i :互動式的意思,若需要刪除時,會詢問用戶
- -e :表示後面接的command name要一致,但command name不能超過15個字元
- -I :命令名稱忽略大小寫
- # 例如:
-
killall -SIGHUP syslogd # 重新啟動syslogd