首頁 > 運維 > linux運維 > linux常用指令詳解和用法

linux常用指令詳解和用法

coldplay.xixi
發布: 2020-09-12 11:34:02
原創
24300 人瀏覽過

linux常用指令詳解與用法:1、reboot指令用於重啟機器;2、ls指令用於檢視linux資料夾所包含的檔案;3、cd切換指令用於切換目前目錄至dirName;4 、pwd指令用於查看目前工作目錄路徑;5、mkdir指令用於建立資料夾等等。

相關學習推薦:linux影片教學

開關機指令

reboot命令用于重启机器
poweroff用于关闭系统
登入後複製

ifconfig 查看ip位址

直接输入ifconfig会列出已经启动的网卡,也可以输入ifconfig eth0单独显示eth0的信息
各选项解释是:
eth0    网卡的代号 
lo        回环地址loopback
inet    IPv4的Ip地址
netmask    子网掩码
broadcast    广播地址
RX/TX     流量发/收情况     tx是发送(transport),rx是接收(receive)
packets     数据包数
errors     数据包错误数
dropped    数据包有问题被丢弃的数量
collisions    数据包碰撞情况,数值太多代表网络状况差
登入後複製

#使用者相關

  • 新增使用者,設定密碼

    #添加用户
    useradd oldboy 
    #设置密码       
    passwd redhat
    
    root用户可以修改其他所有人的密码,且不需要验证
    登入後複製
  • 切換使用者

    su命令可以切换用户身份的需求,
    su - username
    
    su命令中间的-号很重要,意味着完全切换到新的用户,即环境变量信息也变更为新用户的信息
    登入後複製
  • #查看目前使用者

    #先看下当前用户(我是谁)
    whoami
    #切换用户
    su - oldboy
    #退出用户登录
    logout
    ctrl + d
    登入後複製

權限相關

  • 查看權限

    ls -l /var/log/mysqld.log
    登入後複製

    #
    r    read可读,可以用cat等命令查看
    w    write写入,可以编辑或者删除这个文件
    x    executable    可以执行
    登入後複製

特殊字元重定向相關

输入/输出 重定向符号
1.>>    追加重定向,把文字追加到文件的结尾
2.>     重定向符号,清空原文件所有内容,然后把文字覆盖到文件末尾
3. /tmp/oldboy.txt
echo "chaoge666" >> /tmp/oldboy.txt
cat >>/tmp/oldboy.txt  /tmp/network.txt   #标准输出重定向 把命令执行结果信息,放入到文件中
3.通配符  
ls -l /etc/us*
登入後複製

iptables防火牆

centos7默认已经使用firewall作为防火墙了
1.关闭防火墙
systemctl status firewalld #查看防火墙状态
systemctl stop firewalld    #关闭防火墙
systemctl disable firewalld#关闭防火墙开机启动
systemctl is-enabled firewalld.service#检查防火墙是否启动
登入後複製

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 切換

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

實例:

(1)進入要目錄

cd /

(2)進入"家"目錄

cd ~

(3)進入上次工作路徑

cd -

(4)把上一個指令的參數當作cd參數。

cd !$

3、pwd 查看目前工作目錄路徑

#查看目前工作目錄路徑

實例:

(1)查看目前路徑

pwd

(2)查看軟連結的實際路徑

pwd -P

4、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 移動/修改檔案名稱

移動檔案或修改檔案名,根據第二參數類型(如目錄,則移動檔案;如為檔案則重命令該文件)。

當第二個參數為目錄時,可剛將多個檔案以空格分隔為第一參數,移動多個檔案到參數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 * ../

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

>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 | 更多 -5

按空格顯示下5行

# 11.less指令

less 與more 類似,但使用less 可以隨意瀏覽文件,而more 僅能向前移動,卻不能向後移動,而且less 在查看之前不會加載整個文件。

常用指令參數

-i  忽略搜尋時的大小寫

-N  顯示每行的行號

-o  -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 從頭n行文字內容

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從尾n行文字

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

常用參數:

-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

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

18、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結尾的單字的行。

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

19、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

20、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實例:##bz2實例:##壓縮bzip2 -z filename .tar.bz2 解壓縮:bunzip filename.bz2或bzip -d filename.bz2

對應:tar jcvf filename.tar.gz         解壓縮:tar jxvf name.tar. ##實例:

(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

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

22、df 顯示磁碟空間

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

-a 全部檔案系統清單

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

-i 顯示inode資訊

-k 區塊為1024位元組

-l 只顯示本機磁碟

#-T 列出檔案系統類型

實例:

(1)顯示磁碟使用情況

df -l

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

df -haT

23、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/

24、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

25、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(下個月是幾月)

26、cal指令

可以使用者顯示公曆(陽曆)日曆如只有一個參數,則表示年份(1-9999),如有兩個參數,則表示月份和年份

常用參數:

-3 顯示前一月,當月,後一月三個月的日曆

-m 顯示星期一為第一列

-j 顯示在當前年第幾天

-y [year]顯示當前年[year]份的日曆

實例:

(1)顯示指定年月日期

cal 9 2012

(2)顯示2013年每月日曆

cal -y 2013

(3)將星期一做為第一列,顯示前中後三月

cal -3m

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#i05 sleeping,   0 stopped,   0 zombie#sy#sy# 40%) ,  0.0%ni, 90.4%id,  0.0%wa,  0.0%hi,  0.2%si,  0.0%st

Mem:  32949016k total, 1441

#Mem:  32949016k total, 1441

#Mem:  32949016k total, 1441

#Mem:  32949016k total, 1441

#Mem:  328852, #Swap : 32764556k total,        0k used, 32764556k free,  3612636k cached

PID USER  

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 — 进程使用的虚拟内存总量,单位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 — 进程名称(命令名/命令行)

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

32、scp 传输文件

    scp是 secure copy的缩写, scp是linux系统下基于ssh登陆进行安全的远程文件拷贝命令

  • 语法
scp 【可选参数】 本地源文件 远程文件标记
登入後複製
  • 参数

    -r :递归复制整个目录
    -v:详细方式输出
    -q:不显示传输进度条
    -C:允许压缩
    登入後複製
  • 实例

    #传输本地文件到远程地址
    scp 本地文件  远程用户名@远程ip:远程文件夹/
    scp 本地文件  远程用户名@远程ip:远程文件夹/远程文件名
    
    scp /tmp/chaoge.py root@192.168.1.155:/home/
    scp /tmp/chaoge.py root@192.168.1.155:/home/chaoge_python.py
    
    scp -r  本地文件夹  远程用户名@远程ip:远程文件夹/
    scp -r /tmp/oldboy root@192.168.1.155:/home/oldboy
    
    #复制远程文件到本地
    scp root@192.168.1.155:/home/oldboy.txt /tmp/oldboy.txt
    scp -r root@192.168.1.155:/home/oldboy /home/
    登入後複製

33、VI 和vim   编辑文本

vi filename :打开或新建文件,并将光标置于第一行首

vi n filename :打开文件,并将光标置于第n行首

vi filename :打开文件,并将光标置于一行首

vi /pattern filename:打开文件,并将光标置于第一个与pattern匹配的串处

vi -r filename :在上次正用vi编辑时发生系统崩溃,恢复filename

vi filename....filename :打开多个文件,依次进行编辑

屏幕翻滚类命令

Ctrl u:向文件首翻半屏

Ctrl d:向文件尾翻半屏

Ctrl f:向文件尾翻一屏

Ctrl+b;向文件首翻一屏

nz:将第n行滚至屏幕顶部,不指定n时将当前行滚至屏幕顶部.

插入文本类命令

i :在光标前

I :在当前行首

a:光标后

A:在当前行尾

o:在当前行之下新开一行

O:在当前行之上新开一行

r:替换当前字符

R:替换当前字符及其后的字符,直至按ESC键

s:从当前光标位置处开始,以输入的文本替代指定数目的字符

保存命令

按ESC键 跳到命令模式,然后:

:w   保存文件但不退出vi

:w file 将修改另外保存到file中,不退出vi

:w!   强制保存,不推出vi

:wq  保存文件并退出vi

:wq! 强制保存文件,并退出vi

:q  不保存文件,退出vi

:q! 不保存文件,强制退出vi

:e! 放弃所有修改,从上次保存文件开始再编辑

之后,回车,ok!

详情博客:https://www.cnblogs.com/pyyu/p/9460649.html

常见环境变量变量

1、PATH

  • 注意事项: PATH中的环境变量有顺序,如果你添加的变量需要优先被搜索出,需要添加在变量首,否则放在尾部

  • 指定的命令搜索路径

  • 查看PATH

    echo $PATH
    登入後複製
  • 1 临时修改PATH变量

    export PATH=/usr/local/mongdb/bin:$PATH   # 将mongdb下的bin目录放在临时放在PATH变量中,以:号进行分割,
    登入後複製

    修改后通过echo $PATH查看配置

    优点:立即生效,

    缺点:临时改变,只针对当前终端,退出就恢复原样

  • 2 针对用户修改PATH变量

    vim ~/.bashrc 
    #在最后一行添加
    export PATH=/usr/local/mongodb/bin:$PATH
    
    #保存关闭
    #读取该文件让其生效
    source ~/.bashrc
    登入後複製

    优点:针对当前用户,永久有效

    缺点:仅限当前用户

  • 3 全局修改PATH变量

    # 编辑该文件
    vim /etc/profile
    
    # 在文件尾添加,
    export PATH=/usr/local/mongodb/bin:$PATH
    
    # 保存退出,重启生效
    登入後複製

    优点:针对所有用户

2、PS1 设置命令提示符显示的内容

  • 查看

    echo $PS1
    登入後複製
  • 内部变量

    \d  日期
    \H  完整主机名
    \h  主机名第一个名字
    \t  时间24小时制HHMMSS
    \T  时间12小时制
    \A  时间24小时制HHMM
    \u  当前用户账号名
    \v  BASH的版本
    \w  完整工作目录
    \W  利用basename取得工作目录名
    \#  下达的第几个命令
    \$  提示字符,root为#,普通用户为$
    登入後複製
  • 全局修改

    vim /etc/profile 
    
    # 尾添加
    PS1='[\u@\h \W\t]\$'    # 针对上述变量自行更改
    登入後複製

    注意重启

  • 临时修改

    export PS1='[\u@\h \W\t]\$'
    登入後複製

管道命令

命令格式: 命令A | 命令B

Linux提供的管道符“|”讲两条命令隔开,管道符左边命令的输出会作为管道符右边命令的输入。
常见用法:
#检查python程序是否启动
ps -ef|grep "python"

#找到/tmp目录下所有txt文件
ls /tmp|grep '.txt'

#检查nginx的端口是否存活
netstat -tunlp |grep nginx
登入後複製

alias 起别名命令

Linux如何提示你,在使用这些命令时候,提醒你小心呢?
#查看系统别名
alias
默认别名
alias cp='cp -i'
alias egrep='egrep --color=auto'
alias fgrep='fgrep --color=auto'
alias grep='grep --color=auto'
alias l.='ls -d .* --color=auto'
alias ll='ls -l --color=auto'
alias ls='ls --color=auto'
alias mv='mv -i'
alias rm='rm -i'
alias which='alias | /usr/bin/which --tty-only --read-alias --show-dot --show-tilde'

别名作用是:

我们在linux中使用cp时候相当于执行了cp -i
-i:删除已有文件或目录之前先询问用户;

#别名用比较危险的操作,防止你犯错
登入後複製

实例  为rm设置别名

#让系统显示 do not use rm
echo do not use rm
#设置rm别名
alias rm='echo do not use rm'
#设置别名永久生效,写入到/etc/profile(针对登录用户的合同,设置环境变量)
vim /etc/profile #编辑文件
G  快速到达最后一行
o  当前行下一行,创建一个新行,进入编辑模式
source /etc/profile #读取文件(合同生效)
---------------
#取消别名
unalias rm
登入後複製

想了解更多编程学习,敬请关注php培训栏目!

以上是linux常用指令詳解和用法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板