shell中IF的用法介紹
阿新 • • 發佈:2018-11-07
一、語法結構
if [ condition ]
then
statements
[elif condition
then statements. ..]
[else
statements ]
fi
二、說明
(1)[ condition ] (注意condition前後要有空格)
非空返回true,可使用$?驗證(0為true,>1為false) 如:[ hadoop ] 返回true
空返回false 如:[ ] 返回false
(2)[ condition ] && echo OK ||echo notok 可以多條件,條件滿足,執行後面的語句
三、整數比較
-eq 等於,如:if [ "$a" -eq "$b" ] -ne 不等於,如:if [ "$a" -ne "$b" ] -gt 大於,如:if [ "$a" -gt "$b" ] -ge 大於等於,如:if [ "$a" -ge "$b" ] -lt 小於,如:if [ "$a" -lt "$b" ] -le 小於等於,如:if [ "$a" -le "$b" ] 大於(需要雙括號),如:(("$a" > "$b")) >= 大於等於(需要雙括號),如:(("$a" >= "$b")) 小資料比較可使用AWK #下一篇單獨介紹awk資料處理
四、字串比較
= 等於,如:if [ "$a" = "$b" ] == 等於,如:if [ "$a" == "$b" ],與=等價 != 不等於,如:if [ "$a" != "$b" ] 這個操作符將在[[]]結構中使用模式匹配. 大於,在ASCII字母順序下.如: if [[ "$a" > "$b" ]] if [ "$a" \> "$b" ] 注意:在[]結構中">"需要被轉義. -z 字串為"null".就是長度為0. -n 字串不為"null"
五、許可權判斷
-r 有讀的許可權
-w 有寫的許可權
-x 有執行的許可權
六、檔案系統型別判斷
-f 檔案存在並且是一個常規的檔案
-s 檔案存在且不為空
-d 檔案存在並是一個目錄
-b 檔案存在並且是一個塊裝置
-L 檔案存在並且是一個軟連線
例項1 特權使用者的高記憶體佔用查詢
#!/bin/bash
if [ root == `awk -F: '$3==0{print $1}' /etc/passwd ` ];then #>字元判斷
echo "Privileged user is root" #>判斷特權使用者是否只有root
echo "===================================/n======/n="
else
echo "Privileged users are not root"
exit 1
fi
ps aux > 123.txt
if [ $? == 0 ] ;then
echo "High memory occupancy analysis"
echo "===================================/n======/n="
awk '$4>="0.3"{print $1,$11}' 123.txt #>這個$4的點自定義,這裡虛擬機器沒吃記憶體厲害應用
echo "---------------------end----------------"
exit 1
fi
案例2 遠端登入的使用者的詳情查詢
[[email protected] 桌面]# cat 123.sh
#!/bin/bash
lsof -i :ssh |grep -v sshd > 123.txt
if [ $? -eq 0 ];then
echo "Display of users without remote login "
cat 123.txt
exit 1
else
echo "Users without remote login"
fi