Вопрос переписан:
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
Что мне не хватает?
Вы уже заключили $ VARIABLES в кавычки (что является хорошей практикой и учитывает пробелы в переменных / именах файлов), однако вы открываете и закрываете их по всей строке - это работает нормально (хотя и не рекомендуется) для назначения переменных BASH, но когда вы получаете удаленную команду SSH, она терпит неудачу, поскольку пытается выполнить переменную, а не заключенную в кавычки строку, которую вы указали. Правильная команда SSH будет такой:
ssh -p 8899 root @ $ REMOTEIP "mysql -u root -p $ SQL"
поскольку переменная уже "заключена в кавычки" для передачи аргумента.
Вам не хватает кавычек и правильной командной строки клиента mysql:
ssh -p 8899 root@$REMOTEIP "mysql -u root -p -e \"$SQL\""
Вам нужно избегать кавычек вокруг переменной $ SQL, чтобы они передавались в удаленную оболочку, иначе они интерпретируются локальной оболочкой (поэтому вы получаете DROP: команда не найдена, точка с запятой интерпретируется оболочкой). , чтобы клиент mysql выполнял команду, вам необходимо передать параметр командной строки -e.
Возможно, будет проще заменить bash на perl и DBI - не нужно форкнуть mysql, немного больше контроля. Также в интернет-сети полно учебных пособий и примеров «как это сделать» - нет смысла плыть на волнах;)