shell 腳本之數組 和 yum 【下】

shell 腳本之數組 和 yum 【下】

數組

變量:存儲單個元素的內存空間 ? 

數組:存儲多個元素的連續的內存空間,相當于多個變量的 集合。 ? 

數組名和索引 

      索引:編號從0開始,屬于數值索引 

      注意:索引可支持使用自定義的格式,而不僅是數值格式 ,即為關聯索引,bash4.0版本之后開始支持。 bash的數組支持稀疏格式(索引不連續) ? 

      聲明數組: 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

引用數組

? 引用數組元素:${ARRAY_NAME[INDEX]} 

注意:省略[INDEX]表示引用下標為0的元素 ? 

數組的長度(數組中元素的個數): 

${#ARRAY_NAME[*]} 

${#ARRAY_NAME[@]} ? 

示例:生成10個隨機數保存于數組中,并找出其最大值和最小值 

#!/bin/bash 

declare -a rand 

declare -i max=0 

declare –i min=32767 

for i in {0..9}; do 

    rand[$i]=$RANDOM 

    echo ${rand[$i]} 

    [ ${rand[$i]} -gt $max ] && max=${rand[$i]} 

    [ ${rand[$i]} -lt $min ] && min=${rand[$i]} 

done 

echo "Max: $max  Min:$min"

編寫腳本,定義一個數組,數組中的元素是/var/log目錄下所有以 .log結尾的文件;要統計其下標為偶數的文件中的行數之和 

#!/bin/bash 

# declare -a files 

files=(/var/log/*.log) 

declare -i lines=0 

for i in $(seq 0 $[${#files[*]}-1]); do 

if [ $[$i%2] -eq 0 ];then 

    let lines+=$(wc -l ${files[$i]} | cut -d' ' -f1) 

fi 

done 

    echo "Lines: $lines."

數組數據處理

? 引用數組中的元素: 

所有元素:

    ${ARRAY[@]}, ${ARRAY[*]} 

數組切片:

    ${ARRAY[@]:offset:number} 

offset: 

    要跳過的元素個數 

number: 

    要取出的元素個數 

取偏移量之后的所有元素 

    ${ARRAY[@]:offset} ? 

向數組中追加元素: 

    ARRAY[${#ARRAY[*]}] ? 

刪除數組中的某元素:導致稀疏格式 

    unset ARRAY[INDEX] ? 

關聯數組: 

    declare -A ARRAY_NAME 

注意:必須先聲明,再調用 ARRAY_NAME=([idx_name1]='val1' [idx_name2]='val2‘…)

字符串處理

?bash的字符串處理工具: ? 

字符串切片: 

${#var}:

    返回字符串變量var的長度 

${var:offset}:

    返回字符串變量var中從第offset個字符后 (不包括第offset個字符)的字符開始,到最后的部分,offset 的取值在0 到 ${#var}-1 之間(bash4.2后,允許為負值) 

${var:offset:number}:

    返回字符串變量var中從第 offset個字符后(不包括第offset個字符)的字符開始,長度為 number的部分 

${var: -lengh}:

    取字符串的最右側幾個字符 

    注意:冒號后必須有一空白字符 

${var:offset: -lengh}:

    從最左側跳過offset字符,一直 取到字符串的最右側lengh個字符之前

基于模式取子串: 

${var#*word}:其中word可以是指定的任意字符 

    功能:自左而右,查找var變量所存儲的字符串中,第一 次出現的word, 刪除字符串開頭至第一次出現word字符之間的 所有字符 

${var##*word}:同上,不同的是,刪除的是字符串開 頭至最后一次由word指定的字符之間的所有內容 ? 

示例: 

    file="var/log/messages“ 

    ${file#*/}: log/messages 

    ${file##*/}: messages

${var%word*}:其中word可以是指定的任意字符; 

    功能:自右而左,查找var變量所存儲的字符串中,第一 次出現的word, 刪除字符串最后一個字符向左至第一次出現 word字符之間的所有字符; 

示例 file="/var/log/messages" 

    ${file%/*}: /var/log 

${var%%word*}:同上,只不過刪除字符串最右側的字符向 左至最后一次出現word字符之間的所有字符; ? 

示例: url=http://www.magedu.com:80 

    ${url##*:} 80 

    ${url%%:*} http

查找替換: 

    ${var/pattern/substi}:查找var所表示的字符串中,第 一次被pattern所匹配到的字符串,以substi替換之 

    ${var//pattern/substi}: 查找var所表示的字符串中, 所有能被pattern所匹配到的字符串,以substi替換之 ${var/#pattern/substi}:查找var所表示的字符串中, 行首被pattern所匹配到的字符串,以substi替換之 ${var/%pattern/substi}:查找var所表示的字符串中, 行尾被pattern所匹配到的字符串,以substi替換之

 查找并刪除: 

 ${var/pattern}:查找var所表示的字符串中,刪除第一 次被pattern所匹配到的字符串 

     ${var//pattern}:所有 

     ${var/#pattern}:行首 

     ${var/%pattern}:行尾 ? 

 字符大小寫轉換: 

 ${var^^}:把var中的所有小寫字母轉換為大寫 

 ${var,,}:把var中的所有大寫字母轉換為小寫

變量賦值

?${var:-value}:如果var為空或未設置,那么返回value;否 則,則返回var的值 ?${var:+value}:如果var不空,則返回value,否則返回空值 ?${var:=value}:如果var為空或未設置,那么返回value,并 將value賦值給var;否則,則返回var的值 ?${var:?error_info}:如果var為空或未設置,那么在當前終 端打印error_info;否則,則返回var的值

為腳本程序使用配置文件,實現變量賦值 

    (1) 定義文本文件,每行定義“name=value” 

    (2) 在腳本中source此文件即可

Shell變量一般是無類型的,但是bash Shell提供了declare和 typeset兩個命令用于指定變量的類型,兩個命令是等價的 

declare [選項] 變量名 

  -r 將變量設置為只讀屬性 

  -i 將變量定義為整型數 

  -a 將變量定義為數組 

  -A 將變量定義為關聯數組 

  -f 顯示此腳本前定義過的所有函數名及其內容 

  -F 僅顯示此腳本前定義過的所有函數名 

  -x 將變量聲明為環境變量 

  -l  

    將變量值轉為小寫字母 

    declare –l var=UPPER -u  

    將變量值轉為大寫字母 

    declare –u var=lower

間接變量引用

? 如果第一個變量的值是第二個變量的名字,從第一個變量引 用第二個變量的值就稱為間接變量引用 ?

variable1=variable2 ?

variable2=value ?

variable1的值是variable2,而variable2又是變量名, 

variable2的值為value,間接變量引用是指通過variable1獲 得變量值value的行為

bash Shell提供了兩種格式實現間接變量引用 

eval tempvar=\$$variable1 

     tempvar=${!variable1} ? 

示例: 

[root@server ~]# N=NAME 

[root@server ~]# NAME=45

[root@server ~]# N1=${!N} 

[root@server ~]# echo $N1 45

[root@server ~]# eval N2=\$$A 

[root@server ~]# echo $2 45

eval命令

?eval命令將會首先掃描命令行進行所有的置換,然后再執 行該命令。該命令適用于那些一次掃描無法實現其功能的 變量。該命令對變量進行兩次掃描 ? 

示例: 

[root@server ~]# CMD=whoami 

[root@server ~]# echo  $CMD whoami 

[root@server ~]# eval $CMD 

               

創建臨時文件

?mktemp命令:創建的臨時文件可避免沖突 ?

  mktemp [OPTION]… [TEMPLATE] TEMPLATE: filename.XXX X至少要出現三個 ?

  OPTION: 

  -d: 創建臨時目錄 

  -p DIR或–tmpdir=DIR:指明臨時文件所存放目錄位置 ? 

  示例: 

  #mktemp /tmp/test.XXX 

  #tmpdir=`mktemp –d /tmp/testdir.XXX` 

  #mktemp –tmpdir=/testdir test.XXXXXX

  安裝復制文件

?install命令: 

install [OPTION]… [-T] SOURCE DEST 單文件 

install [OPTION]… SOURCE… DIRECTORY install [OPTION]… -t DIRECTORY SOURCE… 

install [OPTION]… -d DIRECTORY…創建空目錄 ? 

選項: 

    -m MODE,默認755 -o OWNER 

    -g GROUP ? 

示例: 

install -m 700 -o wang -g admins file1 file2 

install –m –d /testdir/installdir 

bash如何展開命令行優先級

?

把命令行分成單個命令詞 ?

展開別名 ?

展開大括號種的聲明({}) ?

展開波浪符聲明(~) ?

命令替換$() 和 “) ?

再次把命令行分成命令詞 ?

展開文件通配(*、?、[abc]等等) ?

準備I/0重導向(<、>) ?

運行命令

bash的配置文件

按生效范圍劃分,存在兩類: ? 

全局配置: 

  /etc/profile 

  /etc/profile.d/*.sh 

  /etc/bashrc ? 

個人配置: 

  ~/.bash_profile 

  ~/.bashrc

shell登錄兩種方式

交互式登錄: 

  (1)直接通過終端輸入賬號密碼登錄; 

  (2)使用“su – UserName” 切換的用戶 執行順序: /etc/profile –> /etc/profile.d/*.sh –> ~/.bash_profile –> ~/.bashrc –> /etc/bashrc ? 

非交互式登錄: 

  (1)su UserName 

  (2)圖形界面下打開的終端 

  (3)執行腳本 執行順序: ~/.bashrc –> /etc/bashrc –> /etc/profile.d/*.sh

Profile類

? 按功能劃分,存在兩類: profiile類和bashrc類 ?

profile類:為交互式登錄的shell提供配置 全局:/etc/profile, /etc/profile.d/*.sh 個人:~/.bash_profile 功用: (1) 用于定義環境變量 (2) 運行命令或腳本

bashrc類:為非交互式和交互式登錄的shell提供配置 全局:/etc/bashrc 個人:~/.bashrc 

功用: (1) 定義命令別名和函數 (2) 定義本地變量

編輯配置文件生效

修改profile和bashrc文件后需生效 兩種方法: 

  1重新啟動shell進程 

  2 . 或source 

例: . ~/.bashrc

Bash 退出任務 ?  

保存在~/.bash_logout文件中(用戶) ? 

在退出登錄shell時運行 ? 

用于 

  創建自動備份 

  清除臨時文件

yum 的倉庫指向 和 編譯安裝 

 yum的命令行選項: 

     –nogpgcheck:禁止進行gpg check 

     -y: 自動回答為“yes” 

     -q:靜默模式 

     –disablerepo=repoidglob:臨時禁用此處指定的repo 

     –enablerepo=repoidglob:臨時啟用此處指定的repo 

     –noplugins:禁用所有插件

如何使用光盤當作本地yum倉庫: 

  (1) 掛載光盤至某目錄,例如/media/cdrom # mount /dev/cdrom /media/cdrom 

  (2) 創建配置文件 

    [CentOS7] 

    name= 

    baseurl= 

    gpgcheck= 

    enabled=

程序包編譯

? 程序包編譯安裝: ?

Application-VERSION-release.src.rpm –> 安裝后,使 用rpmbuild命令制作成二進制格式的rpm包,而后再安裝 ? 

源代碼–>預處理–>編譯–>匯編–>鏈接–>執行 ? 

源代碼組織格式: 

    多文件:文件中的代碼之間,很可能存在跨文件依賴關系 

    C、C++:make (項目管理器,configure –> Makefile.in –> makefile) 

    java: maven

C代碼編譯安裝三步驟: 

1、./configure: 

  (1) 通過選項傳遞參數,指定啟用特性、安裝路徑等;執 行時會參考用戶的指定以及makefile.in文件生成makefile 

  (2) 檢查依賴到的外部環境,如依賴的軟件包 

2、make:根據makefile文件,構建應用程序 

3、make install:復制文件到相應路徑 ? 

    開發工具: 

        autoconf: 生成configure腳本 

        automake:生成Makefile.in ? 

注意:安裝前查看INSTALL,README

準備:提供開發工具及開發環境 開發工具:make, gcc等 開發環境:開發庫,頭文件 glibc:標準庫 實現:通過“包組”提供開發組件 

CentOS 6: 

    Development Tools 

    Server Platform Development 

CentOS 7: 

    Development Tools Development and Creative Workstati

第一步:configure腳本 

    選項:指定安裝位置、指定啟用的特性 

    –help: 獲取其支持使用的選項 選項分類: 

    安裝路徑設定: –prefix=/PATH: 指定默認安裝位置,默認為/usr/local/ –sysconfdir=/PATH:配置文件安裝位置 System types:支持交叉編譯

Optional Features: 可選特性 –disable-FEATURE –enable-FEATURE[=ARG] ?

Optional Packages: 可選包, –with-PACKAGE[=ARG],依賴包 –without-PACKAGE,禁用依賴關系

第二步:make ? 

第三步:make install

安裝后的配置: 

  (1) 二進制程序目錄導入至PATH環境變量中; 編輯文件/etc/profile.d/NAME.sh export PATH=/PATH/TO/BIN:$PATH 

  (2) 導入庫文件路徑 編輯/etc/ld.so.conf.d/NAME.conf 添加新的庫文件所在目錄至此文件中 

  讓系統重新生成緩存: ldconfig [-v]

  (3) 導入頭文件 基于鏈接的方式實現: ln -sv ?

  (4) 導入幫助手冊 編輯/etc/man.config|man_db.conf文件 添加一個MANPATH

原創文章,作者:a1215276209,如若轉載,請注明出處:http://www.www58058.com/39229

(0)
a1215276209a1215276209
上一篇 2016-08-24 10:12
下一篇 2016-08-24 10:13

相關推薦

  • linux —————-目錄配配置【FHS】

    linux 目錄配配置【FHS】 /根目錄的意義與內容 根目錄是整個系統最重要的一個目錄;根目錄與開機、還原、系統修復等操作有關 FHS建議標準: 根目錄所在的分區應該越小越好,且應用程序所安裝的軟件最好不要與根目錄放在同一個分區內,保持根目錄越小越好 FHS定義的目錄含義 /bin :系統存放執行文件的目錄,但是bin比較特殊【bin放置的是在單用戶維護?!?/p>

    Linux干貨 2017-04-17
  • 邏輯卷LVM的實現

    LVM(Logical Volume Manager,邏輯卷管理)可以實現把多個實體硬盤分區整合在一起,當作一個硬盤來重新操作處理。最重要的是LVM不像傳統分區一旦確定分區大小就不能再調整,它允許我們彈性的調整分區及文件系統容量! 通過幾道練習題來說明LVM的實現 1、創建一個至少有兩個PV組成的大小為20G的名為testvg的VG;要求PE大小為16MB,…

    2017-06-25
  • 進程和優先級

    ???? 什么是進程?我們先來了解一下進程的概念:我們知道操作系統最核心的概念就是進程。進程簡單來說就是在操作系統中運行的程序,它是操作系統資源管理的最小單位。但是進程是一個動態的實體,它是程序的一次執行過程。進程和程序的區別在于:進程是動態的,程序是靜態的,進程是運行中的程序,而程序是一些保存在硬盤上的可執行代碼。 ?? 當多個任務要執行時怎么辦呢?先執行…

    2017-09-09
  • day5總結筆記

    本文內容: 索引節點 硬鏈接與軟鏈接 重定向 用戶組 useradd命令 索引節點: 索引節點包含了一個表,包含了有關文件的元數據,包含:     文件類型,權限,UID,GID 鏈接數(指向這個文件名路徑名稱個數)      該文件的大小和不同的時間戳。&n…

    系統運維 2016-08-08
  • N23-北京-阿來

           我是阿來,我參加了馬哥Linux運維網絡班,從2016年9月開始我將跟隨馬哥學習Linux技術。我的學習宣言是:學習的路,就在腳下,一步一個腳印,領路的人,就這這里,一天一點進步!

    Linux干貨 2016-09-12
  • 馬哥教育網絡班22期+第1周課程練習

    Linux的發行版以及不同發行版之間的聯系與區別    Linux發行版主要的大分支有三個:dibian  S.U.S.E  redhat 一個操作系統由kernel和application組成。編譯封裝的時候根據不同的application,可以編譯成不同的發行版本。 所有的linux發行版都是基于GPL的版權,它們…

    Linux干貨 2016-08-15
欧美性久久久久