我正在编写一个脚本来恢复一组服务器上的主从复制.在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
}
Run Code Online (Sandbox Code Playgroud)
分配CURRENT_*变量的两行是问题:mysql -u...命令在本地执行,而不是远程会话.
请建议如何远程运行,使用远程mysql命令的结果分配本地变量.
尝试转义ENDSSH如下所示,以便在远程主机上进行变量评估:
ssh s1.domain.com <<\ENDSSH
# ...
ENDSSH
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3948 次 |
| 最近记录: |