數值測試:
-gt 是否大于
-ge 是否大于等于
-eq 是否等于
-ne 是否不等于
-lt 是否小于
-le 是否小于等于
unset 變量(刪除腳本中臨時用到的變量,較好的習慣)
在腳本中,使用{}將多條命令同時運行時,腳本最后需加wait,以結束等待回車環節,否則需手動回車
eval 是先掃描后續內容并替換變量,然后在使用,可解決echo {1..$n} 不打印數列的問題
條件選擇語句if:
if 判斷條件1; then
條件為真的分支代碼
elif 判斷條件2; then
條件為真的分支代碼
elif 判斷條件3; then
條件為真的分支代碼
else
以上條件都為假的分支代碼
fi
條件判斷語句case:
case 變量引用 in (注意:變量引用是用$加變量名)
PAT1)
分支1
;;
PAT2)
分支2
;;
…
*)
默認分支
;;
esac
case支持通配符寫法
循環語句:
for:
for 變量名 in 列表;do
循環體
done
for的另一種c語言格式運用:
for ((控制變量初始化;條件判斷表達式;控制變量的修正表達式));do
循環體
done
while:
while CONDITION; do
循環體
done
命令為真時,開始循環體,直到命令為假
CONDITION:循環控制條件;進入循環之前,先做一次判斷;每一次循環之后會再次做判斷;條件為“true”,則執行一次循環;直到條件測試狀態為“false”終止循環
until:
until CONDITION; do
循環體
done
命令為假時,才開始循環體,直到命令為真
shift:
將參數列表左移一個,后面接數字表示每次左移*個參數
while循環的特殊用法(遍歷文件的每一行):
while read line; do
循環體
done < /PATH/FROM/SOMEFILE
依次讀取/PATH/FROM/SOMEFILE文件中的每一行,且將行賦值給變量line
select:制作列表工具,一般搭配case形成可選列表
select 變量名 in list
do
循環體命令
done
trap:信號捕捉工具
trap ‘觸發指令’ 信號
自定義信號所代表的的命令,當接受指定的信號時,執行前面的自定義指令
trap ‘-‘ 信號:恢復原信號的操作
trap -p:打印自定義信號操作內容
函數function是由若干條shell命令組成的語句塊,實現代碼重用和模塊化編程
語法一:
f_name (){
…函數體…
}
語法二:
function f_name {
…函數體…
}
語法三:
function f_name () {
…函數體…
}
一般只用第一種格式即可
數組:
數組名和索引
索引:編號從0開始,屬于數值索引
關聯索引:索引可支持使用自定義的格式,而不僅是數值格式,bash4.0版本之后開始支持
稀疏索引:不連續的索引,中間缺少元素
聲明數組:
declare -a ARRAY_NAME 普通數組,可以不聲明即可使用
declare -A ARRAY_NAME: 關聯數組,必須先聲明,后使用
注意:兩者不可相互轉換
數組元素的賦值
(1) 一次只賦值一個元素
ARRAY_NAME[INDEX]=VALUE
weekdays[0]=”Sunday”
weekdays[4]=”Thursday”
(2) 一次賦值全部元素
ARRAY_NAME=(“VAL1” “VAL2” “VAL3″ …)
(3) 只賦值特定元素
ARRAY_NAME=([0]=”VAL1″ [3]=”VAL2” …)
(4) 對交互式數組值對賦值
read -a ARRAY
u顯示所有數組:declare -a
引用數組元素:
${ARRAY_NAME[INDEX]}
注意:省略[INDEX]表示引用下標為0的元素
引用數組所有元素:
${ARRAY_NAME[*]}
${ARRAY_NAME[@]}
數組的長度(數組中元素的個數):
${#ARRAY_NAME[*]}
${#ARRAY_NAME[@]}
刪除數組中的某元素:導致稀疏格式
unset ARRAY[INDEX]
刪除整個數組:
unset ARRAY
向數組中追加元素:
ARRAY[${#ARRAY[*]}]=value
${#var}:返回字符串變量var的長度
${var:n}:返回字符串變量var中從第n個字符后的字符開始,到最后(簡稱偏移量)
${var:n:m} :跳過n個取接下來的m個字符
${var: -n}:取倒數n個字符(-n前面有一個空格)
${var:n:-m}:去掉前n個,去掉后m個,剩下的
${var: -n:-m}:先取后n個 ,再從結果中取后m個(-n前面有空格)(centos6不支持)
${var#*word}:其中word可以是指定的任意字符,var變量是儲存字符串變量,這句的功能是當第一次發現關鍵字時,刪除前面的,包括關鍵字,然后留下后面的(懶惰模式)
${var##*word}:同上,但是出于貪婪模式的搜索關鍵字
${var%word*}:邏輯同上,但是是從后向前開始搜索,并且刪除關鍵字之后的字符串
${var%%word*}:邏輯同上,貪婪模式
查找替換
${var/pattern/substr}:查找var所表示的字符串中,第一次被pattern所匹配到的字符串,以substr替換之
${var//pattern/substr}: 查找var所表示的字符串中,所有能被pattern所匹配到的字符串,以substr替換之
${var/#pattern/substr}:查找var所表示的字符串中,行首被pattern所匹配到的字符串,以substr替換之
${var/%pattern/substr}:查找var所表示的字符串中,行尾被pattern所匹配到的字符串,以substr替換之
查找并刪除
${var/pattern}:刪除var所表示的字符串中第一次被pattern所匹配到的字符串
${var//pattern}:刪除var所表示的字符串中所有被pattern所匹配到的字符串
${var/#pattern}:刪除var所表示的字符串中所有以pattern為行首所匹配到的字符串
${var/%pattern}:刪除var所表示的字符串中所有以pattern為行尾所匹配到的字符串
字符大小寫轉換
${var^^}:把var中的所有小寫字母轉換為大寫
${var,,}:把var中的所有大寫字母轉換為小寫(倆逗號)
變量賦值:
declare [選項] 變量名
-r 聲明或顯示只讀變量
-i 將變量定義為整型數
-a 將變量定義為數組
-A 將變量定義為關聯數組
-f 顯示已定義的所有函數名及其內容
-F 僅顯示已定義的所有函數名
-x 聲明或顯示環境變量和函數
-l 聲明變量為小寫字母 declare –l var=UPPER
-u 聲明變量為大寫字母 declare –u var=lower
間接變量引用
bash Shell提供了兩種格式實現間接變量引用,從而顯示var1所表示的真實變量內容
eval tempvar=\$$variable1
tempvar=${!variable1}
創建臨時文件:
mktemp [OPTION]… [TEMPLATE]
TEMPLATE: filenameXXX
X至少要出現三個
OPTION:
-d: 創建臨時目錄
-p DIR或–tmpdir=DIR:指明臨時文件所存放目錄位置
install命令:
選項:
-m MODE,默認755
-o OWNER
-g GROUP
示例:
install -m 700 -o wang -g admins source directory
install –m 770 –d /testdir/installdir (創建文件夾)
expect命令/語言(使用前確保已安裝)
選項
?-c:從命令行執行expect腳本,默認expect是交互地執行的
示例:expect -c ‘expect “\n” {send “pressed enter\n”}
?-d:可以輸出輸出調試信息
示例:expect -d ssh.exp
uexpect中相關命令
?spawn:啟動新的進程
?send:用于向進程發送字符串
?expect:從進程接收字符串
?interact:允許用戶交互
?exp_continue 匹配多個字符串在執行動作后加此命令
示例:實現scp中使用expect實現自動化
示例:在自動化的同時實現繼續使用交互式操作,而非自動退出
示例:實現變量引用手動輸入,并相似$1、$2….
bash –version 查看bash版本號
函數優先級大于別名
declare -f 查看所有被定義的函數
export -f 或declare -xf 查看所有全局變量
unset f_name 刪除定義的某函數
return 在函數中使用,可中途退出函數,但不會退出腳本
kill -l 查看所有信號所代表的的原本命令(trap -l)
continue 停止執行當前循環(后面可接數字表示提前結束該層)
break 停止執行循環體(可接數字,同上)
bash -x test_continue.sh 跟蹤后面的腳本,查看后臺執行的步驟
true或:都可以使得echo $?為0;fault則默認為1
函數內部定義變量時,是同父進程同級的關系,要想只在函數內生效,只需在定義前加local即可:fun () { local name=mage;echo “$name”?}
export name全局變量,影響當前shell環境并可傳給子shell,不加export是局部變量,只影響當前shell,local name則只影響函數內的shell環境,影響最?。ê瘮祪炔坑胐eclare -i等同于local)declare -ig 其中g則會把其定義變為局部變量
export -f function1可以把該定于函數變成全局變量的命令
修改ssh的配置文件:/etc/ssh/sshd_config 中的若有#usedns no,則把#刪除即可
本文來自投稿,不代表Linux運維部落立場,如若轉載,請注明出處:http://www.www58058.com/98404