目录
编写shell脚本文件
db_user="数据库用户"
db_password="数据库密码"
db_name="需要备份的数据库名"
#the directory for story your backup file.you shall change this dir
backup_dir="/data/db_backup/mysql"
#date format for backup file (dd-mm-yyyy)
time="$(date +"%Y%m%d%H%M%S")"
mysqldump -u$db_user -p$db_passwd $db_name > $backup_dir/$db_name"_"$time.sql
参考:https://blog.csdn.net/u010565545/article/details/104218632
直接在windows系统上编写好.sh文件,然后放到linux上执行会报错:
百度之后发现应该是windows和Linux的换行符不同(windows是\r\n,而Linux是\n)导致的
参考https://blog.csdn.net/li_1303999/article/details/93159197
在windows编辑好的文件不可以使用,那就直接在linux上编辑脚本文件
vi db_backup.sh 编辑好文件,执行
chmod +x db_backup.sh
./db_backup.sh
输入数据库密码,查看对应目录是否有生成的sql文件
定时执行脚本文件
执行 crontab -e
进入计划任务编辑模式(类似vi编辑器,按键I进入编辑模式,esc退出编辑模式,:x保存):
输入(每天凌晨1点定时执行脚本文件)
去对应目录下查看是否有在定时时间生成的备份文件,比如 test_20210213115001.sql
cron表达式用法参考https://blog.csdn.net/u010565545/article/details/104218632