Linux Shell篇之二:Shell编程条件语句(1)
一、条件语句if
在LinuxShell编程中,if、for、while、case等条件流程控制语句用的非常多,把这些学好,对提升脚本的功力有非常大的帮助。下面将逐个来讲解具体的用法:
if条件判断语句格式
if (表达式) #if ( Variable in Array )
语句1
else
语句2
fi
注:():表示比较数字大小的运算
练习if语句
例1:测试数字大小
查看具体的执行过程,添加参数-x
例2:测试目录是否存在,不存在则新建
[ -d /data/shell ]:表示判断目录存在;
[ ! -d /data/shell ]:表示判断目录不存在;
结果输出:
注:中括号的两边必须要有空格!
例3:使用if条件语句编写MySQL备份脚本
执行语句并查看:
注:这里是LAMP的环境,并不是源码包安装的mysql!
如果是源码包安装的,就需要填写完整的路径,不是直接使用mysqldump的命令!
二、循环语句for
语法:
for i(变量) in 字符串
do
语句1
done
注:if可以与for整合使用;但是while可以当做条件来循环,功能更强大!
循环语句for练习
例1:列打印1-9:
行打印1-9:
例2:打印3行内容
注:表达式:$(( j=j+1 ))=expr $j + 1
)必须用引号,否则会当成命令;
例3:循环IP
把这个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!并重启系统即可!
再次执行:ssh -l root 192.168.174.16 'df -h'
做成免密钥的登录方式:ssh-keygen
需求:本地机器ssh登录服务器:无需输入密码,即可查看着20台服务器的磁盘使用情况!单向即可!
步骤1:ssh-keygen -t dsa:将会生成密钥文件和私钥文件id_dsa id_dsa.pub
步骤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/
步骤3:并将id_dsa.pub的内容添加到~/.ssh/authorized_keys中:
cat id_dsa.pub >> ~/.ssh/authorized_keys
步骤4:目录.ssh和文件authorized_keys的权限必须是600
完成这些工作后,用户从本地机器到远程机器的登录就不用密码了!
步骤5:编辑脚本文件:
步骤6:把脚本的内容导入到IP.txt文件:
sh twenty-five.sh >>ip.txt
并查看ip.txt的内容:
步骤7:把这个脚本批量执行:
例4:还可以利用这个脚本来复制多个文件到多台服务器上:
步骤1:编辑脚本:
步骤2:执行脚本:
步骤3:查看输出结果!
2、求和值
3、同时解压多个文件
4、同时打包和还原多个文件
gzip格式:把文件打包,以.gz为结尾,并删除原文件,只留下打包过的文件!
如何还原批量的.sh文件?
for i in `ls /tmp/`;do tar -xzf /tmp/$i -C /data/shell/;done
六、循环语句while
语法:
while 条件语句
do
语句1
done
练习while
例1:逐行读取某个文件
mysql -uroot -p123 discuz </etc.hosts.sql
例2:
当需要把一台服务器上的资源,部署到远端的一台服务器上,需要使用以下脚本:
scp -r /data/app/www1 [email protected]:/var/www/html
rsync -aP /data/app/www1 [email protected]:/var/www/html
当需要把资源服务器上的内容,批量部署到特定的服务器时候,就需要用到以下的脚本:
需求:把192.168.174.16:/data/app/www1,同步到192.168.174.17:/var/www/html
编辑这个脚本:
运行脚本:
效果:
再把带#的一行内容过滤:
效果:
如何分别取出其中的3段内容?
echo /data/app1/www1 [email protected] /var/www/html/
运行以下脚本:
过滤掉:scp -r root@:/
这里利用了ip.txt_swp这个临时文件,过滤掉了#那行的内容!
脚本执行的过程如下:
效果如下:
七、util循环语句
语法:直到满足条件,才退出。否则执行action
until 条件
do
action
done
例1:条件判断数字
本文出自 “柏书兵-系统运维” 博客,转载请与作者联系!