我正在为数据库编写备份脚本并想使用 mysqlshellutil.dumpSchemas()
实用程序。
但是我到底怎样才能让它在 shell 脚本中工作呢?
我的基本流程是这样的:
filename_1: backup.sh
. . .
mysqlsh --file mysqlshell_backup.js
filename_2: mysqlshell_backup.js
\connect backup_user:<password>@127.0.0.1:3306
util.dumpSchemas(<options........>)
\q
但是当我运行它时,我得到的只是错误:
SyntaxError: Invalid or unexpected token at mysqlshell_backup.js:2:0
in \connect backup_user:<password>@127.0.0.1:3306
但如果我手动运行代码,例如:
mysqlsh
MySQL JS > \connect backup_user:<password>@127.0.0.1:3306
它工作正常。
MySQL 127.0.0.1:3306 ssl JS >
我尝试使该文件本身成为可执行文件,并通过添加以下内容自行运行它:
#!/usr/local/mysql-shell/bin/mysqlsh --file
\connect backup_user:<password>@127.0.0.1:3306
util.dumpSchemas(<options........>)
\q
但后来我得到:
mysqlshell_backup.js: line 2: connect: command not found
mysqlshell_backup.js: line 3: syntax error near unexpected token `[<options>],'
mysqlshell_backup.js: line 3: `util.dumpSchemas(<options>)
但同样,如果我直接从 mysqlshell 中运行它,代码工作正常,所以我知道没有语法错误。
实际上有没有办法将 mysqlshell 命令作为更大脚本的一部分运行,或者我只是在这里浪费时间?
好的,我想通了。在主脚本中,我可以运行:
mysqlsh backup_user:<password>@127.0.0.1:3306 --file mysqlshell_backup.js
这意味着我可以
\q
从 JS 脚本中删除该行(和 )。