我正在为数据库编写备份脚本,并希望使用mysqlshell util.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命令作为更大脚本的一部分,还是我只是在这里浪费时间?
发布于 2021-07-16 08:26:16
好吧我想明白了。在主脚本中,我可以运行:
mysqlsh backup_user:<password>@127.0.0.1:3306 --file mysqlshell_backup.js
这意味着我可以从JS脚本中删除这一行(和\q)。
https://dba.stackexchange.com/questions/295710
复制相似问题