主頁 > 作業系統 > Linux 的一些常用命令

Linux 的一些常用命令

2020-09-21 16:05:48 作業系統

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 命令

cd(changeDirectory) 命令語法:

cd [目錄名]

說明:切換當前目錄至 dirName,

實體:

(1)進入要目錄

cd /

(2)進入 "home" 目錄

cd ~

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

cd -

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

cd !$

3、pwd 命令

pwd 命令用于查看當前作業目錄路徑,

實體:

(1)查看當前路徑

pwd

(2)查看軟鏈接的實際路徑

pwd -P

4、mkdir 命令

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 命令

移動檔案或修改檔案名,根據第二引數型別(如目錄,則移動檔案;如為檔案則重命令該檔案),

當第二個引數為目錄時,第一個引數可以是多個以空格分隔的檔案或目錄,然后移動第一個引數指定的多個檔案到第二個引數指定的目錄中,

實體:

(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
PWD=/opt/soft/test
World
Hello

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  向前滾動一行
空格鍵 滾動一行
回車鍵 滾動一頁
[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

查找等于 1000 字符的檔案

find -size 1000c

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

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  行程使用的虛擬記憶體總量,單位kbVIRT=SWAP+RES
RES  行程使用的、未被換出的物理記憶體大小,單位kbRES=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

轉載請註明出處,本文鏈接:https://www.uj5u.com/caozuo/98109.html

標籤:Linux

上一篇:nginx筆記(一)

下一篇:[apue] getopt 可能重排引數

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • CA和證書

    1、在 CentOS7 中使用 gpg 創建 RSA 非對稱密鑰對 gpg --gen-key #Centos上生成公鑰/密鑰對(存放在家目錄.gnupg/) 2、將 CentOS7 匯出的公鑰,拷貝到 CentOS8 中,在 CentOS8 中使用 CentOS7 的公鑰加密一個檔案 gpg -a ......

    uj5u.com 2020-09-10 00:09:53 more
  • Kubernetes K8S之資源控制器Job和CronJob詳解

    Kubernetes的資源控制器Job和CronJob詳解與示例 ......

    uj5u.com 2020-09-10 00:10:45 more
  • VMware下安裝CentOS

    VMware下安裝CentOS 一、軟硬體準備 1 Centos鏡像準備 1.1 CentOS鏡像下載地址 下載地址 1.2 CentOS鏡像下載程序 點擊下載地址進入如下圖的網站,選擇需要下載的版本,這里選擇的是Centos8,點擊如圖所示。 決定選擇Centos8后,選擇想要的鏡像源進行下載,此 ......

    uj5u.com 2020-09-10 00:12:10 more
  • 如何使用Grep命令查找多個字串

    如何使用Grep 命令查找多個字串 大家好,我是良許! 今天向大家介紹一個非常有用的技巧,那就是使用 grep 命令查找多個字串。 簡單介紹一下,grep 命令可以理解為是一個功能強大的命令列工具,可以用它在一個或多個輸入檔案中搜索與正則運算式相匹配的文本,然后再將每個匹配的文本用標準輸出的格式 ......

    uj5u.com 2020-09-10 00:12:28 more
  • git配置http代理

    git配置http代理 經常遇到克隆 github 慢的問題,這里記錄一下幾種配置 git 代理的方法,解決 clone github 過慢。 目錄 git配置代理 git單獨配置github代理 git配置全域代理 配置終端環境變數 git配置代理 主要使用 git config 命令 git單獨 ......

    uj5u.com 2020-09-10 00:12:33 more
  • Linux npm install 裝包時提示Error EACCES permission denied解

    npm install 裝包時提示Error EACCES permission denied解決辦法 ......

    uj5u.com 2020-09-10 00:12:53 more
  • Centos 7下安裝nginx,使用yum install nginx,提示沒有可用的軟體包

    Centos 7下安裝nginx,使用yum install nginx,提示沒有可用的軟體包。 18 (flaskApi) [root@67 flaskDemo]# yum -y install nginx 19 已加載插件:fastestmirror, langpacks 20 Loading ......

    uj5u.com 2020-09-10 00:13:13 more
  • Linux查看服務器暴力破解ssh IP

    在公網的服務器上經常遇到別人爆破你服務器的22埠,用來挖礦或者干其他嘿嘿嘿的事情~ 這種情況下正確的做法是: 修改默認ssh的22埠 使用設定密鑰登錄或者白名單ip登錄 建議服務器密碼為復雜密碼 創建普通用戶登錄服務器(root權限過大) 建立堡壘機,實作統一管理服務器 統計爆破IP [root ......

    uj5u.com 2020-09-10 00:13:17 more
  • CentOS 7系統常見快捷鍵操作方式

    Linux系統中一些常見的快捷方式,可有效提高操作效率,在某些時刻也能避免操作失誤帶來的問題。 ......

    uj5u.com 2020-09-10 00:13:31 more
  • CentOS 7作業系統目錄結構介紹

    作業系統存在著大量的資料檔案資訊,相應檔案資訊會存在于系統相應目錄中,為了更好的管理資料資訊,會將系統進行一些目錄規劃,不同目錄存放不同的資源。 ......

    uj5u.com 2020-09-10 00:13:35 more
最新发布
  • vim的常用命令

    Vim的6種基本模式 1. 普通模式在普通模式中,用的編輯器命令,比如移動游標,洗掉文本等等。這也是Vim啟動后的默認模式。這正好和許多新用戶期待的操作方式相反(大多數編輯器默認模式為插入模式)。 2. 插入模式在這個模式中,大多數按鍵都會向文本緩沖中插入文本。大多數新用戶希望文本編輯器編輯程序中一 ......

    uj5u.com 2023-04-20 08:43:21 more
  • vim的常用命令

    Vim的6種基本模式 1. 普通模式在普通模式中,用的編輯器命令,比如移動游標,洗掉文本等等。這也是Vim啟動后的默認模式。這正好和許多新用戶期待的操作方式相反(大多數編輯器默認模式為插入模式)。 2. 插入模式在這個模式中,大多數按鍵都會向文本緩沖中插入文本。大多數新用戶希望文本編輯器編輯程序中一 ......

    uj5u.com 2023-04-20 08:42:36 more
  • docker學習

    ###Docker概述 真實專案部署環境可能非常復雜,傳統發布專案一個只需要一個jar包,運行環境需要單獨部署。而通過Docker可將jar包和相關環境(如jdk,redis,Hadoop...)等打包到docker鏡像里,將鏡像發布到Docker倉庫,部署時下載發布的鏡像,直接運行發布的鏡像即可。 ......

    uj5u.com 2023-04-19 09:26:53 more
  • 設定Windows主機的瀏覽器為wls2的默認瀏覽器

    這里以Chrome為例。 1. 準備作業 wsl是可以使用Windows主機上安裝的exe程式,出于安全考慮,默認情況下改功能是無法使用。要使用的話,終端需要以管理員權限啟動。 我這里以Windows Terminal為例,介紹如何默認使用管理員權限打開終端,具體操作如下圖所示: 2. 操作 wsl ......

    uj5u.com 2023-04-19 09:25:49 more
  • docker學習

    ###Docker概述 真實專案部署環境可能非常復雜,傳統發布專案一個只需要一個jar包,運行環境需要單獨部署。而通過Docker可將jar包和相關環境(如jdk,redis,Hadoop...)等打包到docker鏡像里,將鏡像發布到Docker倉庫,部署時下載發布的鏡像,直接運行發布的鏡像即可。 ......

    uj5u.com 2023-04-19 09:19:04 more
  • Linux學習筆記

    IP地址和主機名 IP地址 ifconfig可以用來查詢本機的IP地址,如果不能使用,可以通過install net-tools安裝。 Centos系統下ens33表示主網卡;inet后表示IP地址;lo表示本地回環網卡; 127.0.0.1表示代指本機;0.0.0.0可以用于代指本機,同時在放行設 ......

    uj5u.com 2023-04-18 06:52:01 more
  • 解決linux系統的kdump服務無法啟動的問題

    問題:專案麒麟系統服務器的kdump服務無法啟動,沒有相關日志無法定位問題。 1、查看服務狀態是關閉的,重啟系統也無法啟動 systemctl status kdump 2、修改grub引數,修改“crashkernel”為“512M(有的機器數值太大太小都會導致報錯,建議從128M開始試,或者加個 ......

    uj5u.com 2023-04-12 09:59:50 more
  • 解決linux系統的kdump服務無法啟動的問題

    問題:專案麒麟系統服務器的kdump服務無法啟動,沒有相關日志無法定位問題。 1、查看服務狀態是關閉的,重啟系統也無法啟動 systemctl status kdump 2、修改grub引數,修改“crashkernel”為“512M(有的機器數值太大太小都會導致報錯,建議從128M開始試,或者加個 ......

    uj5u.com 2023-04-12 09:59:01 more
  • 你是不是暴露了?

    作者:袁首京 原創文章,轉載時請保留此宣告,并給出原文連接。 如果您是計算機相關從業人員,那么應該經歷不止一次網路安全專項檢查了,你肯定是收到過資訊系統技術檢測報告,要求你加強風險監測,確保你提供的系統服務堅實可靠了。 沒檢測到問題還好,檢測到問題的話,有些處理起來還是挺麻煩的,尤其是線上正在運行的 ......

    uj5u.com 2023-04-05 16:52:56 more
  • 細節拉滿,80 張圖帶你一步一步推演 slab 記憶體池的設計與實作

    1. 前文回顧 在之前的幾篇記憶體管理系列文章中,筆者帶大家從宏觀角度完整地梳理了一遍 Linux 記憶體分配的整個鏈路,本文的主題依然是記憶體分配,這一次我們會從微觀的角度來探秘一下 Linux 內核中用于零散小記憶體塊分配的記憶體池 —— slab 分配器。 在本小節中,筆者還是按照以往的風格先帶大家簡單 ......

    uj5u.com 2023-04-05 16:44:11 more