shell 腳本 之循環 for while until 和 軟件包的管理 【上】

shell 腳本 之循環 for while until 和 軟件包的管理 【上】前端


循環執行 node

   將某代碼段重複運行屢次 shell

   重複運行多少次: 數據庫

           循環次數事先已知 vim

           循環次數事先未知 緩存

       有進入條件和退出條件 bash

for, while, untildom


for 變量名 in 列表;do ide

        循環體 工具

     done  

執行機制: 依次將列表中的元素賦值給「變量名」; 每次賦值後即執 行一次循環體; 直到列表中的元素耗盡,循環結束


列表生成方式: 

    (1) 直接給出列表 

    (2) 整數列表: (a) {start..end} (b) $(seq [start [step]] end) 

    (3) 返回列表的命令 $(COMMAND) 

    (4) 使用glob,如:*.sh 

    (5) 變量引用; $@, $*



while循環

while CONDITION; do 

       循環體 

    done

CONDITION:循環控制條件;進入循環以前,先作一次判 斷;每一次循環以後會再次作判斷;條件爲「true」,則執行 一次循環;直到條件測試狀態爲「false」終止循環  

所以:CONDTION通常應該有循環控制變量;而此變量的值 會在循環體不斷地被修正  

進入條件:CONDITION爲true;  

退出條件:CONDITION爲false



until循環 until CONDITION; do 

      循環體

done

進入條件: CONDITION 爲false  

   退出條件: CONDITION 爲true



循環控制語句 之 continue and break


循環控制語句continue

用於循環體中

continue [N]:提早結束第N層的本輪循環,而直接進入下一 輪判斷;最內層爲第1層 

    while CONDTIITON1; do 

       CMD1 

       ... 

    if CONDITION2; then 

       continue 

    fi 

       CMDn 

       ... 

    done




    循環控制語句break

用於循環體中

break [N]:提早結束第N層循環,最內層爲第1層 

    while CONDTIITON1; do 

       CMD1 

       ... 

    if CONDITION2; then 

       break 

    fi CMDn 

       ... 

    done



    建立無限循環

while true; do 

    循環體

done


until false; do 

    循環體

Done



解壓歸檔 之 tar


tar [OPTION]... 

(1) 建立歸檔 

    tar -c -f /PATH/TO/SOMEFILE.tar FILE... 

    tar cf /PATH/TO/SOMEFILE.tar FILE... 

(2) 查看歸檔文件中的文件列表  

    tar -t -f /PATH/TO/SOMEFILE.tar 

(3) 展開歸檔 

    tar -x -f /PATH/TO/SOMEFILE.tar tar -x -f /PATH/TO/SOMEFILE.tar -C /PATH/  


    結合壓縮工具實現:歸檔並壓縮 -j: bzip2, -z: gzip, -J: xz



cpio 複製 從或到文件

    cpio命令是經過重定向的方式將文件進行打包備份,還原恢復 的工具,它能夠解壓以「.cpio」或者「.tar」結尾的文件。


    cpio [選項] > 文件名或者設備名

    cpio [選項] < 文件名或者設備名  


    選項 

      -o 將文件拷貝打包成文件或者將文件輸出到設備上 

      -i 解包,將打包文件解壓或將設備上的備份還原到系統 

      -t 預覽,查看文件內容或者輸出到設備上的文件內容 

      -v 顯示打包過程當中的文件名稱。

      -d 解包生成目錄,在cpio還原時,自動的創建目錄 

      -c 一種較新的存儲方式



      例如


      將etc目錄備份: 

         find ./etc -print |cpio -ov >etc.cpio  

      內容預覽 

         cpio –tv < etc.cpio  

      要解包文件 

         cpio –iv  <etc.cpio 

         cpio –idv < etc.cpio



軟件運行環境

API:Application Programming Interface 

        POSIX:Portable OS  

  程序源代碼 --> 預處理 --> 編譯 --> 彙編 --> 連接 

        靜態編譯: 

        共享編譯:.so


  ABI:Application Binary Interface 

        Windows與Linux不兼容 

        ELF(Executable and Linkable Format) 

        PE(Portable Executable) 

    庫級別的虛擬化: 

        Linux: WINE 

        Windows: Cywin



包管理器



二進制應用程序的組成部分: 

    二進制文件、庫文件、配置文件、幫助文件

程序包管理器: 

    debian:deb文件, dpkg包管理器 

    redhat: rpm文件, rpm包管理器 

    rpm: Redhat Package Manager 

         RPM  Package Manager



   包命名


rpm包命名方式: 

   name-VERSION-release.arch.rpm 

   VERSION: 

   major.

   minor.

   release 

   release:release.OS 

   常見的arch: x86: i386, i486, i586, i686 x86_64: x64, x86_64, amd64 

   powerpc: ppc 

   跟平臺無關:noarch


   包命名和工具


包:分類和拆包 Application-VERSION-ARCH.rpm: 

    主包 Application-devel-VERSION-ARCH.rpm 

    開發子包 Application-utils-VERSION-ARHC.rpm 

    其它子包 Application-libs-VERSION-ARHC.rpm 

    其它子包  

包之間:可能存在依賴關係,甚至循環依賴  


解決依賴包管理工具: 

    yum:rpm包管理器的前端工具 

    apt-get:deb包管理器前端工具 

    zypper: suse上的rpm前端管理工具 

    dnf: Fedora 18+ rpm包管理器前端管理工具


庫文件


查看二進制程序所依賴的庫文件: 

   ldd /PATH/TO/BINARY_FILE  

管理及查看本機裝載的庫文件: 

   ldconfig 

   /sbin/ldconfig -p: 顯示本機已經緩存的全部可用庫文件 

名及文件路徑映射關係 

   配置文件:/etc/ld.so.conf, /etc/ld.so.conf.d/*.conf 

   緩存文件:/etc/ld.so.cache



   包管理器

程序包管理器: 功能:將編譯好的應用程序的各組成文件打包一個或幾個 程序包文件,從而方便快捷地實現程序包的安裝、卸載、查詢、 升級和校驗等管理操做


一、包文件組成 (每一個包獨有) 

    RPM包內的文件 

    RPM的元數據,如名稱,版本,依賴性,描述等 

    安裝或卸載時運行的腳本


二、數據庫(公共) 

    程序包名稱及版本 

    依賴關係 

    功能說明 

    包安裝後生成的各文件路徑及校驗碼信息



管理程序包的方式: 

    使用包管理器:

    rpm 

    使用前端工具:

    yum, dnf 



rpm包管理

   CentOS系統上使用rpm命令管理程序包: 

     安裝、卸載、升級、查詢、校驗、數據庫維護 

     安裝: 

     rpm {-i|--install} [install-options] PACKAGE_FILE… 

        -v: verbose 

        -vv: 

        -h: 以#顯示程序包管理執行進度 

     rpm -ivh PACKAGE_FILE ...



rpm包安裝 [install-options] 

    --test: 測試安裝,但不真正執行安裝;dry run模式 

    --nodeps:忽略依賴關係 

    --replacepkgs | replacefiles 

    --nosignature: 不檢查來源合法性 

    --nodigest:不檢查包完整性 

    --noscipts:不執行程序包腳本片段 

    

    %pre: 安裝前腳本; --nopre 

    %post: 安裝後腳本; --nopost 

    %preun: 卸載前腳本; --nopreun 

    %postun: 卸載後腳本;--nopostun



rpm包升級

升級:

rpm {-U|--upgrade} [install-options] PACKAGE_FILE...

rpm {-F|--freshen} [install-options] PACKAGE_FILE... 

    upgrade:安裝有舊版程序包,則「升級」 若是不存在舊版程序包,則「安裝」 

    freshen:安裝有舊版程序包,則「升級」 若是不存在舊版程序包,則不執行升級操做 

    rpm -Uvh PACKAGE_FILE ... 

    rpm -Fvh PACKAGE_FILE ... 

    --oldpackage:降級 

    --force: 強行升級



升級注意事項

 (1) 不要對內核作升級操做;Linux支持多內核版本並存,所以 ,對直接安裝新版本內核 

    (2) 若是原程序包的配置文件安裝後曾被修改,升級時,新版本 

        的提供的同一個配置文件並不會直接覆蓋老版本的配置文件,而 把新版本的文件重命名(FILENAME.rpmnew)後保留





一、求100之內全部正整數之和





#!/bin/bash

 read -p "first number:" a

 read -p "second number:" b

[ $a -ge $b ] && echo "sum is `seq -s+ $b $a | bc`" || echo "sum is `seq -s+ $a $b | bc`"



[root@localhost bin]# bash shushu.sh

first name is a:2

second name is b:100

sum= 5049




二、經過ping命令探測172.16.250.1-254範圍內的全部主機 的在線狀態,統計在線主機和離線主機各多少。




#!/bin/bash

 read -p "please input a IPv4:" ip

  up=0 down=0

  ipv4=`echo $ip|cut -d. -f1-3`

 for ipv in {0..255} ;do

   IP="$ipv4"."$ipv"

   ping "$IP" -c 1 -W 1 &>/dev/null && echo "The Up IPv4 is:$IP" && let up+=1 &>/dev/null || let down+=1 &>/dev/null

 done

 echo "IPv4($ipv4.1-255) up is :$up"

 echo "IPv4($ipv4.1-255) down is :$down"



三、打印九九乘法表 




for i in  {1..9};do

for j in $(seq 1 $i) ;do

     echo -ne "${j}x${i}=$[i*j]\t"

done

echo 

done


電腦演示



[root@localhost bin]# vim 999.sh

[root@localhost bin]# bash 999.sh

1x1=1

1x2=2 2x2=4

1x3=3 2x3=6 3x3=9

1x4=4 2x4=8 3x4=12 4x4=16

1x5=5 2x5=10 3x5=15 4x5=20 5x5=25

1x6=6 2x6=12 3x6=18 4x6=24 5x6=30 6x6=36

1x7=7 2x7=14 3x7=21 4x7=28 5x7=35 6x7=42 7x7=49

1x8=8 2x8=16 3x8=24 4x8=32 5x8=40 6x8=48 7x8=56 8x8=64

1x9=9 2x9=18 3x9=27 4x9=36 5x9=45 6x9=54 7x9=63 8x9=72 9x9=81





四、利用變量RANDOM生成10個隨機數字,輸出這個10數字 ,並顯示其中的最大者和最小者


#!/bin/bash

declare -i max=0

declare -i min=0


for i in {1..10} ;do

  tmp=$RANDOM

  [ $i -eq 1 ] && min=$tmp

  if [ $i -le 9 ] ;then

     echo -n "$tmp"

  else

     echo "$tmp"

  fi

  if [ $tmp -gt $max ] ;then

     max=$tmp

  elif [$tmp -lt $min ] ;then

     min=$tmp

  fi

done

echo "the max random is $max"

echo "the min random is $min"





 

五、打印國際象棋棋盤


  1#!

  2 #

  3 for i in $(seq 1 8);do

  4 for j in $(seq 1 8);do

  5 [ $[i%2-$j%2] -eq 0 ] &&  echo -ne "\033[41m  \033[0m" ||  echo -ne "\033[47    m  \033[0m"

  6 let j++

  7 done

  8 echo ""

  9 let i++

 10 done

 11 

相關文章
相關標籤/搜索