Shell脚本同时调用#!/bin/bash和#!/usr/bin/expect

如果你想在一个脚本中同时使用bash和expect,你可以将expect部分嵌入到bash脚本中。以下是一个示例:

复制代码
#!/bin/bash

# 设置MySQL服务器地址、端口、用户名和密码
MYSQL_HOST="localhost"
MYSQL_PORT="3306"
MYSQL_USER="your_username"
MYSQL_PASSWORD="your_password"

# 设置要执行的SQL命令
MYSQL_COMMAND="SHOW DATABASES;"

# 使用expect来自动化交互式的过程
expect << EOF
    # 使用spawn启动mysql命令行客户端
    spawn mysql -h $MYSQL_HOST -P $MYSQL_PORT -u $MYSQL_USER

    # expect会等待密码提示符出现,并自动输入密码
    expect "Enter password: "
    send "$MYSQL_PASSWORD\r"

    # 发送执行SQL命令的命令
    send "$MYSQL_COMMAND\r"

    # expect会等待结果返回,并将结果输出到屏幕
    expect "\r\n"

    # 将剩余的输出(如果有)发送到屏幕
    while {1} {
        expect {
            "\r\n" {
                send_user "\n"
                break
            }
            default {
                send_user "-"
                exp_continue
            }
        }
    }

    # 关闭spawned的进程
    expect eof
EOF

# 这里可以继续编写你的bash脚本内容
echo "Bash script continues here..."

在这个示例中,我们使用了bash来设置变量和调用expect。然后,我们使用<< EOFEOF来定义一个here文档,其中包含了expect的命令。这样,bash脚本就可以在执行expect命令后继续执行其他bash命令。

注意:在实际应用中,你可能需要根据你的具体需求来调整这个脚本,例如处理expect命令的输出或者错误等。同时,也要注意在脚本中直接写入MySQL的用户名和密码可能会带来安全风险,建议使用更安全的方式来存储和传递这些敏感信息。

相关推荐
Wang's Blog5 分钟前
Elastic Stack梳理:Logstash 高级数据处理与监控运维实战指南
运维·搜索引擎·elastic search
云和数据.ChenGuang7 分钟前
运维工程师免费技术教程之tomcat动态日志监控
运维·tomcat·firefox·运维工程师·运维技术
python百炼成钢20 分钟前
解决——linux通过网络挂载tftp无法下载
linux·运维·网络
无奈笑天下25 分钟前
银河麒麟高级服务器版本【更换bond绑定的网卡】操作方法
linux·运维·服务器·arm开发·经验分享
深海里的鱼(・ω<)★35 分钟前
CentOS 7 默认 yum 源官方不维护解决方案
linux·运维·centos
猫头虎-人工智能38 分钟前
openEuler远程批量部署实战 SSH VNC IPMI全流程解析
运维·git·开源·ssh·github·开放原子·开源软件
weixin_307779131 小时前
Jenkins Metrics 插件全解析:从数据采集到智能监控的实践指南
运维·开发语言·架构·jenkins
gavin_gxh1 小时前
SAP MM 采购订单号 excel上传 获取订单状态 审批 取消审批
运维·经验分享·其他
菜鸟小九1 小时前
mysql运维(读写分离)
运维·数据库·mysql
菜鸟小九1 小时前
mysql运维(分库分表)
运维·数据库·mysql