Linux中使用mysqldump对MySQL数据库进行定时备份

时间:2024-01-04 21:22:50
    #!/bin/bash
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin
export PATH
export LANG=en_US.UTF-
savedir=/log/database_bak/
cd "$savedir"
time="$(date +"%Y-%m-%d %H:%M:%S")"
mysqldump -u [my_user] -p[my_pwd] [db_name] > [db_name]-"$time".sql

这里注意以下-p后面没有空格直接加[my_pwd]

然后该sh脚本放入/log/sh/目录下并赋予执行权限,最后进入linux定时任务crond,加入以下脚本:

    # run-parts 每天5点02分执行databasebak.sh
* * * * root run-parts /etc/cron.hourly
* * * root run-parts /etc/cron.daily
* * root run-parts /etc/cron.weekly
* * root run-parts /etc/cron.monthly
* * * root sh /log/sh/databasebak.sh

最后保存好后重启crond,service crond restart即可!