shell 流程控制

Posted love2

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了shell 流程控制相关的知识,希望对你有一定的参考价值。

一、条件语句 if

1.1、单分支
if [ 1 -eq 1 ];then
        echo "haha"
fi
1.2、双分支
if [ 1 -eq 2 ];then
        echo "haha"
else
        echo "shadan"
fi
1.3、多分支
if [ 1 -eq 2 ];then
        echo "haha"
elif [ 1 -eq 1 ];then
        echo "123"
else
        echo "shadan"
fi
脚本1,yum源,防火墙配置
#!/bin/bash
str=`cat /etc/redhat-release |awk '{print $4}'|awk -F '.' '{print $1}'`
version=0
mkdir /etc/yum.repos.d/bak &>/dev/null
mv /etc/yum.repos.d/* /etc/yum.repos.d/bak/ &>/dev/null
if [ $str == 7 ];then
    version=7
else
    version=6
fi
echo $version
if [ $version -eq  7 ];then
    #关闭防火墙及开机自启
    systemctl stop firewalld
    systemctl disable firewalld
    #关闭selinux
    setenforce 0
    sed -i 7s/enforcing/disabled/g /etc/selinux/config
    wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
    #配置yum源
    wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo
elif [ $version -eq 6 ];then
    #关闭防火墙及开机自启
    iptables -F
    service iptables stop
    chkconfig iptables off
    #关闭selinux
    setenforce 0
    sed -i 7s/enforcing/disabled/g /etc/selinux/config
    #配置yum源
    wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-6.repo
    wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-6.repo
else
    echo "please check your /etc/redhat-release file "
fi
yum clean all
yum makecache

二、条件语句 case

2.1、格式
case    变量  in  
    匹配条件1)                  
        命令序列    1
                ;;  
    匹配条件2)                  
        命令序列    2
                ;;  
    匹配条件3)                  
        命令序列    3
                ;;  
           *)                   
        ?匹配后命令列 
esac
脚本1,批量删除用户
#!/bin/bash
 while true
 do
    read -p "请输入你要删除的账户前缀>> " delname
    read -p "请输入你要删除的账户数量>> " delnum
    echo  "你将删除如下账户:
            用户前缀是: $delname
            用户数量是: $delnum"
    read -p "你确定要删除(y|yes/n|no)?" ch
    case $ch in
        y|yes)
            for i in `seq $delnum`
                do
                    username=$delname$i
                    id $username &>/dev/null
                        if [ $? -eq 0 ];then
                            userdel -r $username
                            echo "删除成功 $username"
                        else
                            echo "没有该用户 $username"
                        fi
                done
            break
            ;;
        n|no)
            echo "取消删除"
            exit 1
            ;;
        *)
            echo "错误输入,请重新输入"
    esac
done
脚本2,系统命令工具箱
#!/bin/bash
menu(){
cat << EOF
    =====================system info====================
                h、显示帮助命令
                f、显示磁盘分区
                d、显示磁盘挂载
                m、查看内存使用
                u、查看系统负载
                q、退出脚本
    =====================system info====================
EOF
}
menu
while true
do
read -p "请输入对应序号>> " ch
    case $ch in 
        h)
        clear
        menu
        ;;
        f|d)
        lsblk
        ;;
        m)
        free -h
        ;;
        u)
        uptime 
        ;;
        q)
        exit
        ;;
        *)
        echo "error input"
        
    esac
done

三、交互脚本expect

执行某些命令时,需要回答,例如 ssh登录 需要输入yes和密码

[root@localhost ~]# ssh root@100.100.100.101
The authenticity of host '100.100.100.101 (100.100.100.101)' can't be established.
ECDSA key fingerprint is SHA256:O84EC9RloVc32hoAxnpkn29AX9kM4z+xMgZ3h1CJkj8.
ECDSA key fingerprint is MD5:a8:2c:88:fd:64:2f:ad:8d:69:75:37:b9:19:2c:8c:57.
Are you sure you want to continue connecting (yes/no)? yes 
Warning: Permanently added '100.100.100.101' (ECDSA) to the list of known hosts.
root@100.100.100.101's password: 
Last failed login: Tue Jan 28 02:10:31 CST 2020 on tty1
There was 1 failed login attempt since the last successful login.
Last login: Mon Jan 27 22:23:10 2020
3.2 我们使用 expect 完成上述操作
!/bin/expect
spawn  ssh root@100.100.100.101
expect {
    "yes/no" {send "yes
";exp_continue}
    "password" {send "123
"}
}
interact 显示执行过程
expect "#" 当出现 # 号符执?行行如下命令 
    send "echo haha
"
    send "exit
"
expect eof

注意,不能使用 bash执行,而是赋予权限,使用 source 脚本名 或者 ./脚本名 执行

脚本,使用 expect 进行密钥对分发
#!/bin/bash
#获取当前网段可用ip
read -p "请输入网段..." ip_pre
rm -rf ip.txt &>/dev/null
for i in {1..254}
do
    {
    ip=$ip_pre.$i
    ping -c1 -w1 $ip >/dev/null
    if [ $? -eq 0 ];then
        echo "$ip"|tee -a ip.txt
   fi
}&
done
wait

#生成密钥对
if [ ! -f ~/.ssh/id_rsa ];then
        ssh-keygen -P "" -f ~/.ssh/id_rsa
fi

#使用expect分发密钥
while read line
do
        /usr/bin/expect <<-EOF
        spawn   ssh-copy-id     $line   -f
        expect  {
                "yes/no" {send  "yes
";exp_continue}
                "password" {send "123
"}
                }
        expect eof
        EOF
done<ip.txt

以上是关于shell 流程控制的主要内容,如果未能解决你的问题,请参考以下文章

shell编程中的流程控制语句

shell编程进阶

Shell 流程控制

shell--8Shell 流程控制

Shell流程控制

Shell 流程控制