Linux Shell篇之二:Shell编程条件语句(1)

Linux Shell篇之二:Shell编程条件语句(1)

一、条件语句if

       在LinuxShell编程中,if、for、while、case等条件流程控制语句用的非常多,把这些学好,对提升脚本的功力有非常大的帮助。下面将逐个来讲解具体的用法:

if条件判断语句格式

if (表达式)  #if ( Variable in Array )

语句1

else

语句2

       fi

注:():表示比较数字大小的运算

练习if语句

例1:测试数字大小

wKiom1W08JrB1DsgAAEMWOZKUSI168.jpg

wKioL1W08oTzKxT6AACJIzwPPNg131.jpg

查看具体的执行过程,添加参数-x

wKiom1W08QTS-_RkAAFaWPphqF0620.jpg


例2:测试目录是否存在,不存在则新建

[ -d /data/shell ]:表示判断目录存在;

wKioL1W09s3inbGUAACktxNiRiE052.jpg

[ ! -d /data/shell ]:表示判断目录不存在;

wKiom1W8eGXjnqOlAACcb0XUIJU948.jpg

结果输出:

wKioL1W8erKBfX7cAACYlzJu-R4532.jpg

注:中括号的两边必须要有空格!



例3:使用if条件语句编写MySQL备份脚本

wKiom1W4pu2AhyEGAAJgTTOAO8k463.jpg

执行语句并查看:

wKioL1W4qNyyibtnAAJGsRp-p8A138.jpg

注:这里是LAMP的环境,并不是源码包安装的mysql!

如果是源码包安装的,就需要填写完整的路径,不是直接使用mysqldump的命令!



二、循环语句for

语法:

for i(变量) in 字符串

do

语句1

done

注:if可以与for整合使用;但是while可以当做条件来循环,功能更强大!

循环语句for练习

例1:列打印1-9

wKiom1W9lBOh5NqWAAAo5T6LOnU599.jpg

wKiom1W9nZaTutlXAABXxYGwTu4750.jpg

wKioL1W9okqw4uikAABEwuHpaE0309.jpg

wKioL1W9okqCVNPAAAAwkmzL_kM941.jpg

行打印1-9:

wKiom1W9o43QhcTFAABIiUCe6og869.jpg

wKiom1W9o43h9ishAABIj1kmrmQ106.jpg

wKioL1W9pYLBrniYAABeWeMEyfA007.jpg


例2:打印3行内容

wKioL1W7FZCi_Ut-AACAtJbW89c469.jpg

wKiom1W7E5_zlLQTAACAfhvNC7s852.jpg

wKioL1W7FcWhlCehAABFW0u5Et4573.jpg

注:表达式:$(( j=j+1 ))=expr $j + 1

      )必须用引号,否则会当成命令;


例3:循环IP

wKioL1W9qVmzhbLHAABM3y6-Zc4723.jpg

wKiom1W9p2WS47j4AADiGcXzQLw625.jpg

把这个IP服务器列表导入到一个文件中:

sh twenty-four.sh >>ip.txt

让这20台服务器批量运行命令:如查看本地磁盘的使用情况;

ssh -l root 192.168.174.16 'df -h'

出现错误:Address 192.168.174.16 maps to localhost, but this does not map back to the address �C POSSIBLE BREAKIN ATTEMPT!

解决办法:修改这个文件:/etc/ssh/ssh_config yes改成no!并重启系统即可!

wKioL1W9thXxmRGWAAQfFpw2Utg181.jpg

再次执行:ssh -l root 192.168.174.16 'df -h'

wKioL1W9trGjuwi6AADOvby8Or0042.jpg

做成免密钥的登录方式:ssh-keygen

需求:本地机器ssh登录服务器:无需输入密码,即可查看着20台服务器的磁盘使用情况!单向即可!

步骤1:ssh-keygen -t dsa:将会生成密钥文件和私钥文件id_dsa  id_dsa.pub

wKiom1W-G7Oix7f1AAIgPKw4dzk093.jpg

步骤2:在B上新建目录:mkdir .ssh

将 .pub 文件复制到B机器的 .ssh 目录:

scp /root/.ssh/id_dsa.pub [email protected]:/root/.ssh/

或者,

ssh-copy-id -i /root/.ssh/id_dsa.pub 192.168.174.17:/root/.ssh/

wKioL1W-IPbSo_gDAADpCeRnxzo751.jpg

wKiom1W-Hx-B2-6ZAAAt3SwEXAI893.jpg

步骤3:并将id_dsa.pub的内容添加到~/.ssh/authorized_keys中:

cat id_dsa.pub >> ~/.ssh/authorized_keys

wKioL1XB7h6B3TFJAABsL_BFOqI109.jpg

步骤4:目录.ssh和文件authorized_keys的权限必须是600

wKiom1W-IKnSdIWPAAC1QBRzsmY147.jpg

完成这些工作后,用户从本地机器到远程机器的登录就不用密码了!

wKiom1XB7hewWryvAAFg9iAjriE598.jpg

步骤5:编辑脚本文件:

wKiom1W-JiqBJ2ANAABSP1uCulg435.jpg

步骤6:把脚本的内容导入到IP.txt文件:

sh twenty-five.sh >>ip.txt

并查看ip.txt的内容:

wKioL1W-KN3R_oybAAA41PsYLMs020.jpg

步骤7:把这个脚本批量执行:

wKioL1W-KB7TyDB8AAGMoZ1OyUs476.jpg


例4:还可以利用这个脚本来复制多个文件到多台服务器上:

步骤1:编辑脚本:

wKiom1W-KqGjM2kYAABg-e4LQXI608.jpg

步骤2:执行脚本:

wKioL1W-LJXjeGCTAARD-oq3FXs780.jpg

步骤3:查看输出结果!

wKioL1W-LJaDra6dAAIr0MuH86A680.jpg


2、求和值

wKioL1W-MaOQHtL7AABhRsJmdTY356.jpg

wKiom1W-L6-yWdEcAAAkpgHf1_Q534.jpg


3、同时解压多个文件

wKioL1W-Nf7A0CwvAABPoZZc2Q4515.jpg

wKioL1W-Nf7CN9F8AAA3_P6RbuU076.jpg


4、同时打包和还原多个文件

gzip格式:把文件打包,以.gz为结尾,并删除原文件,只留下打包过的文件!

wKioL1W-OFmheuudAANp3wM6Ewo895.jpg


wKioL1W-PXiSBAi0AAOfee9stzE459.jpg

wKiom1W-O4TS1H_0AAHaPGM3zP0786.jpg

如何还原批量的.sh文件?

for i in `ls /tmp/`;do tar -xzf /tmp/$i -C /data/shell/;done

wKioL1W_PynjWGg7AAHqBexY9L8921.jpg



六、循环语句while

语法:

while 条件语句

do

       语句1

      done


练习while

例1:逐行读取某个文件

wKiom1XAiLbzd5UCAAA9dm0QDtg278.jpg

wKioL1XAiq3QMYKZAACNnVV4UNY853.jpg

mysql -uroot -p123 discuz </etc.hosts.sql

例2:

当需要把一台服务器上的资源,部署到远端的一台服务器上,需要使用以下脚本:

scp -r /data/app/www1 [email protected]:/var/www/html

wKioL1XBqtuARwZQAABGxyP3N7o014.jpg

rsync -aP  /data/app/www1 [email protected]:/var/www/html

当需要把资源服务器上的内容,批量部署到特定的服务器时候,就需要用到以下的脚本:

需求:把192.168.174.16:/data/app/www1,同步到192.168.174.17:/var/www/html

编辑这个脚本:

wKioL1XA0CGxi5hcAAAwe8jwooo336.jpg

运行脚本:

wKiom1XAzirQpFDBAAB7iqfnmrI275.jpg

效果:

wKiom1XBhlCBHOeWAABpkUWFfm0372.jpg

再把带#的一行内容过滤:

wKiom1XAzvXC_9DBAABDvu1nNR0594.jpg

效果:

wKioL1XA0O3ircjaAABlMUX-u2g243.jpg

如何分别取出其中的3段内容?

echo /data/app1/www1 [email protected] /var/www/html/

wKiom1XBqRmi1zTuAAE8spEt7vU901.jpg

运行以下脚本:

wKioL1XBqzegJjTPAADD3jpgIjs974.jpg

wKioL1XBqzfzgm8GAACUycTGz9Q985.jpg

过滤掉:scp -r root@:/

wKioL1XBqqXw7epgAACH0GQTQcE371.jpg

这里利用了ip.txt_swp这个临时文件,过滤掉了#那行的内容!

wKiom1XEWJ6QxB_xAAEvWRf7u_8017.jpg

脚本执行的过程如下:

wKiom1XEV6bAY8J5AACSexXVgmc680.jpg

效果如下:

wKioL1XEXTPDLHlLAAB4Ckp94no645.jpg

wKiom1XEWzfCZiYYAACN7iskUcg161.jpg

 


七、util循环语句

语法:直到满足条件,才退出。否则执行action

until 条件                     

do

action

done

例1:条件判断数字

wKioL1XA6MLj8fgHAABEWeTJYxo888.jpg

wKiom1XA5szR2Y1pAAA1OtRaPD8658.jpg


本文出自 “柏书兵-系统运维” 博客,转载请与作者联系!

你可能感兴趣的:(linux)