问题改写为:

HOMEDIR="ftpuser"
REMOTEIP="1.1.1.1"
MYSQLPASS="password"

Q1="DROP USER "$HOMEDIR"_shop;"
Q2="DROP DATABASE "$HOMEDIR"_shop;"
Q3="CREATE DATABASE IF NOT EXISTS "$HOMEDIR"_shop;"
Q4="GRANT ALL ON "$HOMEDIR"_shop TO '"$HOMEDIR"_shop'@'localhost' IDENTIFIED BY '$MYSQLPASS';"
Q5="GRANT ALL ON "$HOMEDIR"_shop TO '"$HOMEDIR"_shop'@'anotherip' IDENTIFIED BY '$MYSQLPASS';"
# Need to grant permissions from another server as well
Q6="FLUSH PRIVILEGES;"
SQL="${Q1}${Q2}${Q3}${Q4}${Q5}${Q6}"

echo $SQL
echo " "
ssh -p 8899 root@$REMOTEIP "mysql -u root -p "$SQL""

我然后运行:

/root/testing/migratesite.sh

和得到:

bash: DROP: command not found
bash: CREATE: command not found
bash: GRANT: command not found
bash: GRANT: command not found
bash: FLUSH: command not found

我是什么失踪?

有帮助吗?

解决方案

您缺少报价和适当的MySQL客户端的命令行:

ssh -p 8899 root@$REMOTEIP "mysql -u root -p -e \"$SQL\""

您需要逃避周围$ SQL变量的报价,使他们获得通过到远程shell,否则他们得到本地shell解释(这就是为什么你DROP:命令没有找到,分号被shell解释)。另外,以具有MySQL客户端执行你必须通过-e命令行选项的命令。

其他提示

你试试这个:

ssh -p 8899 root@$REMOTEIP "echo \"$SQL\" | mysql -u root --password=$SQL_PASS"
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top