> 数据库 > MySQL >

linux中使用mysqldump对mysql数据库进行定时备份

Shell代码  
  1. #!/bin/bash  
  2. PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin  
  3. export PATH  
  4. export LANG=en_US.UTF-8  
  5. savedir=/log/database_bak/  
  6. cd "$savedir"  
  7. time="$(date +"%Y-%m-%d %H:%M:%S")"  
  8. mysqldump -u [my_user] -p[my_pwd] [db_name] > [db_name]-"$time".sql  

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

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

 

Shell代码  
  1. # run-parts 每天502分执行databasebak.sh  
  2. 01 * * * * root run-parts /etc/cron.hourly  
  3. 02 4 * * * root run-parts /etc/cron.daily  
  4. 22 4 * * 0 root run-parts /etc/cron.weekly  
  5. 42 4 1 * * root run-parts /etc/cron.monthly  
  6. 02 5 * * * root sh /log/sh/databasebak.sh  

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

 
 
(责任编辑:IT)