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的用户名和密码可能会带来安全风险,建议使用更安全的方式来存储和传递这些敏感信息。

相关推荐
DX_水位流量监测8 分钟前
大坝安全监测之渗流渗压位移监测设备技术解析
大数据·运维·服务器·网络·人工智能·安全
电商API&Tina9 分钟前
京东 API 数据采集接口接入与行业分析
运维·服务器·网络·数据库·django·php
Mr_Xuhhh1 小时前
博客标题:深入理解Shell:从进程控制到自主实现一个微型Shell
linux·运维·服务器
小小bugbug2 小时前
mysql查询的原始返回顺序与limit分页优化
mysql·adb
f***24114 小时前
高效自动化管理临时文件的技术方案
运维·自动化
m0_738120724 小时前
应急响应——知攻善防靶场Linux-1详细应急过程
linux·运维·服务器·网络·web安全·ssh
obboda4 小时前
磁盘管理(MBR、LVM)
运维·5g
kylezhao20194 小时前
S7-1200 CPU 与 S7-200 SMART S7通信(S7-1200 作为服务器)
运维·服务器
摸鱼仙人~5 小时前
大模型文章生成的风格个性化与多文体写作:一套可落地的方法论
linux·运维·服务器
xybDIY5 小时前
亚马逊云 Organizations 组织 Link 账号关联与解绑自动化解决方案
运维·自动化·云计算·aws