一、函數調用
1.while循環的特殊用法(遍歷文件的每一行):
while read line; do
循環體
done < /PATH/FROM/SOMEFILE
依次讀取/PATH/FROM/SOMEFILE文件中的每一行,且將行賦值給變量line
示例:
掃描/etc/passwd文件每一行,如發現GECOS字段為空,則填充用戶名和單位電話為62985600,并提示該用戶的GECOS信息修改成功。
#!/bin/bash # while read line ; do var=`echo $line | cut -d ":" -f 5` user=`echo $line | cut -d ":" -f 1` [[ -z "${var}" ]] && chfn -f ${user} -p 62985600 ${user} ;echo "${user}'s information change successful" done < /etc/passwd
2.for循環的特殊用法
雙小括號方法,即((…))格式,也可以用于算術運算
雙小括號方法也可以使bash Shell實現C語言風格的變量操作
for循環的特殊格式:
for ((控制變量初始化;條件判斷表達式;控制變量的修正表達式)) ;do
循環體
done
控制變量初始化:僅在運行到循環代碼段時執行一次
控制變量的修正表達式:每輪循環結束會先進行控制變量修正運算,而后再做條件判斷
示例:
打印正序九九乘法表
#!/bin/bash for ((j=1;j<=9;j++)) ; do for ((i=1;i<=j;i++)) ; do echo -ne "$iX$j=$[i*j]\t" done echo done
3.select 循環與菜單
select variable in list ;do
循環體命令
done
主要用于創建菜單,按數字順序排列的菜單項將顯示在標準錯誤上,并顯示PS3 提示符,等待用戶輸入
用戶輸入菜單列表中的某個數字,執行相應的命令
用戶輸入被保存在內置變量REPLY 中。
select與case
select 是個無限循環,因此要記住用break 命令退出循環,或用exit 命令終止腳本。也可以按ctrl+c 退出循環。
select 經常和case 聯合使用
與for 循環類似,可以省略in list ,此時使用位置參量
4.函數介紹
函數function是由若干條shell命令組成的語句塊,實現代碼重用和模塊化編程。
它與shell程序形式上是相似的,不同的是它不是一個單獨的進程,不能獨立運行,而是shell程序的一部分。
函數和shell程序比較相似,區別在于:
Shell程序在子Shell中運行
而Shell函數在當前Shell中運行。因此在當前Shell中,函數可以對shell中變量進行修改
(1).函數定義
函數由兩部分組成:函數名和函數體。
語法一:
function f_name {
…函數體…
}
語法二:
function f_name(){
…函數體…
}
語法三:
f_name(){
…函數體…
}
(2).函數使用
函數的定義和使用:
可在交互式環境下定義函數
可將函數放在腳本文件中作為它的一部分
可放在只包含函數的單獨文件中
調用:函數只有被調用才會執行;
調用:給定函數名
函數名出現的地方,會被自動替換為函數代碼
函數的生命周期:被調用時創建,返回時終止
函數返回值
函數有兩種返回值:
函數的執行結果返回值:
(1) 使用echo或printf命令進行輸出
(2) 函數體中調用命令的輸出結果
?
函數的退出狀態碼:
(1) 默認取決于函數中執行的最后一條命令的退出狀態碼
(2) 自定義退出狀態碼,其格式為:
return 從函數中返回,用最后狀態命令決定返回值
return 0 無錯誤返回。
return 1-255 有錯誤返回
示例:
dir () {
ls -l $1
}
定義該函數后,若在$后面鍵入dir,其顯示結果同ls-l的作用相同。
該dir函數將一直保留到用戶從系統退出,或執行了如下所示的unset命令:unset dir
(3).在腳本中定義及使用函數
函數在使用前必須定義,因此應將函數定義放在腳本開始部分,直至shell首次發現它后才能使用
調用函數僅使用其函數名即可。
示例:
#!/bin/bash # func1 hello () { echo "Hello there today's date is `date +%F`" } echo "now going to the function hello" hello echo "back from the function"
使用函數文件
可以將經常使用的函數存入函數文件,然后將函數文件載入shell。
文件名可任意選取,但最好與相關任務有某種聯系。例如:functions.main
一旦函數文件載入shell,就可以在命令行或腳本中調用函數??梢允褂胹et命令查看所有定義的函數,其輸出列表包括已經載入shell的所有函數。
若要改動函數,首先用unset命令從shell中刪除函數。改動完畢后,再重新載入此文件。
創建函數文件示例:
#!/bin/bash #functions.main findit () { if [ $# -lt 1 ] ; then echo "Usage:findit file" return 1 fi find / -name $1 –print }
(4).載入函數
函數文件已創建好后,要將它載入shell
定位函數文件并載入shell的格式:
. filename 或source filename
注意:此即<點> <空格> <文件名>
這里的文件名要帶正確路徑
示例:上例中的函數,可使用如下命令:
. functions.main
檢查載入函數
使用set命令檢查函數是否已載入。set命令將在shell中顯示所有的載入函數。
示例:
set findit () { if [ $# -lt 1 ]; then echo "usage :findit file"; return 1 fi find / -name $1 -print }
執行shell函數
要執行函數,簡單地鍵入函數名即可:
?
刪除shell函數
現在對函數做一些改動。首先刪除函數,使其對shell不可用。使用unset命令完成此功能.
命令格式為:
unset function_name
函數參數
函數可以接受參數:
傳遞參數給函數:調用函數時,在函數名后面以空白分隔給定參數列表即可;例如“testfunc arg1 arg2 …”
在函數體中當中,可使用$1, $2, …調用這些參數;還可以使用$@, $*, $#等特殊變量
函數變量
變量作用域:
環境變量:當前shell和子shell有效
本地變量:只在當前shell進程有效,為執行腳本會啟動專用子shell進程;因此,本地變量的作用范圍是當前shell腳本程序文件,包括腳本中的函數。
局部變量:函數的生命周期;函數結束時變量被自動銷毀
注意:如果函數中有局部變量,如果其名稱同本地變量,使用局部變量。
在函數中定義局部變量的方法
local NAME=VALUE
函數的變量由函數名后的參數賦值
腳本的變量由腳本名后的參數賦值
當函數的參數為腳本的參數時兩者相等
示例
pritvar.sh #!/bin/bash fun () { echo $1 ; echo $2 } fun a b echo $1 $2
執行bash printvar.sh c d
結果為
函數的$1=a $2=b
腳本的$1=c $2=d
(5).函數遞歸實例
函數遞歸:
函數直接或間接調用自身
注意遞歸層數
遞歸實例:
階乘是基斯頓·卡曼于1808年發明的運算符號,是數學術語
一個正整數的階乘(factorial)是所有小于及等于該數的正整數的積,并且有0的階乘為1。自然數n的階乘寫作n!。
n!=1×2×3×…×n。
階乘亦可以遞歸方式定義:0!=1,n!=(n-1)!×n。
n!=n(n-1)(n-2)…1
n(n-1)! = n(n-1)(n-2)!
示例
#!/bin/bash # fact() { if [ $1 -eq 0 -o $1 -eq 1 ]; then echo 1 else echo $[$1*$(fact $[$1-1])] fi } fact $1
二、rpm程序包管理器
1.包查詢
rpm -q[p] {PACKAGE_FILE|PACKAGE_NAME|NAME}
對已安裝的程序:-q {PACKAGE_NAME|NAME}
-a: 查詢安裝的所有程序包
-c: 查詢程序的配置文件
-d: 查詢程序的幫助文檔
-f: 查看指定的文件由哪個程序包安裝生成
-i: 查詢程序的簡要說明信息
-l: 查看指定的程序包安裝后生成的所有文件;
-R|–requires: 查詢指定的程序包所依賴的CAPABILITY;
–scripts:程序包自帶的腳本片斷
–changelog:查詢rpm包的changelog
–provides: 列出指定程序包所提供的CAPABILITY
–whatprovides CAPABILITY:查詢指定的CAPABILITY由哪個包所提供
–whatrequires CAPABILITY:查詢指定的CAPABILITY被哪個包所依賴
對尚未安裝的程序:-qp {PACKAGE_FILE}
-c:
-d:
-i:
-l:
-R:
rpm2cpio 包文件 | cpio –itv 預覽包內文件
rpm2cpio 包文件 | cpio –id “*.conf”釋放包內文件
2.包卸載:
rpm -e {PACKAGE_NAME|NAME}
–test: 測試卸載,并不真正卸載
–nodeps: 忽略依賴關系
–almatches: 如果一個程序同時安裝多個版本,將其全部卸載
注意:如果程序包的配置文件安裝后曾被修改,卸載時,此文件同常不會刪除,而是被重命名(加.rpmsave后綴)后保存
3.程序文件完整性查詢
rpm -V {PACKAGE_NAME|NAME} 查詢包安裝之后生成的文件是否發生了改變
-a:查詢所有已安裝的程序
-f: 查詢指定的文件是否被更改過
-p:查詢指定的rpm包是否被更改過
沒有查詢結果表示生成的文件沒有改變
查詢結果
S file Size differs
M Mode differs (includes permissions and file type)
5 digest (formerly MD5 sum) differs
D Device major/minor number mismatch
L readLink(2) path mismatch
U User ownership differs
G Group ownership differs
T mTimediffers
P capabilities differ
4.包校驗
包來源合法性驗正及完整性驗正:
完整性驗正:SHA256
來源合法性驗正:RSA
公鑰加密:
對稱加密:加密、解密使用同一密鑰;
非對稱加密:密鑰是成對兒的
public key: 公鑰,公開所有人
secret key: 私鑰, 不能公開
導入所需要公鑰:rpm –import /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
檢查包的完整性和簽名rpm -K {PACKAGE_FILE}
rpm –import /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
公鑰文件由CentOS 7發行版光盤在安裝系統時復制到/etc//pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
rpm -qa gpg-pubkey* 查詢公鑰文件
rpm -e gpg-pubkey* 卸載公鑰文件
5.rpm數據庫
數據庫位置:/var/lib/rpm
rpm {–initdb|–rebuilddb}
initdb: 初始化;如果事先不存在數據庫,則新建之;否則,不執行任何操作
rebuilddb:重建,無論當前存在與否,直接重新創建數據庫
三、yum程序包管理器
CentOS: yum, dnf
YUM: YellowdogUpdate Modifier,rpm的前端程序,用來解決軟件包相關依賴性,可以在多個庫之間定位軟件包,up2date的替代工具
yum repository: yum repo,存儲了眾多rpm包,以及包的相關的元數據文件(放置于特定目錄repodata下)
文件服務器:
ftp://
http://
file:///
nfs://
1.yum配置文件
yum客戶端配置文件:
/etc/yum.conf:為所有倉庫提供公共配置
/etc/yum.repos.d/*.repo:為倉庫的指向提供配置
倉庫指向的定義:
[repositoryID]
name=Some name for this repository
baseurl=url://path/to/repository/
enabled={1|0} 默認為1,啟用
gpgcheck={1|0} 默認為1,啟用
gpgkey=URL 公鑰文件路徑
enablegroups={1|0} 默認為1,啟用
failovermethod={roundrobin|priority} 默認為:roundrobin,意為隨機挑選;
cost= 默認為1000 cost值越小,優先級越高
yum -config-manager –disable “倉庫名" :禁用倉庫
yum -config-manager –enable “倉庫名” :啟用倉庫
原創文章,作者:anonymous,如若轉載,請注明出處:http://www.www58058.com/38396
對當天所學的東西總結的很全面,對于腳本而言需要我們多寫,多看優秀代碼,yum源的配置是基本能力,同時rpm包管理器中查詢語句是我們能平常用挺多的,需要多加練習。