腳本函數與程序包管理

一、函數調用

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}

14 46 56 --.png

-a: 查詢安裝的所有程序包

14 48 01 --.png

-c: 查詢程序的配置文件

14 48 47 --.png

-d: 查詢程序的幫助文檔

14 49 11 --.png

-f: 查看指定的文件由哪個程序包安裝生成

14 50 55 --.png

-i: 查詢程序的簡要說明信息

14 51 49 --.png

-l: 查看指定的程序包安裝后生成的所有文件;

14 50 45 --.png

-R|–requires: 查詢指定的程序包所依賴的CAPABILITY;

14 52 13 --.png

–scripts:程序包自帶的腳本片斷

14 53 18 --.png

–changelog:查詢rpm包的changelog

14 54 04 --.png

–provides: 列出指定程序包所提供的CAPABILITY

14 54 44 --.png

–whatprovides CAPABILITY:查詢指定的CAPABILITY由哪個包所提供

–whatrequires CAPABILITY:查詢指定的CAPABILITY被哪個包所依賴

對尚未安裝的程序:-qp  {PACKAGE_FILE}
-c:
-d:
-i:
-l:
-R:

rpm2cpio 包文件 | cpio –itv 預覽包內文件

14 59 27 --.png

rpm2cpio 包文件 | cpio –id “*.conf”釋放包內文件

2.包卸載:
rpm -e {PACKAGE_NAME|NAME}

–test: 測試卸載,并不真正卸載

15 01 29 --.png

–nodeps: 忽略依賴關系
–almatches: 如果一個程序同時安裝多個版本,將其全部卸載

注意:如果程序包的配置文件安裝后曾被修改,卸載時,此文件同常不會刪除,而是被重命名(加.rpmsave后綴)后保存

3.程序文件完整性查詢

rpm -V {PACKAGE_NAME|NAME} 查詢包安裝之后生成的文件是否發生了改變

15 14 50 --.png

-a:查詢所有已安裝的程序

15 09 42 --.png

-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*  卸載公鑰文件

15 18 44 --.png

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

(0)
anonymousanonymous
上一篇 2016-08-21 20:46
下一篇 2016-08-21 20:46

相關推薦

  • iptables

    iptables簡介 netfilter/iptables(簡稱為iptables)組成Linux平臺下的包過濾防火墻,與大多數的Linux軟件一樣,這個包過濾防火墻是免費的,它可以代替昂貴的商業防火墻解決方案,完成封包過濾、封包重定向和網絡地址轉換(NAT)等功能。 iptables基礎 規則(rules)其實就是網絡管理員預定義的條件,規則一般的定義為“…

    2017-05-02
  • 馬哥教育網絡班19期第一周課程練習

    1、描述計算機的組成及其功能。 從大體上計算機是由cpu、內存、主板、I/O設備、存儲設備組成 cpu的功能就好像人的大腦,控制身體的。嚴格意義上是用來解釋計算機指令以及處理軟件中的數據的。 內存的功能就好像人的大腦記憶區、來存放眼睛看到的世界。嚴格意義上是用于暫時存放cpu中的運算數據,以及與硬盤等外部存儲器交換的數據 主板的功能就好像人的身體,來鏈接身體…

    Linux干貨 2016-06-18
  • 運維工程師技能需求排行

    這是我今天在拉勾網搜索運維,翻完了4四頁也招聘信息之后得到的,我的目的是想要看看之后的學習,哪個更應該成為重點,有些在我意料之中,有些還真的沒想到,算是努力了一個小時的收獲吧,分享給大家。
    注意:其中的看法僅代表個人觀點,很多都是依靠我自己的學習經驗和工作經驗累積的

    Linux干貨 2017-12-12
  • 13 文件查找與壓縮

    locate find 壓縮命令 file-roller、compress/uncompress(.Z)、gzip/gunzip(.gz)、bzip2/bunzip2(.bz2)、xz/unxz(.xz) zip/unzip、tar locate 數據源 1)查詢系統上預建的文件索引數據庫      2)依賴于事先構建…

    Linux干貨 2016-08-18
  • 8月3日課堂練習及課后作業

    課堂練習 1、創建用戶gentoo,附加組為bin和root,默認shell為/bin/csh,注釋信息為“Gentoo Distribution” useradd -G bin,root -s /bin/csh -c "Gentoo Distribution" gentoo  2、創建下面的用戶、組和組成員關系,名字為admi…

    Linux干貨 2016-08-04
  • 作業管理

    作業管理 ·Linux的作業控制:          前臺作業:通過終端啟動,且啟動后一直占據終端;          后臺作業:可通過終端啟動,但啟動后即轉入后臺運行(釋放終端) ·如何讓作業運行于…

    Linux干貨 2016-09-11

評論列表(1條)

  • 馬哥教育
    馬哥教育 2016-08-21 20:59

    對當天所學的東西總結的很全面,對于腳本而言需要我們多寫,多看優秀代碼,yum源的配置是基本能力,同時rpm包管理器中查詢語句是我們能平常用挺多的,需要多加練習。

欧美性久久久久