我正在编写一个脚本来恢复一组服务器上的主从复制。迷失在尝试分配本地变量的 bash 语法中,结果是远程运行的命令替换为本地值:
function doRemote() {
ssh s1.domain.com <<ENDSSH
mysql -u root -pXXX --execute="DROP DATABASE db; CREATE DATABASE db;"
mysql -u root -pXXX --database=db < $WORKDIR$FILENAME
sudo rm -rf /var/log/mysql/db-bin.*
mysql -u root -pXXX --execute="FLUSH LOGS;"
CURRENT_LOG=`mysql -u root -pXXX --execute="SHOW MASTER STATUS" -AN | awk '{print $1}'`
CURRENT_POS=`mysql -u root -pXXX --execute="SHOW MASTER STATUS" -AN | awk '{print $2}'`
# ...
ENDSSH
}
分配 CURRENT_* 变量的两行是问题所在:mysql -u...
命令在本地执行,而不是远程会话。
请建议如何远程运行该程序,用远程 mysql 命令的结果分配本地变量。
尝试逃跑ENDSSH
如下所示,以便变量评估发生在远程主机上:
ssh s1.domain.com <<\ENDSSH
# ...
ENDSSH
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)