shell流程语句使用介绍,分支与巡回结构

分段与循环结构

if语句是事实上生产专业中最重要且最常用的言辞,所以,必须驾驭牢固。

一、case运用

1)使用if、case、read
例子1:
#!/bin/bash
#读取终端输入的字符
read -p "Please input a Number:" n
n1=`echo $n|sed 's/[0-9]//g'`

if条件句

*#!/bin/bash
#第1段程序,用case语句完毕多少个增选语句#
#read -p "请输入三个名字:" i
#case $i in
#redhat)
#   echo "fedora";;
#fedora)
#   echo "redhat";;
#
)
#   echo "Error";;
#esac

#利用if语句举行判断
if [ ! -z $n1 ]
then
echo "Please input a Number."
exit 1
elif [ $n -lt 0 ] || [ $n -gt 100 ]
then
echo "The number ranger is 0-100"
exit 1
fi

if条件句语法

  • 单分支结构

语法

  1. if [ 条件 ]

  2.   then

  3.     指令

  4. fi

  5. if [ 条件 ];then

  6.     指令

  7. fi

标准表达式[ -f "$file1" ]&& echo 1,相当于上边包车型大巴if语句。

  1. if [ -f "$file1" ];then

  2.     echo 1

  3. fi

  • 双分层协会
  1. if [ 条件 ]

  2.   then

  3.     指令集1

  4. else

  1.     指令集2

  2. fi

原则表达式[ -f "$file1" ]&& echo 1||echo 0,相当于双分支if [ -f "$file1" ];then echo 1;else echo 0;fi。

  • 多分支协会
  1. if 条件

  2.   then

  3.     指令

  4. elif 条件

  5.   then

  6.     指令

  7. elif 条件

  8.   then

  9.     指令

  10.     ...

  11.   else

  1.     指令

  2. fi

#第2段程序,用case语句达成三个指令的八个挑选成效,比if语句轻便#
#case $1 in
#shell流程语句使用介绍,分支与巡回结构。-n|--new)
#  touch $2;;
#-e|--edit)
#  vim $2;;
#-c|--cat)
#  cat $2;;
#-r|--remove)
#  rm -rf $2;;
#*)
#  echo "Usage:$0 (-n|-e|-c|-r) 文件名";;
#esac**

n2=$[$n%2]

单分支if条件句

支付shell脚本判别系统剩余内部存款和储蓄器的尺寸,假如低于100M就邮件报告急察方给助理馆员,并步向种类定期职责每两分钟实践一回检查。

free -m|awk 'NR==2{print $4}'

  1. [root@lamp ~]# cat free_m.sh
  1. #!/bin/bash

  2.  

  3. FREE=`free -m|awk 'NR==3{print $4}'`

  1. if [ $FREE -lt 100 ]

  2.   then

  3.     echo "warning:The available memory $FREE."

  1.     exit 0

  2. fi

  3. echo "The available memory $FREE."

二、for运用

#行使case语句实行推断
case $n2 in
0)
echo "偶数"
;;
1)
echo "奇数"
;;
*)
echo "Please input a Number."
;;
esac

双多分层if条件句

用if双拨出完毕read读入的方式相比较四个数的轻重。

  1. [root@lamp ~]# cat c3.sh

  2. #!/bin/bash

  3. read -p "Pls input two nums: " num01 num02

  1. [ -z $num01 ]&&{

  2.   echo "the num01 you input must be int."

  1.   exit 2

  2. }

  3. [ -z $num02 ]&&{

  4.   echo "the num02 you input must be int."

  1.   exit 2

  2. }

  3. expr $num01 $num02 1 &>/dev/null

  4. [ $? -ne 0 ]&&{

  5.   echo "the num you input must be int."

  1.   exit 2

  2. }

  3. if [ $num01 -lt $num02 ]

  4.   then

  5.     echo "$num01 < $num02."

  6. elif [ $num01 -gt $num02 ]

  7.   then

  8.     echo "$num01 > $num02."

  9.   else

  1.     echo "$num01 = $num02."

  2. fi

用if双拨出实现对nginx或mysql服务是还是不是正规进行剖断,使用进程数、端口、url的诀窍剖断,借使经过没起,把过程运营。

web服务和数据库(mysql)的督察措施。

1、端口监察和控制

本地监察和控制:netstat、ss、lsof

长途监察和控制:telnet、nmap、nc

telnet监察和控制端口

  1. [root@lamp ~]# echo -e "n"|telnet www.baidu.com 80|grep Connected|wc -l

  2. Connection closed by foreign host.

  1. 1

nmap监察和控制端口

  1. [root@lamp ~]# nmap www.baidu.com -p 80|grep open|wc -l

  2. 1

nc监察和控制端口

  1. [root@lamp ~]# nc -z 192.168.163.128 22|grep succeeded|wc -l

  2. 1

2、进度监察和控制

本土监控:ps -ef|grep mysql|wc -l

3、wget、curl,http格局基于重回值或然再次回到内容判别。

4、header(http),http方式基于状态码判别。

5、数据库特有通过mysql客商端连接,依照再次回到值也许再次来到内容剖断。

  1. [root@lamp ~]# cat check_db.sh
  1. #!/bin/bash

  2. #local

  3. if [ "`netstat -lnt|grep 3306|awk -F "[ :] " '{print $5}'`" = "3306" ]

  4. #if [ `ps -ef|grep mysql|grep -v grep|wc -l` -gt 0 ]

  5. #if [ `netstat -lntup|grep mysqld|wc -l` -gt 0 ]

  6. #if [ `lsof -i tcp:3306|wc -l` -gt 0 ]

  7.  

  8. #remote

  9. #if [ `nmap 192.168.1.123 -p 3306 2>/dev/null|grep open|wc -l` -gt 0 ]

  10. #if [ `nc -w 2 192.168.1.123 3306 &>/dev/null&&echo ok|grep ok|wc -l` -gt 0 ]

  1.   then

  2.     echo "Mysql is Running."

  3. else

  1.     echo "Mysql is Stopped."

  2.     /deta/mysql start

  3. fi

 

  1. [root@lamp ~]# cat check_web.sh
  1. #!/bin/bash

  2. if [ "`curl -I -s -o /dev/null -w "%{http_code}n" " = "200" ]

  3. #if [ `curl -I 2>/dev/null|head -1|egrep "200|302|301"|wc -l` -eq 1 ]

  1. #curl -s &>/dev/null

  2. #if [ $? -eq 0 ]

  3. #if [ "`curl -s &>/dev/null&&echo $?`" = "0" ]

  4. #if [ "`curl -s " = "bbs" ]

  5.   then

  6.     echo "httpd is running."

  7. else

  1.     echo "httpd is stopped."

  2. fi

 

通过传参的点子往/etc/user.conf里加多顾客,具体供给如下:

1、命令用法:USAGE:sh adduser {-add|-del|-search} username

2、传参需求:假诺参数为-add,表示增添后边接的客商名;要是参数为-del,表示删除前边接的顾客名;尽管参数为-search,表示查找前面接的客户名。

3、借使有同名的客户则不可能加上,未有对应客商则无需删除,查找到客户以致未有客户时提交鲜明提醒。

4、/etc/user.conf不能够被抱有外界顾客之间删除或修改。

  1. [root@lamp ~]# cat user.sh

  2. #!/bin/bash

  3. ROOT_UID=0

  4.  

  5. if [ "$UID" -ne "$ROOT_UID" ]

  6.   then

  7.     echo "Mast be root to run this script."

  1.     exit 1

  2. fi

  3. if [ $# -ne 2 ]

  4.   then

  5.     echo "USAGE:sh $0 {-add|-del|-search} username."

  6.     exit 2

  7. fi

  8. check=$1

  9. name=$2

  10. if [ "$check" = "add" ]

  11.   then

  12.     result=`cat /etc/user.conf|grep -Fx "$name"`

  13.     [ -z $result ]&&{

  14.       echo "$name" >> /etc/user.conf

  15.       echo "user add "$name" is ok."

  16.       exit 0

  17.     }

  18.     echo "user $name is in."

  19.     exit 0

  20. elif [ "$check" = "del" ]

  21.   then

  22.     result=`cat /etc/user.conf|grep -Fx "$name"`

  23.     [ -z $result ]&&{

  24.       echo "user "$name" not find."

  25.       exit 0

  26.     }

  27.     sed -ri /^$name$/d /etc/user.conf

  1.     echo "user del "$name" is ok."

  2. elif [ "$check" = "search" ]

  3.   then

  4.     result=`cat /etc/user.conf|grep -Fx "$name"`

  5.     [ -z $result ]&&{

  6.       echo "user $name not find."

  7.       exit 0

  8.     }

  9.     echo $result

  10.     exit 0

  11. else

  1.     echo "USAGE:sh $0 {-add|-del|-search} username."

  2.     exit 1

  3. fi

 

得到文件md5值,防篡改。

  1. [root@lamp ~]# find ./ -type f|xargs md5sum

将md5值写入文件。

  1. [root@lamp ~]# find ./ -type f|xargs md5sum >/tmp/md5list

比较md5值。

  1. [root@lamp ~]# md5list -c /tmp/md5list  

**#!/bin/bash
#for i in 1 aa c 88
#do
#   echo $i
#done

例子2:
#!/bin/bash
read -p "please input a digit:" n
#n2=`echo $n|grep -c '[^0-9]'`
#n1=$[$n%2]

for i in `cat /opt/user.txt`
do
   useradd user$i 2>/opt/userfalse.log
done**

#if [ $n2 -eq 1 ]
if echo $n | grep -q '[^0-9]'
then
echo "你输入的不是数字,请重新输入"
exit 1
fi

**三、while运用**

n1=$[$n%2]

 

if [ $n1 -eq 0 ]
#if(($n1==0))
then
echo "输入的是偶数"
else
echo "输入的是基数"
fi

#!/bin/bash
i=1
while [ $i -le 5 ]
do
  echo "请等待..."
#  let i
   i=i
done

例子3:
#!/bin/bash
a=1
if [ $a == 2 ]
then
echo "true"
elif [ $a -lt 10 ]
then
echo "no false"
else
echo "false"
fi

**四、猜数字**

例子4:
#!/bin/bash

#!/bin/bash

FILES=$*
if [ -z $* ];
then
echo -e "\033[32m{usage:$0 /boot|/tmp|/tmp/test.txt}\033[0m"
exit
fi

#  “上边包车型客车这段代码有BUG,若是尚未输入数值,会报错”
#x=$[RANDOM]
#read -p "10 以内数字请猜一猜:" cai
#
#   if [ $cai -gt $x ];then
#       echo "对不起,你猜大了,正确答案是:$x"
#   elif [ $cai -lt $x ];then
#       echo "对不起,你猜小了,正确答案是:$x"
#   else
#       echo "恭喜您,猜对了,准确答案正是:$x"
#   fi

for i in `echo 192.168.204.129 127.0.0.1`
do

#  "不猜到精确不鸣金收兵,突显猜的次数"
#x=$[RANDOM]
#i=0
#while :
#do
#  read -p "10 以内的数字猜一猜:" cai
#  let i  
#    if [ $cai -gt $x ];then
#        echo "对不起,你猜大了"
#    elif [ $cai -lt $x ];then
#        echo "对不起,你猜小了"
#    else
#        echo "恭喜您,猜对了,准确答案就是:$x ,你一共猜了$i 次"
#        exit
#    fi
#done

scp -r $FILES root@$i:/root/install

#  "上面再来一段晋级代码消除BUG"
x=$[RANDOM]
i=0
while :
do
  read -p "10 以内的数字猜一猜:" cai
  let i  
    if [ $cai -gt $x ];then
        echo "对不起,你猜大了"
    elif [ $cai -lt $x ];then
        echo "对不起,你猜小了"
    else
        echo "恭喜您,猜对了,精确答案就是:$x ,你一共猜了$i 次"
        exit
    fi
done

done

**五、端口状态**

2)使用date
#!/bin/bash
d=`date %F`
exec >$d.log 2>&1
echo "Begin at `date`"
ls /learing
cd /log
ls /root >root.log
echo "End at `date`"

#!/bin/bash
#     rpm -q httpd  &> /dev/null
#
#    if [ ! $? -eq 0 ];then
#         yum -y install httpd   &> /dev/null
#    fi
#
#        # systemctl status httpd  &> /dev/null
#          netstat -antpu |grep 80
#    if [ ! $? -eq 0 ];then
#          systemctl restart httpd  
#    fi

3)使用for
例子1:
!/bin/bash
sum=0
#打字与印刷1到100相加后的总额
for i in `seq 1 100`
do
sum=$[$sum $i]
echo $i
done;
echo $sum

     rpm -q httpd  &> /dev/null
    if [ ! $? -eq 0 ];then
     yum -y install httpd   &> /dev/null
    fi
        # systemctl status httpd  &> /dev/null
         netstat -antpu |grep 80
    if [ ! $? -eq 0 ];then
           systemctl restart httpd
          if [ $? == 0 ];then
           echo "重启成功"
          fi
    fi

 

**六、非交互发邮件**

例子2:
!/bin/bash
for f in `ls /etc/`
do
if [ -d /etc/$f ]
then
ls -d /etc/$f
#echo "/etc/$f"
fi
done;

#!/bin/bash
mail -s "hello" root << EOF
first
second
third
...
tenth
EOF

例子3:
#!/bin/bash
n=`wc -l passwd |awk '{print $1}'`
for i in `seq 1 $n`;
do
sed -n "$i"p passwd;
done

**七、函数**

例子4:
#!/bin/bash

#!/bin/bash
cecho(){
   echo -e "\033[$1m$2\033[0m"
}

#while read line
for i in `cat ip.txt`
do
echo -e "\033[32m scp -r /root/learing/t8.sh root@$i:/tmp \033[0m"
done

cecho 32 OK
cecho 33 OK
cecho 34 Error
cecho 35 Hehe
**八、录入IP**

例子5:
#!/bin/bash
pfile=`find . -name "*.sh"|tail -2`
for i in `$pfile`
do
tar -czvf 2016-07-22.tar.gz $i
done

#!/bin/bash
i=1
while :
do
  read -p "请输入over结束恐怕输入你要录入的IP:" ip
  [ $ip == over ] && break
  x[$i]=$ip
  echo $ip >> /opt/temp/ip.log
  let i
done
#echo ${x[@]}
echo ${x[*]}

例子6:
#!/bin/bash
j=0
for((i=1;i<=100;i ))
do
j=$[$i $j]
done
echo $j

**九、录数总括**

4)使用while
例子1:
#!/bin/bash
i=0
#while [ $i -lt 5 ]
while [[ $i<5 ]]
do
echo "$i"
((i ))
done

#!/bin/bash
sum=0
while :
do
  read -p "请输入数字:" num
  [ $num -eq 0 ] && break
#  let sum =`$num`
  sum=$[sum num]
done
echo "你输入的数字总和为:$sum"

例子2:
#!/bin/bash
while :
do
read -p "请输入:" n
if [ -z $n ]
then
echo "必要输入内容:"
continue
fi

**十、排序**

n1=`echo $n|sed 's/[0-9]//g'`

#!/bin/bash
read -p "请输入第贰个整数:" num1
read -p "请输入第三个整数:" num2
read -p "请输入第二个整数:" num3

if [ ! -z $n1 ]
then
echo "须求输入数字:"
continue
fi

#首先种方法:
#先定出num3为最大值,再定出num1、num2的轻重
#if [ $num1 -gt $num3 ];then
#     t=$num3
#     num3=$num1
#     num1=$t
#fi
#if [ $num2 -gt $num3 ];then
#     t=$num3
#     num3=$num2
#     num2=$t
#fi
#if [ $num1 -gt $num2 ];then
#     t=$num2
#     num2=$num1
#     num1=$t
#fi
#echo "$num1,$num2,$num3"

break
done
echo $n

#第二种办法:
#教师的资质的法子,先定num1为最小值,然后相比较num2、num3的分寸
#if [ $num1 -gt $num2 ];then
#tmp=$num1
#num1=$num2
#num2=$tmp
#fi
#if [ $num1 -gt $num3 ];then
#tmp=$num1
#num1=$num3
#num3=$tmp
#fi
#if [ $num2 -gt $num3 ];then
#tmp=$num2
#num2=$num3
#num3=$tmp
#fi
#echo "排序为:$num1,$num2,$num3"

例子3:
#!/bin/bash
while :
do
load=`w|head -1|awk -F 'load average: ' '{print $2}'|cut -d'.' -f1`
if [ $load -gt 10 ]
then
top|mail -s "load is high:$load" load@163.com
fi
sleep 30
done

#其二种艺术:
#和煦的艺术,先3、2比较:大数下沉小数上浮;然后2、1比较:大数下沉小数上浮;最终3、2相比:大数下沉小数上浮,最后鲜明1、2、3几个数的顺序
#if [ $num3 -lt $num2 ];then
#     t=$num2
#     num2=$num3
#     num3=$t
#fi
#if [ $num2 -lt $num1 ];then
#     t=$num1
#     num1=$num2
#     num2=$t
#fi
#if [ $num3 -lt $num2 ];then
#     t=$num2
#     num2=$num3
#     num3=$t
#fi
#echo "排序为:$num1,$num2,$num3"

例子4:
#!/bin/bash
while read line
do
echo -e "\033[32m scp -r /root/learing/t8.sh root@$line:/tmp \033[0m"
done < ip.txt

#第三种办法:
#和下面的第二种沉思一致
#if [ $num2 -lt $num1 ];then
#   t=$num1
#   num1=$num2
#   num2=$t
#fi
#if [ $num3 -lt $num2 ];then
#   t=$num2
#   num2=$num3
#   num3=$t
#fi
#if [ $num2 -lt $num1 ];then
#   t=$num1
#   num1=$num2
#   num2=$t
#fi
#echo "排序为:$num1,$num2,$num3

例子5:
#!/bin/bash
while read line
do
echo $line
done </etc/hosts

**十一、批量变动文件名**

5)调用自定义函数
#!/bin/bash
ipaddress()
{
ifconfig |grep -A1 "$1"|tail -1|awk '{print $2}'|awk -F ':' '{print $2}'
}

#!/bin/bash
touch /opt/temp/{a,b,c,d,e,f}.txt
for i in `ls /opt/temp/*.txt`
do
  mv $i ${i%.*}.doc  #那边三个变量i后面无法用相对路线,为啥?
done

read -p "请输入网卡名字:" ipname
myip=`ipaddress $ipname`
echo "$ipname address is $myip"

**十二、ping命令**

6)使用八个指令
例子1:

#!/bin/bash
read -p "请输入ip地址:" ip
ping -c2 -i0.1 -W1 $ip   &> /dev/null
#ping -c2    ip  表示ping2次这些ip,c和2以内可以有空格
#ping -i0.1  ip  表示ping这一个ip的间隔时间0.1秒
#ping -W1    ip  表示ping那几个ip的过期时间1秒
if [ $? == 0 ];then
  echo "$ip 成功ping通"
else
  echo "$ip 未能ping通"
fi

#!/bin/bash

**十三、取6为私行密码**

DATE=`date`
echo "DATE is ${DATE}"

#!/bin/bash
X=abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789
pass=''
for i in {1..6}
do
  n=$[RANDOMb]    #26小写字母 26大写字母 拾个数字=62
  tmp=${X:$n:1}
  pass=${pass}$tmp
done
echo $pass

USERS=`who |wc -l`
echo "LOGIN in user is ${USERS}"

**十四、数列求和**

UP=`date;uptime`
echo "Uptime is ${UP}"

#!/bin/bash
read -p "请输入叁个正整数:" n
#n=${n:-100}
#sum=0
#for i in `seq $n`
#do
#  # let sum=($sum $i)
#  #  sum=$[$sum $i]
#   sum=$[sum i]
#done
#echo "从1到$n 的总额是:"$sum

例子2:

n=${n:-100}
i=1;sum=0
while [ $i -le $n ]
do
   let sum =i
   let i
done
echo "从1到$n 的总额是:"$sum

#!/bin/bash
#机械台数
machineNum=`ifconfig |grep -n '^[a-zA-Z0-9]'|wc -l`

**十五、增多客商**

#获得机器的机械名所在行和机器名
machineName=`ifconfig |grep -n 'Link encap'|awk -F' ' '{print $1}'|awk -F':' '{print $2}'`

#!/bin/bash
#先是段是相似增添客户
#read -p "请输入顾客名:" user
#[ -z $user ] && echo "请输入正确的客商名" && exit
#read -p "请输入密码:" pass
#[ -z $pass ] && echo "请输入准确的密码" && exit
#useradd $user
#echo $pass |passwd --stdin $user

#得到机器的机器名对应的IP地址
machineIP=`ifconfig |grep -n 'inet addr'|awk -F':' '{print $3}'|awk -F' ' '{print $1}'`

#其次段是丰盛客户时没有输入密码。会暗中同意给个默密码
#read -p "请输入客户名:" user
#read -p "请输入密码:" pass
#[ -z $user ] && exit
#pass=${pass:-123456}

for num in `seq 1 $machineNum`;
do
#`echo "$machineName"|sed -n '$num' p"`
n=`echo "$machineName"|sed -n "$num"p`
m=`echo "$machineIP"|sed -n "$num"p`
echo "机器$num:$n的IP地址是:$m";
done

#useradd $user
#echo $pass |passwd --stdin $user
**十六、超客商报告急察方**

7)读取文件内容
#!/bin/bash
for ip in `cat ip.txt`
do
echo $ip
./rsync.expect $ip ip.txt
done

#!/bin/bash
x=`who | wc -l`
[ x > 2 ] && echo "有人侵袭计算机啊!!!"|mail -s 'overuser' root

#crontab -e -u root /opt/jiaoben/useralert 可以用那么些周期安排义务监察和控制

**十七、远程非交互**

#!/bin/bash
rm -rf /root/.ssh/known_hosts     #全部曾经三番两次过的主机存储为那么些岗位,删掉后会>提醒未连接过的主机,要不要继续远程登入
expect << EOF
spawn ssh 172.25.0.10    
expect "continue" {send "yesn"}
expect "password" {send "redhatn"}
expect "#"      {send "touch /a.txtn"}
expect "#"      {send "exitn"}
EOF

#spawn代表将交互式的转会为非交互,expect代表希望出现一个值后,发送什么命令

**十八、中断**

#!/bin/bash
for i in {1..5}
do
   [ $i -eq 3 ] && continue
   echo $i
done
echo OK

#for i in {1..5}
#do
#   [ $i -eq 3 ] && break
#   echo $i
#done
#echo OK

#for i in {1..5}
#do
#   [ $i -eq 3 ] && exit
#   echo $i
#done
#echo OK

**二十、自动划分分区(待完善)**

#!/bin/bash
read -p "请输入你要分开的分区个数(暗许每种分区500M):" i
for $i in `seq $[i-1]`
do
    fdisk /dev/vdb << EOF
n
p
$[i 1]

500M
w
EOF
done

####亟待完善!!!!!#########

 

本文由星彩网app下载发布于星彩网app下载,转载请注明出处:shell流程语句使用介绍,分支与巡回结构

TAG标签: 星彩网app下载
Ctrl+D 将本页面保存为书签,全面了解最新资讯,方便快捷。