Cal*_*ane 4 mysql bash mysqldump
我有一个bash脚本,它从一个db导出一个表并将其导入另一个db.奇迹般有效.
但是,因为我想让它作为一个cronjob运行,我希望它发送一封电子邮件,以防万一我出错.但是我怎么知道我是否有错误,例如:
ERROR 1045 (28000): Access denied for user 'importuser'@'192.168.xxx.xxx' (using password: YES)
Run Code Online (Sandbox Code Playgroud)
任何想法怎么做?这是关键段落:
mysql --user=$rep_user --password=$rep_password --host=$rep_host --database=$rep_name < /tmp/${i}.sql
Run Code Online (Sandbox Code Playgroud)
我已经试过了
result=`mysql --user=$rep_user --password=$rep_password --host=$rep_host --database=$rep_name < /tmp/${i}.sql`
echo $result >> $EMAILMESSAGE
Run Code Online (Sandbox Code Playgroud)
但它没有显示在我的$ 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
Run Code Online (Sandbox Code Playgroud)