您好,登录后才能下订单哦!
本篇内容介绍了“linux下Vps自动备份web和mysql数据库的脚本怎么写”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
一、备份web文件夹
1、备份/home/users/public_html目录
2、修改crontab为每周第一天3:22时运行
复制代码 代码如下:
22 3 * * 0 root run-parts /etc/cron.weekly
3、复制脚本到/etc/cron.weekly目录
4、修改权限
复制代码 代码如下:
chmod 0755 /etc/cron.weekly/webbackup.sh
5、脚本如下
复制代码 代码如下:
#!/bin/sh
filename=`date +%y%m%d`
backup_dir="/root/dropbox/backup/web"
#delete all files 10 days ago
find $backup_dir -mtime +30 -name "*" -exec rm -rf {} \;
#each user you want backup
users="baidu sina"
for user in ${users}; do
tar zcvf $backup_dir/$user$filename.tar.gz /home/$user/public_html
done
6、注意filename那句不是单引号,在tab键上方
7、要备份的用户的public_html目录,就把该用户填入users
二、mysql数据库每日备份
1、为了安全,新建用户backup,用强密码(自动生成即可),全局权限为select,lock tables
2、每日3:00开始执行,修改crontab
3、复制脚本到/etc/cron.daily
4、修改权限
5、脚本内容
复制代码 代码如下:
#!/bin/sh
dbuser="backup"
dbpassword="youpassword"
datas="db1 db2 db3"
filename=`date +%y%m%d`
bin_dir="/usr/local/mysql/bin"
backup_dir="/root/dropbox/backup/mysql"
#delete all files 10 days ago
find $backup_dir -mtime +10 -name "*" -exec rm -rf {} \;
#do each database backup
for data in ${datas}; do
$bin_dir/mysqldump --opt -u$dbuser -p$dbpassword $data | gzip > $backup_dir/$data$filename.sql.gz
done
6、同上一个第6条
7、要备份的数据库填入datas
“linux下Vps自动备份web和mysql数据库的脚本怎么写”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。