mysql创建数据库和用户脚本

mysql创建数据库和用户脚本

问题重写:

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

我错过了什么?

答案1

您缺少引号和正确的 mysql 客户端命令行:

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

您需要对 $SQL 变量周围的引号进行转义,以便将它们传递到远程 shell,否则它们将被本地 shell 解释(这就是为什么您会得到 DROP:未找到命令,分号是由 shell 解释的)。另外,要让 mysql 客户端执行命令,您必须传递 -e 命令行选项。

答案2

您已经将 $VARIABLES 括在引号中(这是很好的做法,并且考虑到了变量/文件名中的空格),但是您在整行中打开和关闭它们 - 这对于 BASH 变量赋值来说可以正常工作(尽管不推荐),但是当您使用 SSH 远程命令时,它会失败,因为它尝试执行变量,而不是您提供的引号括起来的字符串。正确的 SSH 命令将是:

ssh -p 8899 root@$REMOTEIP “mysql -u root -p $SQL”

因为该变量已经被用于传递参数的引号“引用”。

答案3

用 perl 和 DBI 代替 bash 可能更容易 - 不需要 fork mysql,控制力更强。此外,互联网上充斥着关于“如何做”的教程和示例 - 没有必要逆流而上 ;)

相关内容