Pregunta

Pregunta reescrita:

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""

A continuación, ejecute:

/root/testing/migratesite.sh

Y conseguir:

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

¿Qué me falta?

¿Fue útil?

Solución

Se le cotizaciones y una línea de comandos del cliente de MySQL adecuada echa en falta:

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

Es necesario para escapar de las comillas alrededor de la variable $ SQL para que se pasan a la shell remoto, de lo contrario va a interpretar por el shell local (por eso se obtiene DROP: comando no encontrado, el punto y coma se interpreta por el shell .) Además, para que el cliente de MySQL para ejecutar un comando que tiene que pasar la opción de línea de comandos -e.

Otros consejos

¿Usted intentó esto:

ssh -p 8899 root@$REMOTEIP "echo \"$SQL\" | mysql -u root --password=$SQL_PASS"
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top