微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何在bash中捕获mysql错误

我有一个bash脚本,它从一个db导出一个表并将其导入另一个db.奇迹般有效.

但是,因为我想让它作为一个cronjob运行,我希望它发送一封电子邮件,以防万一我出错.但是如何判断我是否有错误,例如:

ERROR 1045 (28000): Access denied for user 'importuser'@'192.168.xxx.xxx' (using password: YES)

任何想法怎么做?这是关键段落:

MysqL --user=$rep_user --password=$rep_password --host=$rep_host --database=$rep_name < /tmp/${i}.sql

我已经试过了

    result=`MysqL --user=$rep_user --password=$rep_password --host=$rep_host --database=$rep_name < /tmp/${i}.sql`
    echo $result >> $EMAILMESSAGE

但它没有显示在我的$EMAILMESSAGE中

有谁知道如何实现这一目标?

解决方法:

我假设您的$EMAILMESSAGE变量已经初始化并保存文件的位置.如果是这样,您应该能够按如下方式获得结果(仅当命令失败时):

result=$(MysqL --user=$rep_user --password=$rep_password --host=$rep_host --database=$rep_name < /tmp/${i}.sql 2>&1 )
[ $? = 0 ] || echo $result >> $EMAILMESSAGE

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐