玩過Linux的人都會知道,Linux中的命令的確是非常多,但是玩過Linux的人也從來不會因為Linux的命令如此之多而煩惱,因為我們只需要掌握我們最常用的命令就可以了。當然你也可以在使用時去找一下man,他會幫你解決不少的問題。然而每個人玩Linux的目的都不同,所以他們常用的命令也就差異非常大,而我主要是用Linux進行C/C++和shell程序編寫的,所以常用到的命令可以就會跟一個管理Linux系統的人有所不同。因為不想在使用是總是東查西找,所以在此總結一下,方便一下以後的查看。不多說,下面就說說我最常用的Linux命令。
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:反向選擇,即顯示出沒有‘查找字符串’內容的那一行
#例如:
#取出文件/etc/man.config中包含MANPATH的行,並把找到的關鍵字加上顏色
grep--color=auto'MANPATH'/etc/man.config
#把ls-l的輸出中包含字母file(不區分大小寫)的內容輸出
ls-l|grep-ifile
4、find命令
find是一個基於查找的功能非常強大的命令,相對而言,它的使用也相對較為復雜,參數也比較多,所以在這裡將給把它們分類列出,它的基本語法如下:
find[PATH][option][action]
#與時間有關的參數:
-mtimen:n為數字,意思為在n天之前的“一天內”被更改過的文件;
-mtime+n:列出在n天之前(不含n天本身)被更改過的文件名;
-mtime-n:列出在n天之內(含n天本身)被更改過的文件名;
-newerfile:列出比file還要新的文件名
#例如:
find/root-mtime0#在當前目錄下查找今天之內有改動的文件
#與用戶或用戶組名有關的參數:
-username:列出文件所有者為name的文件
-groupname:列出文件所屬用戶組為name的文件
-uidn:列出文件所有者為用戶ID為n的文件
-gidn:列出文件所屬用戶組為用戶組ID為n的文件
#例如:
find/home/ljianhui-userljianhui#在目錄/home/ljianhui中找出所有者為ljianhui的文件
#與文件權限及名稱有關的參數:
-namefilename:找出文件名為filename的文件
-size[+-]SIZE:找出比SIZE還要大(+)或小(-)的文件
-tpyeTYPE:查找文件的類型為TYPE的文件,TYPE的值主要有:一般文件(f)、設備文件(b、c)、
目錄(d)、連接文件(l)、socket(s)、FIFO管道文件(p);
-permmode:查找文件權限剛好等於mode的文件,mode用數字表示,如0755;
-perm-mode:查找文件權限必須要全部包括mode權限的文件,mode用數字表示
-perm+mode:查找文件權限包含任一mode的權限的文件,mode用數字表示
#例如:
find/-namepasswd#查找文件名為passwd的文件
find.-perm0755#查找當前目錄中文件權限的0755的文件
find.-size+12k#查找當前目錄中大於12KB的文件,注意c表示byte
5、cp命令
該命令用於復制文件,copy之意,它還可以把多個文件一次性地復制到一個目錄下,它的常用參數如下:
-a:將文件的特性一起復制
-p:連同文件的屬性一起復制,而非使用默認方式,與-a相似,常用於備份
-i:若目標文件已經存在時,在覆蓋時會先詢問操作的進行
-r:遞歸持續復制,用於目錄的復制行為
-u:目標文件與源文件有差異時才會復制
例如 :
cp-afile1file2#連同文件的所有特性把文件file1復制成文件file2
cpfile1file2file3dir#把文件file1、file2、file3復制到目錄dir中
6、mv命令
該命令用於移動文件、目錄或更名,move之意,它的常用參數如下:
-f:force強制的意思,如果目標文件已經存在,不會詢問而直接覆蓋
-i:若目標文件已經存在,就會詢問是否覆蓋
-u:若目標文件已經存在,且比目標文件新,才會更新
注:該命令可以把一個文件或多個文件一次移動一個文件夾中,但是最後一個目標文件一定要是“目錄”。
例如:
mvfile1file2file3dir#把文件file1、file2、file3移動到目錄dir中
mvfile1file2#把文件file1重命名為file2
7、rm命令
該命令用於刪除文件或目錄,remove之間,它的常用參數如下:
-f:就是force的意思,忽略不存在的文件,不會出現警告消息
-i:互動模式,在刪除前會詢問用戶是否操作
-r:遞歸刪除,最常用於目錄刪除,它是一個非常危險的參數
例如:
rm-ifile#刪除文件file,在刪除之前會詢問是否進行該操作
rm-frdir#強制刪除目錄dir中的所有文件
8、ps命令
該命令用於將某個時間點的進程運行情況選取下來並輸出,process之意,它的常用參數如下:
-A:所有的進程均顯示出來
-a:不與terminal有關的所有進程
-u:有效用戶的相關進程
-x:一般與a參數一起使用,可列出較完整的信息
-l:較長,較詳細地將PID的信息列出
其實我們只要記住ps一般使用的命令參數搭配即可,它們並不多,如下:
psaux#查看系統所有的進程數據
psax#查看不與terminal有關的所有進程
ps-lA#查看系統所有的進程數據
psaxjf#查看連同一部分進程樹狀態
9、kill命令
該命令用於向某個工作(%jobnumber)或者是某個PID(數字)傳送一個信號,它通常與ps和jobs命令一起使用,它的基本語法如下:
kill-signalPID
signal的常用參數如下:
注:最前面的數字為信號的代號,使用時可以用代號代替相應的信號。
[plain]view plaincopyprint?
1:SIGHUP,啟動被終止的進程
2:SIGINT,相當於輸入ctrl+c,中斷一個程序的進行
9:SIGKILL,強制中斷一個進程的進行
15:SIGTERM,以正常的結束進程方式來終止進程
17:SIGSTOP,相當於輸入ctrl+z,暫停一個進程的進行
例如:
#以正常的結束進程方式來終於第一個後台工作,可用jobs命令查看後台中的第一個工作進程
kill-SIGTERM%1
#重新改動進程ID為PID的進程,PID可用ps命令通過管道命令加上grep命令進行篩選獲得
kill-SIGHUPPID