20180601

cut命令
1.作用:cut命令是一個選取命令,其功能是將文件中的每一行”字節” ”字符” ”字段” 進行剪切,選取我們需要的,並將這些選取好的數據輸出至標準輸出
2.格式:
cut -[n]b file
cut -c file
cut -d[分隔符] -f[域] file
3.參數解釋:
-b(bytes) :以字節爲單位進行分割。這些字節位置將忽略多字節字符邊界,除非也指定了 -n 標誌。
-c(characters) :以字符爲單位進行分割。
-d :自定義分隔符,默認爲製表符。
-f(filed) :與-d一起使用,指定顯示哪個區域。
-n :取消分割多字節字符。僅和 -b 標誌一起使用。如果字符的最後一個字節落在由 -b 標誌的 List 參數指示的
範圍之內,該字符將被寫出;否則,該字符將被排除。
cut分割截取字符串
1)-b
20180601
20180601
20180601
20180601
20180601

20180601

20180601

20180601
剪切字符:
20180601
20180601
20180601
2) -c
20180601
3) -f
20180601
20180601

sort命令
sort命令支持常用的排序功能
-n
– number-sort
按字符串數值排序,與-g區別爲不轉爲浮點數,以數字排序,其他數值爲0
-g
–general-number-sort
按通用數值排序,支持科學計數法
-f
–ignore-case
忽略大小寫,默認大小寫字母不同
-k
–key=POS1[,POS2]
排序從POS1開始,若指定POS2,則POS2結束,否則以pos1排序
-t
–field-separator=SEP
指定列的分割符
-r
–reverse
降序排序,默認爲升序
-h
–human-numeric-sort
使用易讀性數字(例如: 2K 1G)
-u
–unique
去除重複的行
-o
–output=FILE
將輸出寫入文件

1)默認排序
20180601

2)數字排序
20180601

3)指定列排序
sort排序的時候,可以按字段分割的數據進行排序。-t參數表示行的分割字符,-k表示第幾列。當然,可以進行降序排序,-r參數可以實現。
下面是對passwd文件,以冒號(:)進行分割,然後對第三列以數字方式進行降序排序。
20180601

4)文件夾大小排序
在du的時候,加上-h可以使用易讀性數字,比如2k,1g,3M這種。sort也支持-h參數。
比如,du一個文件夾下的目錄大小後,想以文件大小進行排序。由於du -h的結果是3k,2M,1G這種,不能簡單的按數字排序。所以,可以使用-h參數。具體如下:
20180601

5)系統進程內存佔用排序
查看系統進程中,內存佔用最多的前5個進程信息
20180601

6)對文件進行去重排序
如果文件內容有很多重複的,需要進行去重。sort也是支持的,可以通過-u參數使用
20180601

7)將sort輸出內容寫入文件
在shell中,一般將控制檯內容寫入文件,可以使用重定向,但如果想把sort的排序內容寫回文件,則不能使用重定向。則需要-o參數。具體如下:

20180601

wc命令
wc -l只顯示行數
wc -w只顯示數字
wc -m只顯示詞
wc -L拋棄換行符

uniq
uniq命令可以去除排序過的文件中的重複行,因此uniq經常和sort合用。也就是說,爲了使uniq起作用,所有的重複行必須是相鄰的。
20180601

tee命令
在執行Linux命令時,我們既想把輸出保存到文件中,又想在屏幕上看到輸出內容,就可以使用tee命令
要注意的是:在使用管道線時,前一個命令的標準錯誤輸出不會被tee讀取。
20180601
sort -a追加
20180601

tr命令
1、關於tr
通過使用 tr,您可以非常容易地實現 sed 的許多最基本功能。您可以將 tr 看作爲 sed 的(極其)簡化的變體:它可以用一個字符來替換另一個字符,或者可以完全除去一些字符。您也可以用它來除去重複字符。這就是所有 tr 所能夠做的。
tr用來從標準輸入中通過替換或刪除操作進行字符轉換。tr主要用於刪除文件中控制字符或進行字符轉換。使用tr時要轉換兩個字符串:字符串1用於查詢, 字符串2用於處理各種轉換。tr剛執行時,字符串1中的字符被映射到字符串2中的字符,然後轉換操作開始。
帶有最常用選項的tr命令格式爲:
tr -c -d -s ["string1_to_translate_from"] ["string2_to_translate_to"] < input-file
這裏:
-c 用字符串1中字符集的補集替換此字符集,要求字符集爲ASCII。
-d 刪除字符串1中所有輸入字符。
-s 刪除所有重複出現字符序列,只保留第一個;即將重複出現字符串壓縮爲一個字符串。
input-file是轉換文件名。雖然可以使用其他格式輸入,但這種格式最常用。
2、字符範圍
指定字符串1或字符串2的內容時,只能使用單字符或字符串範圍或列表。
[a-z] a-z內的字符組成的字符串。
[A-Z] A-Z內的字符組成的字符串。
[0-9] 數字串。
/octal 一個三位的八進制數,對應有效的ASCII字符。
[On] 表示字符O重複出現指定次數n。因此[O2]匹配OO的字符串。
tr中特定控制字符的不同表達方式
速記符含義八進制方式
/a Ctrl-G 鈴聲/007
/b Ctrl-H 退格符/010
/f Ctrl-L 走行換頁/014
/n Ctrl-J 新行/012
/r Ctrl-M 回車/015
/t Ctrl-I tab鍵/011
/v Ctrl-X /030
3、應用例子
(1)去除oops.txt裏面的重複的小寫字符
tr -s "[a-z]"<oops.txt >result.txt
(2)刪除空行
tr -s "[/012]" < plan.txt 或 tr -s ["/n"] < plan.txt
(3)有時需要刪除文件中的^M,並代之以換行
tr -s "[/015]" "[/n]" < file 或 tr -s "[/r]" "[/n]" < file
(4)大寫到小寫
cat a.txt |tr "[a-z]" "[A-Z]" >b.txt
(5)刪除指定字符
一個星期的日程表。任務是從其中刪除所有數字,只保留日期。日期有大寫,也有小寫格式。因此需指定兩個字符範圍[a-z]和[A-Z],命令tr -cs "[a-z][A-Z]" "[/012]" 將文件每行所有不包含在[a-z]或[A-Z](所有希臘字母)的字符串放在字符串1中並轉換爲一新行。-s選項表明壓縮所有新行, -c表明保留所有字母不動。原文件如下,後跟tr命令:
tr -cs "[a-z][A-Z]" "[/012
]" <diary.txt
(6)轉換控制字符
tr的第一個功能就是轉換控制字符,特別是從dos向UNIX下載文件時,忘記設置ftp關於回車換行轉換的選項時更是如此。cat -v filename 顯示控制字符。
cat -v stat.txt
box aa^^^^^12^M
apple bbas^^^^23^M
^Z
猜想‘^ ^ ^ ^ ^ ^’是tab鍵。每一行以Ctrl-M結尾,文件結尾Ctrl-Z,以下是改動方法。
使用-s選項,查看ASCII表。^的八進制代碼是136,^M是015,tab鍵是011,^Z是032 ,下面將按步驟完成最終功能。
用tab鍵替換^ ^ ^ ^ ^ ^,命令爲"/136" "[/011]"。將結果重定向到臨時工作文件stat.tmp
tr -s "[/136]" "[/011
]" <stat.txt >stat.tmp
用新行替換每行末尾的^M,並用/n去除^Z,輸入要來自於臨時工作文件stat.tmp。
tr -s "[/015][/032]" "/n" <stat.tmp
要刪除所有的tab鍵,代之以空格,使用命令
tr -s "[/011]" "[/040*]" <input.file
(7)替換passwd文件中所有冒號,代之以tab鍵,可以增加可讀性
tr -s "[:]" "[/011]" < /etc/passwd 或 tr -s "[:]" "[/t]" < /etc/passwd
(8)使路徑具有可讀性
如果用 echo $PATH 或者 echo $LD_LIBRARY_PATH 等類似的命令來顯示路徑信息的話,我們看到的將會是一大堆用冒號連接在一起的路徑, tr命令可以把這些冒號轉換爲回車,這樣,這些路徑就具有很好的可讀性了
echo $PATH | tr ":" "/n"
(9)可以在vi內使用所有這些命令!只要記住:在tr命令前要加上您希望處理的行範圍和感嘆號 (!),如 1,$!tr -d '/t'(美元符號表示最後一行)。
(10)另外,當有人給您發送了一個在 Mac OS 或 DOS/Windows 機器上創建的文本文件時,您會發現tr非常有用。
如果沒有將文件保存爲使用 UNIX 換行符來表示行結束這種格式,則需要將這樣的文件轉換成本機 UNIX 格式,否則一些命令實用程序不會正確地處理這些文件。Mac OS 的行尾以回車字符(/r)結束,許多文本處理工具將這樣的文件作爲一行來處理。爲了糾正這個問題,可以用下列技巧:
Mac -> UNIX:tr "/r" "/n"<macfile > unixfile
UNIX -> Mac:tr "/n" "/r"<unixfile > macfile
Microsoft DOS/Windows 約定,文本的每行以回車字符(/r)並後跟換行符(/n)結束。爲了糾正這個問題,可以使用下列命令:
DOS -> UNIX:tr -d "/r"<dosfile > unixfile
UNIX -> DOS:在這種情況下,需要用awk,因爲tr不能插入兩個字符來替換一個字符。要使用的 awk 命令爲 awk '{ print $0"/r" }'<unixfile > dosfile

split命令
split命令可以將一個大文件分割成很多個小文件,有時需要將文件分割成更小的片段,比如爲提高可讀性,生成日誌等。
20180601
生成一個大小爲100KB的測試文件:
20180601
使用split命令將上面創建的date.file文件分割成大小爲10KB的小文件:
20180601
文件被分割成多個帶有字母的後綴文件,如果想用數字後綴可使用-d參數,同時可以使用-a length來指定後綴的長度:
20180601
爲分割後的文件指定文件名的前綴:
20180601
使用-l選項根據文件的行數來分割文件,例如把文件分割成每個包含10行的小文件:
20180601

在Linux Shell中有很多的特殊符號,這對於我們寫Shell腳本時要特別留意:一方面要知道這些特殊符號的用法,這些符號用好了可以達到事半功倍的效果;但另一方面要避免這些特殊符號的過度使用而導致腳本難以調試、難以閱讀。
這些特殊符號羅列出來大致如下:
複製代碼
代碼如下:

; ;; . , / / ‘string'| ! $ ${} $? $$ $ “string” ** ? : ^ $# $@ command{} [] [[]] () (()) || && {xx,yy,zz,…}~ ~+ ~- & / + – %= == !=

輸出/輸入重導向:
複製代碼
代碼如下:

< << : > &> 2&> 2<>>& >&2

下面就逐一介紹這些特殊符號的含義和用法……

井號 (comments)

這幾乎是個滿場都有的符號。
#!/bin/bash
井號也常出現在一行的開頭,或者位於完整指令之後,這類情況表示符號後面的是註解文字,不會被執行。

This line is comments.

echo “a = $a” # a = 0
由於這個特性,當臨時不想執行某行指令時,只需在該行開頭加上 # 就行了。這常用在撰寫過程中。
#echo “a = $a” # a = 0
如果被用在指令中,或者引號雙引號括住的話,或者在倒斜線的後面,那他就變成一般符號,不具上述的特殊功能。
~ 帳戶的 home 目錄
算是個常見的符號,代表使用者的 home 目錄:cd ~;也可以直接在符號後加上某帳戶的名稱:cd ~user
或者當成是路徑的一部份:~/bin;~+ 當前的工作目錄,這個符號代表當前的工作目錄,她和內建指令 pwd 的作用是相同的。

echo ~+/var/log

~- 上次的工作目錄,這個符號代表上次的工作目錄。

echo ~-/etc/httpd/logs

; 分號 (Command separator)
在 shell 中,擔任”連續指令”功能的符號就是”分號”。譬如以下的例子:cd ~/backup ; mkdir startup ; cp ~/.* startup/.
;; 連續分號 (Terminator)
專用在 case 的選項,擔任 Terminator 的角色。
case “$fop” inhelp) echo “Usage: Command -help -version filename” ;;version) echo “version 0.1″ ;;esac
. 逗號 (dot)
在 shell 中,使用者應該都清楚,一個 dot 代表當前目錄,兩個 dot 代表上層目錄。
CDPATH=.:~:/home:/home/web:/var:/usr/local
在上行 CDPATH 的設定中,等號後的 dot 代表的就是當前目錄的意思。
如果檔案名稱以 dot 開頭,該檔案就屬特殊檔案,用 ls 指令必須加上 -a 選項纔會顯示。除此之外,在 regular expression 中,一個 dot 代表匹配一個字元。
‘string' 單引號 (single quote)
被單引號用括住的內容,將被視爲單一字串。在引號內的代表變數的$符號,沒有作用,也就是說,他被視爲一般符號處理,防止任何變量替換。
heyyou=homeecho ‘$heyyou' # We get $heyyou
“string” 雙引號 (double quote)
被雙引號用括住的內容,將被視爲單一字串。它防止通配符擴展,但允許變量擴展。這點與單引數的處理方式不同。
heyyou=homeecho “$heyyou” # We get home
command 倒引號 (backticks)
在前面的單雙引號,括住的是字串,但如果該字串是一列命令列,會怎樣?答案是不會執行。要處理這種情況,我們得用倒單引號來做。
fdv=date +%Fecho “Today $fdv”
在倒引號內的 date +%F 會被視爲指令,執行的結果會帶入 fdv 變數中。
, 逗點 (comma)
這個符號常運用在運算當中當做”區隔”用途。如下例
#!/bin/bashlet “t1 = ((a = 5 + 3, b = 7 – 1, c = 15 / 3))”echo “t1 = $t1, a = $a, b = $b”
/ 斜線 (forward slash)
在路徑表示時,代表目錄。
cd /etc/rc.dcd ../..cd /
通常單一的 / 代表 root 根目錄的意思;在四則運算中,代表除法的符號。
let “num1 = ((a = 10 / 2, b = 25 / 5))”
\ 倒斜線 (escape)
在交互模式下的escape 字元,有幾個作用;放在指令前,有取消 aliases 的作用;放在特殊符號前,則該特殊符號的作用消失;放在指令的最末端,表示指令連接下一行。

type rm

rm is aliased to `rm -i'

\rm .*.log

上例,我在 rm 指令前加上 escape 字元,作用是暫時取消別名的功能,將 rm 指令還原。

bkdir=/home

echo “Backup dir, \$bkdir = $bkdir”

Backup dir, $bkdir = /home
上例 echo 內的 \$bkdir,escape 將 $ 變數的功能取消了,因此,會輸出 $bkdir,而第二個 $bkdir 則會輸出變數的內容 /home。
管道 (pipeline)
pipeline 是 UNIX 系統,基礎且重要的觀念。連結上個指令的標準輸出,做爲下個指令的標準輸入。
who
wc -l
善用這個觀念,對精簡 script 有相當的幫助。
! 驚歎號(negate or reverse)
通常它代表反邏輯的作用,譬如條件偵測中,用 != 來代表”不等於”
if [ "$?" != 0 ]thenecho “Executes error”exit 1fi
在規則表達式中她擔任 “反邏輯” 的角色
ls a[!0-9]
上例,代表顯示除了a0, a1 …. a9 這幾個文件的其他文件。
: 冒號
在 bash 中,這是一個內建指令:”什麼事都不幹”,但返回狀態值 0。

echo $? # 迴應爲 0
: > f.
上面這一行,相當於cat/dev/null>f.
上面這一行,相當於cat/dev/null>f.
。不僅寫法簡短了,而且執行效率也好上許多。
有時,也會出現以下這類的用法
: ${HOSTNAME?} ${USER?} ${MAIL?}
這行的作用是,檢查這些環境變數是否已設置,沒有設置的將會以標準錯誤顯示錯誤訊息。像這種檢查如果使用類似 test 或 if 這類的做法,基本上也可以處理,但都比不上上例的簡潔與效率。
除了上述之外,還有一個地方必須使用冒號
PATH=$PATH:$HOME/fbin:$HOME/fperl:/usr/local/mozilla
在使用者自己的HOME 目錄下的 .bash_profile 或任何功能相似的檔案中,設定關於”路徑”的場合中,我們都使用冒號,來做區隔。
? 問號 (wild card)
在文件名擴展(Filename expansion)上扮演的角色是匹配一個任意的字元,但不包含 null 字元。

ls a?a1

善用她的特點,可以做比較精確的檔名匹配。

  • 星號 (wild card)
    相當常用的符號。在文件名擴展(Filename expansion)上,她用來代表任何字元,包含 null 字元。

    ls a*a a1 access_log

    在運算時,它則代表 “乘法”。
    let “fmult=23″
    除了內建指令 let,還有一個關於運算的指令 expr,星號在這裏也擔任”乘法”的角色。不過在使用上得小心,他的前面必須加上escape 字元。
    次方運算
    兩個星號在運算時代表 “次方” 的意思。
    let “sus=2
    3″echo “sus = $sus” # sus = 8
    $ 錢號(dollar sign)
    變量替換(Variable Substitution)的代表符號。
    vrs=123echo “vrs = $vrs” # vrs = 123
    另外,在 Regular Expressions 裏被定義爲 “行” 的最末端 (end-of-line)。這個常用在 grep、sed、awk 以及 vim(vi) 當中。
    ${} 變量的正規表達式
    bash 對 ${} 定義了不少用法。以下是取自線上說明的表列
    ${parameter:-word} ${parameter:=word} ${parameter:?word} ${parameter:+word} ${parameter:offset} ${parameter:offset:length} ${!prefix
    } ${#parameter} ${parameter#word} ${parameter##word} ${parameter%word} ${parameter%%word} ${parameter/pattern/string} ${parameter//pattern/string}

$引用script 的執行引用變量,引用參數的算法與一般指令相同,指令本身爲0,其後爲1,然後依此類推。引用變量的代表方式如下:
$0, $1, $2, $3, $4, $5, $6, $7, $8, $9, ${10}, ${11}…..
個位數的,可直接使用數字,但兩位數以上,則必須使用 {} 符號來括住。
$
則是代表所有引用變量的符號。使用時,得視情況加上雙引號。
echo “$
還有一個與 $
具有相同作用的符號,但效用與處理方式略爲不同的符號。

$@
$@ 與 $ 具有相同作用的符號,不過她們兩者有一個不同點。
符號 $
將所有的引用變量視爲一個整體。但符號 $@ 則仍舊保留每個引用變量的區段觀念。
$#
這也是與引用變量相關的符號,她的作用是告訴你,引用變量的總數量是多少。
echo “$#”
$? 狀態值 (status variable)
一般來說,UNIX(linux) 系統的進程以執行系統調用exit() 來結束的。這個回傳值就是status值。回傳給父進程,用來檢查子進程的執行狀態。
一般指令程序倘若執行成功,其回傳值爲 0;失敗爲 1。
tar cvfz dfbackup.tar.gz /home/user > /dev/nullecho “$?”
由於進程的ID是唯一的,所以在同一個時間,不可能有重複性的PID。有時,script會需要產生臨時文件,用來存放必要的資料。而此script亦有可能在同一時間被使用者們使用。在這
種情況下,固定文件名在寫法上就顯的不可靠。唯有產生動態文件名,才能符合需要。符號
由於進程的ID是唯一的,所以在同一個時間,不可能有重複性的PID。有時,script會需要產生臨時文件,用來存放必要的資料。而此script亦有可能在同一時間被使用者們使用。在這種情況下,固定文件名在寫法上就顯的不可靠。唯有產生動態文件名,才能符合需要。符號
或許可以符合這種需求。它代表當前shell 的 PID。
echo “$HOSTNAME, $USER, $MAIL” > ftmp.$$
使用它來作爲文件名的一部份,可以避免在同一時間,產生相同文件名的覆蓋現象。
ps: 基本上,系統會回收執行完畢的 PID,然後再次依需要分配使用。所以 script 即使臨時文件是使用動態檔名的寫法,如果 script 執行完畢後仍不加以清除,會產生其他問題。
() 指令羣組 (command group)
用括號將一串連續指令括起來,這種用法對 shell 來說,稱爲指令羣組。如下面的例子:(cd ~ ; vcgh=pwd ; echo $vcgh),指令羣組有一個特性,shell會以產生 subshell 來執行這組指令。因此,在其中所定義的變數,僅作用於指令羣組本身。我們來看個例子

cat ftmp-01#!/bin/basha=fsh(a=incg ; echo -e “/n $a /n”)echo $a# ./ftmp-01incgfsh

除了上述的指令羣組,括號也用在 array 變數的定義上;另外也應用在其他可能需要加上escape 字元才能使用的場合,如運算式。
(())
這組符號的作用與 let 指令相似,用在算數運算上,是 bash 的內建功能。所以,在執行效率上會比使用 let 指令要好許多。
#!/bin/bash(( a = 10 ))echo -e “inital value, a = $a/n”(( a++ ))echo “after a++, a = $a”

{} 大括號 (Block of code)
有時候 script 當中會出現,大括號中會夾着一段或幾段以”分號”做結尾的指令或變數設定。

cat ftmp-02#!/bin/basha=fsh{a=inbc ; echo -e “/n $a /n”}echo $a# ./ftmp-02inbcinbc

這種用法與上面介紹的指令羣組非常相似,但有個不同點,它在當前的 shell 執行,不會產生 subshell。
大括號也被運用在 “函數” 的功能上。廣義地說,單純只使用大括號時,作用就像是個沒有指定名稱的函數一般。因此,這樣寫 script 也是相當好的一件事。尤其對輸出輸入的重導向上,這個做法可精簡 script 的複雜度。
此外,大括號還有另一種用法,如下
{xx,yy,zz,…}
這種大括號的組合,常用在字串的組合上,來看個例子
mkdir {userA,userB,userC}-{home,bin,data}
我們得到 userA-home, userA-bin, userA-data, userB-home, userB-bin, userB-data, userC-home, userC-bin, userC-data,這幾個目錄。這組符號在適用性上相當廣泛。能加以善用的話,回報是精簡與效率。像下面的例子
chown root /usr/{ucb/{ex,edit},lib/{ex?.?*,how_ex}}
如果不是因爲支援這種用法,我們得寫幾行重複幾次呀!
[] 中括號
常出現在流程控制中,扮演括住判斷式的作用。if [ "$?" != 0 ]thenecho “Executes error”exit 1fi
這個符號在正則表達式中擔任類似 “範圍” 或 “集合” 的角色
rm -r 200[1234]
上例,代表刪除 2001, 2002, 2003, 2004 等目錄的意思。
[[]]
這組符號與先前的 [] 符號,基本上作用相同,但她允許在其中直接使用 || 與 && 邏輯等符號。
#!/bin/bashread akif [[ $ak > 5 || $ak < 9 ]]thenecho $akfi || 邏輯符號 這個會時常看到,代表 or 邏輯的符號。 && 邏輯符號 這個也會常看到,代表 and 邏輯的符號。 & 後臺工作 單一個& 符號,且放在完整指令列的最後端,即表示將該指令列放入後臺中工作。 tar cvfz data.tar.gz data > /dev/null &
/ 單字邊界
這組符號在規則表達式中,被定義爲”邊界”的意思。譬如,當我們想找尋 the 這個單字時,如果我們用
grep the FileA
你將會發現,像 there 這類的單字,也會被當成是匹配的單字。因爲 the 正巧是 there 的一部份。如果我們要必免這種情況,就得加上 “邊界” 的符號
grep ‘/' FileA

  • 加號 (plus)
    在運算式中,她用來表示 “加法”。
    expr 1 + 2 + 3
    此外在規則表達式中,用來表示”很多個”的前面字元的意思。

    grep '10/+9′ fileB109100910000910000931010009#這個符號在使用時,前面必須加上 escape 字元。

  • 減號 (dash)
    在運算式中,她用來表示 “減法”。
    expr 10 – 2
    此外也是系統指令的選項符號。
    ls -expr 10 – 2
    在 GNU 指令中,如果單獨使用 – 符號,不加任何該加的文件名稱時,代表”標準輸入”的意思。這是 GNU 指令的共通選項。譬如下例
    tar xpvf -
    這裏的 – 符號,既代表從標準輸入讀取資料。
    不過,在 cd 指令中則比較特別
    cd -
    這代表變更工作目錄到”上一次”工作目錄。
    % 除法 (Modulo)
    在運算式中,用來表示 “除法”。
    expr 10 % 2
    此外,也被運用在關於變量的規則表達式當中的下列
    ${parameter%word}${parameter%%word}
    一個 % 表示最短的 word 匹配,兩個表示最長的 word 匹配。
    = 等號 (Equals)
    常在設定變數時看到的符號。
    vara=123echo ” vara = $vara”
    或者像是 PATH 的設定,甚至應用在運算或判斷式等此類用途上。
    == 等號 (Equals)
    常在條件判斷式中看到,代表 “等於” 的意思。
    if [ $vara == $varb ]
    …下略
    != 不等於
    常在條件判斷式中看到,代表 “不等於” 的意思。
    if [ $vara != $varb ]
    …下略

如何輸出顏色
http://www.cnblogs.com/lr-ting/archive/2013/02/28/2936792.html

source exec 區別http://alsww.blog.51cto.com/2001924/1113112

簡易審計系統
1.mkdir -p /usr/local/records/
2.chmod 777 /usr/local/records/
3.chmod o+t /usr/local/records/
4.vi /etc/profile 在最後一行添加代碼
5.if [ ! -d /usr/local/records/${LOGNAME} ]
6.then
7.mkdir -p /usr/local/records/${LOGNAME}
8.chmod 300 /usr/local/records/${LOGNAME}
9.fi
10.export HISTORY_FILE="/usr/local/records/${LOGNAME}/。history"
11.export PROMPT_COMMAND='{date "+%Y-%m-%d %T #### $(who am i|awk "{print \$1\" \"\$2\" \"\$5}")#### $(history 1 |{read x cmd;echo "$cmd";})"; } >>$HISTORY_FILE'

20180601

//1.sh
[root@lanquark ~]# cat 1.sh
#!/bin/bash

A=B
echo "PID for 1.sh before exec/source/fork is:$$"
export A
echo "1.sh:\$A is $A"
case $1 in
exec)
echo "using exec..."
exec ./2.sh;;
source)
echo "using source..."
. ./2.sh;;
*)
echo "using fork by default..."
./2.sh;;
esac
echo "1.sh:\$A is $A"

//2.sh
[root@lanquark ~]# cat 2.sh
#!/bin/bash

echo "PID for 2.sh is:$$"
echo "2.sh get \$A=$A from 1.sh"
export A=C
echo "2.sh:\$A is $A"

//在1.sh中以fork方式執行2.sh
[root@lanquark ~]# ./1.sh fork
PID for 1.sh before exec/source/fork is:27181
1.sh:$A is B
using fork by default...
//說明2.sh不是在1.sh同一個shell中執行,進程id不相同
PID for 2.sh is:27182
//子shell繼承父shell的環境,所以$A=B
2.sh get $A=B from 1.sh
//子shell中修改A的值
2.sh:$A is C
//子shell環境變量改變不影響父shell
1.sh:$A is B

//在1.sh以exec方式執行2.sh
[root@lanquark ~]# ./1.sh exec
PID for 1.sh before exec/source/fork is:27495
1.sh:$A is B
using exec...
//和父進程的進程ID相同,說明沒有產生子shell
PID for 2.sh is:27495
2.sh get $A=B from 1.sh
2.sh:$A is C
//2.sh執行完以後沒有回退到1.sh。並且1.sh中的最後一條語句沒有執行

//在1.sh以source執行2.sh
[root@lanquark ~]# ./1.sh source
PID for 1.sh before exec/source/fork is:27670
1.sh:$A is B
using source...
//和父進程的進程ID相同,說明沒有產生子shell
PID for 2.sh is:27670
2.sh get $A=B from 1.sh
//在子進程中修改了A的值
2.sh:$A is C
//子進程中的修改反映到了父進程中
1.sh:$A is C

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章