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. array_pop()方法

    array_pop — 将数组最后一个单元弹出(出栈) 说明 mixed array_pop ( array &$array ) array_pop() 弹出并返回 array 数组的最后一个 ...

  2. remote desktop software

    remote desktop software remote desktop https://www.microsoft.com/zh-cn/p/microsoft-remote-desktop/9w ...

  3. sqlserver 比较两个表的列

    一.问题 给了两个各有四五十个列的表,找出他们相同的列和不同的列 二.查询两个表的列,存在临时表 --#a ,#b都是临时表,当前连接断开后自动删除--RANK() OVER (ORDER BY sy ...

  4. 【大数据】Spark性能优化和故障处理

    第一章 Spark 性能调优 1.1 常规性能调优 1.1.1 常规性能调优一:最优资源配置 Spark性能调优的第一步,就是为任务分配更多的资源,在一定范围内,增加资源的分配与性能的提升是成正比的, ...

  5. mininet invalid literal for int() with base 10: 'cpu.cfs_period_us:'

    问题产生原因:内核编译时没有加入 CONFIG_CFS_BANDWIDTH 选项 http://www.haifux.org/lectures/299/netLec7.pdf https://mail ...

  6. 【BZOJ1297】[SCOI2009]迷路(矩阵快速幂)

    [BZOJ1297][SCOI2009]迷路(矩阵快速幂) 题面 BZOJ 洛谷 题解 因为边权最大为\(9\),所以记录往前记录\(9\)个单位时间前的.到达每个点的方案数就好了,那么矩阵大小就是\ ...

  7. luogu1082 [NOIp2012]同余方程 (扩展欧几里得)

    由于保证有解,所以1%gcd(x,y)=0,所以gcd(x,y)=1,直接做就行了 #include<bits/stdc++.h> #define pa pair<int,int&g ...

  8. spring@Transactional的一点理解

    spring事务有7种传播行为,分别是: 1.PROPAGATION.REQUIRED:如果当前没有事务,就创建一个新事务,如果当前存在事务,就加入该事务,该设置是最常用的设置. 2.PROPAGAT ...

  9. saltstack主机管理项目【day23】:主机管理项目需求分析-设计

    本节内容 一. 主机管理项目需求分析 二 .主机管理项目架构设计 三.主机管理项目初始构建 四. 主机管理项目编主机分发器 一. 主机管理项目需求分析 场景:我现在又一台裸机要实现一下人物 配置管理: ...

  10. python---django中orm的使用(4)字段,参数(on_delete重点)补充,一对多,一对一,多对多

    1.索引: 普通索引:加快查找速度 唯一索引:加快查找速度,唯一约束 主键索引:加快查找速度,唯一索引,不为空 class UserInfo(models.Model): username = mod ...