2

書き直された質問:

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

私は何が欠けていますか?

4

2 に答える 2

3

引用符と適切なmysqlクライアントコマンドラインがありません。

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

$ SQL変数を囲む引用符をエスケープして、リモートシェルに渡されるようにする必要があります。そうしないと、ローカルシェルによって解釈されます(そのため、DROP:コマンドが見つかりません。セミコロンはシェルによって解釈されます)。 、mysqlクライアントにコマンドを実行させるには、-eコマンドラインオプションを渡す必要があります。

于 2009-11-03T12:20:07.383 に答える
0

これを試しましたか:

ssh -p 8899 root@$REMOTEIP "echo \"$SQL\" | mysql -u root --password=$SQL_PASS"
于 2009-11-03T12:20:31.933 に答える