mysql脚本文件捕捉错误_在bash脚本中捕获mysqldump错误

用户试图改进mysqldump脚本,以便在备份数据库时不仅能输出成功或失败的消息,还能捕获并附加实际的错误信息到日志文件。当前的问题是,错误输出覆盖了日志文件的其他内容,并且错误检查不正确。用户寻求一种方法来:a)获取mysqldump的详细错误信息,b)追加到现有日志,c)在输出错误后仍然能显示备份是否成功。
摘要由CSDN通过智能技术生成

我目前正在尝试编写一个脚本来备份我的几个站点及其数据库.

一切都运行良好,但我正在尝试对我的日志有点聪明 – 基本上,目前它将尝试运行mysqldump并将回应成功或失败.

我宁愿做的是输出实际的错误而不仅仅是一个无用的’mysqldump failed’消息.我已经浏览了一下,我几乎可以这样做,我想要使用“2> log_file.txt”

我原来的命令:

mysqldump -u asdsa --password=$DB_PASS $DB_NAME > $MYSQL_LOCATION

if [ "$?" -eq 0 ]

then

echo -e "mysqldump successfully finished at $(date +'%d-%m-%Y %H:%M:%S')"$'\r' >> "$LOG_LOCATION"

else

echo -e "mysqldump failed at $(date +'%d-%m-%Y %H:%M:%S')"$'\r' >> "$LOG_LOCATION"

fi

所以我添加了“2> $LOG_LOCATION |”抓住实际的错误.所以我更新的命令看起来像这样(这个添加在第一行):

mysqldump -u $DB_USER--password=$DB_PASS $DB_NAME 2> $LOG_LOCATION | > $MYSQL_LOCATION

if [ "$?" -eq 0 ]

then

echo -e "mysqldump successfully finished at $(date +'%d-%m-%Y %H:%M:%S')"$'\r' >> "$LOG_LOCATION"

else

echo -e "mysqldump failed at $(date +'%d-%m-%Y %H:%M:%S')"$'\r' >> "$LOG_LOCATION"

fi

这会将错误输出到我的日志文件中,但会覆盖其中的任何内容.这也意味着我的错误检查if语句没有收到错误.

有什么方法可以:

a)从mysqldump函数中捕获实际错误(即该用户拒绝访问)

b)将此错误附加到现有错误日志

c)在输出上述错误后还附加成功或失败消息

任何帮助都会很棒!

谢谢!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值