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数据库并做远程备份容灾的更多相关文章

  1. shell脚本连接、读写、操作mysql数据库实例

    本文介绍了如何在shell中读写mysql数据库.主要介绍了如何在shell 中连接mysql数据库,如何在shell中创建数据库,创建表,插入csv文件,读取mysql数据库,导出mysql数据库为 ...

  2. Linux 用 shell 脚本 批量 导入 csv 文件 到 mysql 数据库

    前提: 每个csv文件第一行为字段名 创建的数据库字段名同csv 文件的字段名 1. 批量导入 多个 csv 文件 for file in ./*.csv;do mv $file tablename. ...

  3. Shell脚本中执行sql语句操作mysql的5种方法【转】

    对于自动化运维,诸如备份恢复之类的,DBA经常需要将SQL语句封装到shell脚本.本文描述了在Linux环境下mysql数据库中,shell脚本下调用sql语句的几种方法,供大家参考.对于脚本输出的 ...

  4. shell编程系列24--shell操作数据库实战之利用shell脚本将文本数据导入到mysql中

    shell编程系列24--shell操作数据库实战之利用shell脚本将文本数据导入到mysql中 利用shell脚本将文本数据导入到mysql中 需求1:处理文本中的数据,将文本中的数据插入到mys ...

  5. shell脚本专题之-----------全自动编译安装mysql

    mysql的编译安装,在博客 开源服务专题之--------mysql的编译安装 中已经说明了,但是还是比较麻烦,尤其是一大堆命令,来手动执行,稍有不慎,就会出错.生产上一般都是先在本地测试环境进行自 ...

  6. Shell脚本中执行sql语句操作mysql

    对于自动化运维,诸如备份恢复之类的,DBA经常需要将SQL语句封装到shell脚本.本文描述了在Linux环境下mysql数据库中,shell脚本下调用sql语句的几种方法,供大家参考.对于脚本输出的 ...

  7. shell脚本专题之-----------全自动编译安装mysql(免安装版)

    mysql的编译安装,在博客 开源服务专题之--------mysql的编译安装 中已经说明了,但是还是比较麻烦,尤其是一大堆命令,来手动执行,稍有不慎,就会出错.生产上一般都是先在本地测试环境进行自 ...

  8. SHELL脚本中执行SQL语句操作MYSQL的5种方法

    对于自动化运维,诸如备份恢复之类的,DBA经常需要将SQL语句封装到shell脚本.本文描述了在Linux环境下mysql数据库中,shell脚本下调用sql语句的几种方法,供大家参考.对于脚本输出的 ...

  9. mysql数据库每个表的备份脚本

    对mysql数据库中的每张表进行按日期备份,思想是:先把每张表的表名取出取出,然后通过for循环去对每个表进行按日期备份 [root@ZFVM-APP-- backup]# vim dataname. ...

随机推荐

  1. Beta阶段敏捷冲刺②

    1.提供当天站立式会议照片一张. 每个人的工作 (有work item 的ID),并将其记录在码云项目管理中: 1.1昨天已完成的工作. 姓名 昨天已完成的工作 徐璐琳 完成设置界面的排版 祁泽文 实 ...

  2. 从苦逼到牛逼,详解Linux运维工程师的打怪升级之路

    做运维也快四年多了,就像游戏打怪升级,升级后知识体系和运维体系也相对变化挺大,学习了很多新的知识点. 运维工程师是从一个呆逼进化为苦逼再成长为牛逼的过程,前提在于你要能忍能干能拼,还要具有敏锐的嗅觉感 ...

  3. OneZero第四周第五次站立会议(2016.4.15)

    1. 时间: 15:00--15:15  共计15分钟. 2. 成员: X 夏一鸣 * 组长 (博客:http://www.cnblogs.com/xiaym896/), G 郭又铭 (博客:http ...

  4. TCP 协议连接与关闭的握手

     原文链接 http://blog.csdn.net/oney139/article/details/8103223   TCP头部: 其中 ACK   SYN  序号  这三个部分在以下会用到,它们 ...

  5. C++11 自动推导auto

    C++11 自动推导auto C++11中引入的auto主要有两种用途:自动类型推导和返回值占位. auto在C++98中的标识临时变量的语义,由于使用极少且多余,在C++11中已被删除.前后两个标准 ...

  6. (NOI2014)(bzoj3669)魔法森林

    LCT裸题,不会的可以来这里看看. 步入正题,现将边按a排序,依次加入每一条边,同时维护路径上的最小生成树上的最大边权,如果两点不连通,就直接连通. 如果两点已经连通,就将该边与路径上较小的一条比较, ...

  7. 【BZOJ1025】[SCOI2009]游戏(动态规划)

    [BZOJ1025][SCOI2009]游戏(动态规划) 题面 BZOJ 洛谷 题解 显然就是一个个的置换,那么所谓的行数就是所有循环的大小的\(lcm+1\). 问题等价于把\(n\)拆分成若干个数 ...

  8. 解题:SDOI 2014 重建

    题面 做这个这个题需要稍微深入理解一点矩阵树定理:套矩阵树定理得到的东西是有意义的,它是“所有生成树边权乘积之和”(因为度数矩阵是点的边权和,邻接矩阵是边权),即$\sum_{t}\prod_{e∈t ...

  9. 置换群和Burnside引理,Polya定理

    定义简化版: 置换,就是一个1~n的排列,是一个1~n排列对1~n的映射 置换群,所有的置换的集合. 经常会遇到求本质不同的构造,如旋转不同构,翻转交换不同构等. 不动点:一个置换中,置换后和置换前没 ...

  10. 洛谷P3862 8月月赛B

    https://www.luogu.org/problemnew/show/P3862#sub P3862 8月月赛B 推公式:f(n)->f(n+1) 奇葩的预处理 https://www.l ...