【发布时间】:2014-02-04 06:47:16
【问题描述】:
我正在编写一个脚本来恢复一组服务器上的主从复制。迷失在 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 命令的结果分配局部变量。
【问题讨论】:
-
使它适用于单行:
CURRENT_LOG=$(ssh s1.somain.com "mysql -u root -pXXX --execute=\"SHOW MASTER STATUS\" -AN | awk '{print \$1}'")