centos6.5环境通过shell脚本备份php的web及mysql数据库并做远程备份容灾
centos6.5环境通过shell脚本备份php的web及mysql数据库并做远程备份容灾
系统:centos6.5
1.创建脚本目录
mkdir -p /usr/local/sh/
创建备份web文件存放目录
mkdir -p /data/backup/www/
创建备份db文件存放目录
mkdir -p /data/backup/db/
授权backup用户对所有数据库的操作权限(注意用来备份mysql数据库)
GRANT ALL PRIVILEGES ON *.* TO 'backup'@'localhost' IDENTIFIED BY 'pass';
2.编辑备份的脚本文件
vim /data/scripts/backup-web-db.sh
#!/bin/bash
#需备份的站点目录
Website_Dir1=www.chinasoft.com
Website_Dir2=www.yayachinasoft.com
#数据库备份用户名密码
MYSQL_UserName=backup
MYSQL_PassWord=pass
#需要备份的数据名
Backup_Database_Name1=yunva
Backup_Database_Name2=yayasdk
#FTP服务器信息
FTP_HostName=ftp_ip
FTP_UserName=web-backup
FTP_PassWord=pass
FTP_BackupDir=website-db-backup/yayachinasoft-yayachinasoft/
#Values Setting END!
#备份文件名
TodayWWWBackup=*-$(date +"%Y%m%d").tar.gz
TodayDBBackup=*-$(date +"%Y%m%d").sql
OldWWWBackup=*-$(date -d -3day +"%Y%m%d").tar.gz
OldDBBackup=*-$(date -d -3day +"%Y%m%d").sql
#备份站点源码
tar -zcf /data/backup/www/$Website_Dir1--$(date +"%Y%m%d").tar.gz -C /var/www/web $Website_Dir1
tar -zcf /data/backup/www/$Website_Dir2--$(date +"%Y%m%d").tar.gz -C /var/www/web $Website_Dir2
#备份数据库
mysqldump -u$MYSQL_UserName -p$MYSQL_PassWord $Backup_Database_Name1 > /data/backup/db/$Backup_Database_Name1-$(date +"%Y%m%d").sql
mysqldump -u$MYSQL_UserName -p$MYSQL_PassWord $Backup_Database_Name2 > /data/backup/db/$Backup_Database_Name2-$(date +"%Y%m%d").sql
#备份配置文件
#cp /etc/php.ini /tmp/conf/php
#cp -r /etc/ningx/* /tmp/conf/nginx
#删除旧的备份文件
rm -f /data/backup/www/$OldWWWBackup
rm -f /data/backup/db/$OldDBBackup
#上传备份文件夹到FTP服务器
cd /data/backup/
lftp $FTP_HostName -u $FTP_UserName,$FTP_PassWord << EOF
cd /$FTP_BackupDir/www
mrm $OldWWWBackup
mput www/$TodayWWWBackup
cd /$FTP_BackupDir/db/
mrm $OldDBBackup
mput db/$TodayDBBackup
bye
EOF
3.添加脚本执行权限
chmod +x /data/scripts/backup-web-db.sh
4.添加计划任务:
每天凌晨2点执行备份任务
crontab -e
#backup-web-db
00 02 * * * /bin/bash /data/scripts/backup-web-db.sh >/dev/null 2>&1
重启生效
systemctl restart crond
公司内部FTP服务;
调试:
手动测试ftp是否能够连接
lftp ftp_ip -u web-backup,pass
手动调试程序是否正常执行:
sh -x /data/scripts/backup-web-db.sh
FTP_HostName=ftp_ip
FTP_UserName=web-backup
FTP_PassWord=pass
FTP_BackupDir=website-db-backup/yayachinasoft-yayachinasoft/
centos6.5环境通过shell脚本备份php的web及mysql数据库并做远程备份容灾的更多相关文章
- shell脚本连接、读写、操作mysql数据库实例
本文介绍了如何在shell中读写mysql数据库.主要介绍了如何在shell 中连接mysql数据库,如何在shell中创建数据库,创建表,插入csv文件,读取mysql数据库,导出mysql数据库为 ...
- Linux 用 shell 脚本 批量 导入 csv 文件 到 mysql 数据库
前提: 每个csv文件第一行为字段名 创建的数据库字段名同csv 文件的字段名 1. 批量导入 多个 csv 文件 for file in ./*.csv;do mv $file tablename. ...
- Shell脚本中执行sql语句操作mysql的5种方法【转】
对于自动化运维,诸如备份恢复之类的,DBA经常需要将SQL语句封装到shell脚本.本文描述了在Linux环境下mysql数据库中,shell脚本下调用sql语句的几种方法,供大家参考.对于脚本输出的 ...
- shell编程系列24--shell操作数据库实战之利用shell脚本将文本数据导入到mysql中
shell编程系列24--shell操作数据库实战之利用shell脚本将文本数据导入到mysql中 利用shell脚本将文本数据导入到mysql中 需求1:处理文本中的数据,将文本中的数据插入到mys ...
- shell脚本专题之-----------全自动编译安装mysql
mysql的编译安装,在博客 开源服务专题之--------mysql的编译安装 中已经说明了,但是还是比较麻烦,尤其是一大堆命令,来手动执行,稍有不慎,就会出错.生产上一般都是先在本地测试环境进行自 ...
- Shell脚本中执行sql语句操作mysql
对于自动化运维,诸如备份恢复之类的,DBA经常需要将SQL语句封装到shell脚本.本文描述了在Linux环境下mysql数据库中,shell脚本下调用sql语句的几种方法,供大家参考.对于脚本输出的 ...
- shell脚本专题之-----------全自动编译安装mysql(免安装版)
mysql的编译安装,在博客 开源服务专题之--------mysql的编译安装 中已经说明了,但是还是比较麻烦,尤其是一大堆命令,来手动执行,稍有不慎,就会出错.生产上一般都是先在本地测试环境进行自 ...
- SHELL脚本中执行SQL语句操作MYSQL的5种方法
对于自动化运维,诸如备份恢复之类的,DBA经常需要将SQL语句封装到shell脚本.本文描述了在Linux环境下mysql数据库中,shell脚本下调用sql语句的几种方法,供大家参考.对于脚本输出的 ...
- mysql数据库每个表的备份脚本
对mysql数据库中的每张表进行按日期备份,思想是:先把每张表的表名取出取出,然后通过for循环去对每个表进行按日期备份 [root@ZFVM-APP-- backup]# vim dataname. ...
随机推荐
- Beta阶段敏捷冲刺②
1.提供当天站立式会议照片一张. 每个人的工作 (有work item 的ID),并将其记录在码云项目管理中: 1.1昨天已完成的工作. 姓名 昨天已完成的工作 徐璐琳 完成设置界面的排版 祁泽文 实 ...
- 从苦逼到牛逼,详解Linux运维工程师的打怪升级之路
做运维也快四年多了,就像游戏打怪升级,升级后知识体系和运维体系也相对变化挺大,学习了很多新的知识点. 运维工程师是从一个呆逼进化为苦逼再成长为牛逼的过程,前提在于你要能忍能干能拼,还要具有敏锐的嗅觉感 ...
- OneZero第四周第五次站立会议(2016.4.15)
1. 时间: 15:00--15:15 共计15分钟. 2. 成员: X 夏一鸣 * 组长 (博客:http://www.cnblogs.com/xiaym896/), G 郭又铭 (博客:http ...
- TCP 协议连接与关闭的握手
原文链接 http://blog.csdn.net/oney139/article/details/8103223 TCP头部: 其中 ACK SYN 序号 这三个部分在以下会用到,它们 ...
- C++11 自动推导auto
C++11 自动推导auto C++11中引入的auto主要有两种用途:自动类型推导和返回值占位. auto在C++98中的标识临时变量的语义,由于使用极少且多余,在C++11中已被删除.前后两个标准 ...
- (NOI2014)(bzoj3669)魔法森林
LCT裸题,不会的可以来这里看看. 步入正题,现将边按a排序,依次加入每一条边,同时维护路径上的最小生成树上的最大边权,如果两点不连通,就直接连通. 如果两点已经连通,就将该边与路径上较小的一条比较, ...
- 【BZOJ1025】[SCOI2009]游戏(动态规划)
[BZOJ1025][SCOI2009]游戏(动态规划) 题面 BZOJ 洛谷 题解 显然就是一个个的置换,那么所谓的行数就是所有循环的大小的\(lcm+1\). 问题等价于把\(n\)拆分成若干个数 ...
- 解题:SDOI 2014 重建
题面 做这个这个题需要稍微深入理解一点矩阵树定理:套矩阵树定理得到的东西是有意义的,它是“所有生成树边权乘积之和”(因为度数矩阵是点的边权和,邻接矩阵是边权),即$\sum_{t}\prod_{e∈t ...
- 置换群和Burnside引理,Polya定理
定义简化版: 置换,就是一个1~n的排列,是一个1~n排列对1~n的映射 置换群,所有的置换的集合. 经常会遇到求本质不同的构造,如旋转不同构,翻转交换不同构等. 不动点:一个置换中,置换后和置换前没 ...
- 洛谷P3862 8月月赛B
https://www.luogu.org/problemnew/show/P3862#sub P3862 8月月赛B 推公式:f(n)->f(n+1) 奇葩的预处理 https://www.l ...