首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从bash脚本中执行mysqlshell?有可能吗?

从bash脚本中执行mysqlshell?有可能吗?
EN

Database Administration用户
提问于 2021-07-15 15:34:52
回答 1查看 599关注 0票数 2

我正在为数据库编写备份脚本,并希望使用mysqlshell util.dumpSchemas()实用程序。

但我怎么才能让它在shell脚本中工作呢?

我的基本流程是:

代码语言:javascript
复制
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

但是当我运行它时,我得到的都是错误:

代码语言:javascript
复制
SyntaxError: Invalid or unexpected token at mysqlshell_backup.js:2:0
in \connect backup_user:<password>@127.0.0.1:3306

但是,如果我手动运行代码,例如:

代码语言:javascript
复制
mysqlsh
MySQL  JS > \connect backup_user:<password>@127.0.0.1:3306

效果很好。

代码语言:javascript
复制
MySQL  127.0.0.1:3306 ssl  JS > 

我尝试通过添加以下内容使该文件成为它自己的可执行文件,并在其上运行它:

代码语言:javascript
复制
#!/usr/local/mysql-shell/bin/mysqlsh --file
\connect backup_user:<password>@127.0.0.1:3306
util.dumpSchemas(<options........>)
\q

但我得到了:

代码语言:javascript
复制
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命令作为更大脚本的一部分,还是我只是在这里浪费时间?

EN

回答 1

Database Administration用户

回答已采纳

发布于 2021-07-16 08:26:16

好吧我想明白了。在主脚本中,我可以运行:

mysqlsh backup_user:<password>@127.0.0.1:3306 --file mysqlshell_backup.js

这意味着我可以从JS脚本中删除这一行(和\q)。

票数 2
EN
页面原文内容由Database Administration提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://dba.stackexchange.com/questions/295710

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档