1122Shell脚本之利用mysqldump备份MySQL数据库
- #!/bin/bash
- #Mysql 自动备份 压缩并上传到 指定ftp
- #设想每天凌晨3点备份mysql
- #编辑crontab配置文件
- #00 03 * * * backupmysql.sh
- #压缩并以“服务器名+时间 ”命名打包文件
- #数据量小的情况下以mail的方式发送到指定邮箱(需要建立sendmail服务)
- #数据量大的情况下以ftp的方式传送到指定的ftp服务器(远程ftp需开启)
- #linzhanghui.blog.chinaunix.net
- #程序部分以伪代码方式存在。
- #
- #1.设置mysql登陆参数
- dbuser=root
- dbpassword=123456
- dbserver=localhost
- dbname=cacti
- dbopt=--opt
- backupdir=/tmp/dbbackup/
- #2.设置ftp具体参数
- ftpserver=192.168.137.3
- ftpuser=userlin
- ftppassword=passwdlin
- #3.设置文件备份文件名,备份文件保存天数
- fileprefix=lzhserver
- dumpfilename=$backupdir$fileprefix`date -d now +%Y%m%d`.sql
- newfile=$fileprefix-`date -d now +%Y%m%d`.tar.gz
- keepdays=7
- #4.写入操作到日志文件(事先需建立)
- logfile=/var/log/mysqlbackup.log
- logtmp=/var/log/mybackup.tmp
- #=====如果没有备份文件夹则建立之======
- if [ ! -d "$backupdir" ];
- then
- echo "无此文件夹,建立中..."
- mkdir -p $backupdir
- fi
- #=====事先删除7天之前的备份数据库文件=====
- echo "开始执行备份...">>$logfile
- echo "删除保留天数之前的备份文件...">>$logfile
- find $backupdir -name $fileprefix* -mtime +$keepdays -fls $logtmp -exec rm {};
- echo "删除的备份文件:">>$logfile
- cat $logtmp >>$logfile
- echo "删除旧备份文件成功!" >>$logfile
- #=====备份+打包======
- if [ -f $backupdir$newfile ]
- then
- echo "$newfile 备份文件存在, 备份结束 ...">>$logfile
- else
- if [ -z $dbpasswd ]
- then
- mysqldump -u$dbuser -h$dbserver $dbopt $dbname >$dumpfilename
- else
- mysqldump -u$dbuser -p$dbpasswd -h$dbserver $dbopt $dbname >$dumpfilename
- fi
- tar czvf $backupdir$newfile $dumpfilename
- echo "$backupdir$newfile 备份成功!+“$压缩包容量”">>$logfile
- fi
- #======以ftp方式发送=====
- ftp -i -n <<end_ftp
- open $ftpserver
- user $ftpuser $ftppassword
- lcd $backupdir
- hash
- prompt
- put $newfile
- close
- bye
- end_ftp
1122Shell脚本之利用mysqldump备份MySQL数据库的更多相关文章
- 利用xtrabackup备份mysql数据库
利用xtrabackup备份mysql数据库 一.安装1.直接下载二进制文件wget http://www.percona.com/downloads/XtraBackup/XtraBackup-2. ...
- 利用mysqldump备份mysql
mysqldump备份机制:通过给定的参数信息和系统表数据,来一张表一张表地获取数据并生成insert语句插入备份文件中,这样由于时间点不一致,就会导致数据不一致,然而对于一个要求强一致性的系统来说, ...
- mysqldump - 备份 MySQL 数据库
参考资料 备份 备份所有数据库中的所有数据(包括系统数据库) –all-databases 通过 --all-databases 选项备份所有的数据库: mysqldump -uroot -p --a ...
- 利用mysqldump备份magento数据库
在Magento开发和维护过程中,经常需要将Magento的数据库导出.导入,这些工作可以通过mysqldump这个工具来实现. 下面我来简单介绍一下mysqldump在导出导入Magento dat ...
- Linux自动备份MySQL数据库脚本代码
下面这段Linux的Shell脚本用于每日自动备份MySQL数据库,可通过Linux的crontab每天定时执行 在脚本中可设置需要备份的数据库表清单,并且会将备份文件通过gzip压缩.需要注意的是, ...
- Linux下自动备份MySQL数据库并上传到远程FTP服务器
Linux下自动备份MySQL数据库并上传到远程FTP服务器且删除指定日期前的备份Shell脚本 说明: 1.备份MySQL数据库存放目录/var/lib/mysql下面的xshelldata数据库 ...
- 一个备份MySQL数据库的简单Shell脚本(转)
Shell脚本是我们写不同类型命令的一种脚本,这些命令在这一个文件中就可以执行.我们也可以逐一敲入命令手动执行.如果我们要使用shell脚本就必须在一开始把这些命令写到一个文本文件中,以后就可以随意反 ...
- [转]一个备份MySQL数据库的简单Shell脚本
本文翻译自 iSystemAdmin 的 <A Simple Shell Script to Backup MySQL Database> Shell脚本是我们写不同类型命令的一种脚本,这 ...
- 一个备份mysql 数据库的脚本
# 获取当前系统日期,格式为: 2009-2-21DATE=`date "+%F"` # 定义mysql 服务的主目录 DB_DIR=/usr # 定义备份后的路径BAK_DIR= ...
随机推荐
- Linux系统NFS网络文件系统
Linux系统NFS网络文件系统 NFS(network file system)网络文件系统,就是通过网络让不同的主机系统之间可以共享文件或目录,此种方法NFS客户端使用挂载的方式让共享文件或目录到 ...
- iOS - 详细理解KVC与KVO
详细理解KVC与KVO 在面试的时候,KVC与KVO有些时候还是会问到的,并且他们都是Objective C的关键概念,在这里我们先做一个简单地介绍: (一)KVC: KVC即指:NSKeyValue ...
- Android自定义控件7--自定义开关--绘制界面内容
本文实现全自定义控件--自定义开关 本文地址:http://www.cnblogs.com/wuyudong/p/5922316.html,转载请注明源地址. 自定义开关 (View),本文完成下面内 ...
- Java打印九九乘法表
package com.czgo; /** * 九九乘法表 * * @author AlanLee * */ public class Print99 { public static void mai ...
- [css]我要用css画幅画(六)
接着之前的[css]我要用css画幅画(五), 由于这个画已经画了很久了,这次一次性加了比较多更新,算是让这幅画告一段落吧. 本次的更新包括: 1. 给云增加动画 2. 画了一棵树 3. 树上画了一个 ...
- 此实现不是 Windows 平台 FIPS 验证的加密算法的一部分的解决办法方案
最近操作系统不断地报异常或错误,可能是用得太久了,而刚好工作比较多又不想重新安装系统,但用一段时间后(一天大概有两次)系统就出现各种问题导致无法继续使用真是痛苦万分啊,今天又来了这样的错误: 此实现不 ...
- C# Attribute学习
由于项目中需要使用到序列化相关的技术,从而想到是否可以使用C#中的特性,特此花了近两小时学习了一下. 对于特性的学习,主要参考了两篇博文,特此感谢.以下附链接: http://www.cnblogs. ...
- C、C++: 引用、指针、实例、内存模型、namespace
// HelloWorld.cpp : Defines the entry point for the console application. // #include "stdafx.h& ...
- SQL Update:使用一个表的数据更新另一张表
表结构 功能 用表B的数据(mc列)更新表A的mc列 SQL Server update A SET A.mc = b.mc FROM A ,B WHERE A.bmbh = B.bmbh and A ...
- 带你一步步的了解“C#事件”机制
是什么 本文讨论类型中定义的最后一种成员:事件 定义了时间成员的类型允许类型通知其他对象发生了特定的事情. 具体的说,定义了时间成员的类型能提供以下功能: 方法能登记它对事件的关注 方法能注销它对事件 ...