mysql erstellen Datenbank und Benutzerskript
Frage
Frage Rewritten:
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""
ich dann laufen:
/root/testing/migratesite.sh
Und bekommen:
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
Was bin ich fehlt?
Lösung
Sie fehlen Zitate und eine richtige MySQL-Client-Befehlszeile:
ssh -p 8899 root@$REMOTEIP "mysql -u root -p -e \"$SQL\""
Sie müssen die Anführungszeichen um das $ SQL-Variable zu entkommen, so dass sie an dem entfernt Shell übergeben bekommen, sonst sie von der lokalen Shell interpretiert bekommen (das ist, warum SieFormal DROP erhalten: Befehl nicht gefunden, das Semikolon von der Shell interpretiert wird auch.), um den mySQL-Client haben einen Befehl Sie müssen übergeben Sie die -e Befehlszeilenoption auszuführen.
Andere Tipps
Haben Sie versucht, dies:
ssh -p 8899 root@$REMOTEIP "echo \"$SQL\" | mysql -u root --password=$SQL_PASS"
Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow