快照方式备份MySQL数据库及举例

作者: 红豆殺 日期: 2011 年 03 月 17 日发表评论7条评论查看评论
 

一、创建逻辑卷

依照如下连接的文档创建一个逻辑卷
要求:物理卷20G;卷组名为vg0;逻辑卷2G,逻辑卷名为mydata
创建逻辑卷挂载点,并挂载之
# mkdir /mydata
# mount /dev/vgo/mydata /mydata

二、安装MySQL数据库

如果机器已装有mysql,则此步可省略
只需修改mysql的配置文件中的datadir的值改为/mysata
然后将原数据库的数据文件全部copy至/mydata文件下,即转移数据库所在位置
修改/mydata目录及其内容的属主属组
然后重启mydql服务
如果需要重新安装,可依如下文档进行安装:
同样安装完成后,只需将mysql配置文件中的datadir的值改为/mydata
操作如下:
# sed -i ‘s/ ^datadir.*$/datadir=\/mydata/g’ /etc/my.cnf
# service mysqld restart
 
修改/mydata目录及其内容的属主属组
# chown -R mysql:mysql /mydata/*
# chown mydql:mysql /mydql
 
启动mysql服务
# service mysqld start

三、创建快照

锁定所有表先
# mydql
>FLUSH TABLES WITH READ LOCK;
>\q
 
创建快照
# pvvreat -L 20M -s -n mysnap /dev/vgo/mydata
注:此命令详细解释可参照如下文档:
解锁表
# mysql
>UNLOCK TABLES;
>\q
创建快照挂载点,并挂载之
# mkdir /mysnap
# mount /dev/vgo/mysnap
# ls
发现此时/mysnap目录下的文件和/mydata下的文件一模一样
此时,在原卷上做任何修改都不会影响/mysnap中的文件

四、测试

对数据库进行一些修改
# mysql
>CREATE DATABASE mydb;
>USE mydb;
>CREATE TABLE sanptest (
>name char(30),
>id   int);
>\q
现在从快照目录下复制mydb文件到其它目录下,进行物理备份
注:生产应用中应该备份整个数据库
 
# cd /mysanp
# cp -rp mydb  /tmp/
 
卸载快照卷
# umount /mysnap
# lvremove /dev/vgo/mysnap
 
下面对数据库进行一些删除操作
# mydql
>FLUSH LOGS;
>DROP DATABASE mydb;
>\q
此时,/mydata目录下已没有mydb文件
 
 
现在将刚才物理备份的的mydb文件复制回来
# copy -rp /tmp/mydb /mydata
# service mysqld restart
 
 
查看数据库
# mysql
>SHOW DATABASES;
发现和做修改之前的的数据库一模一样,没有刚创建的mydb库
也就是说快照备份只保存做快照那一时刻的数据信息
 
 
 
此时,若想找回快照之后失去的数据,刚需要用的二进制日志
查看二进制日志
# mysql
>SHOW BINLOG EVENTS IN’mysql-bin.0000X’;
这里X表示数据,数字不同,日志内容也不一样,数字越大越接近现在
这些日志全放在/mydata文件下
显示大致如下:

如我们想从二进制日志文件mysql-bin.0000013中恢复一个insert操作,就可以用如下命令:
# mysqlbinlog –start-position 106 –end-position 220 mysql-bin.0000013 > /tmp/a.mysql
# mysql -uroot -p < /tmp/a.sql
显示结果如下:

快照方式备份MySQL数据库及举例的更多相关文章

  1. ​学会用各种姿势备份MySQL数据库

    学会用各种姿势备份MySQL数据库 前言 为什么需要备份数据? 数据的备份类型 MySQL备份数据的方式 备份需要考虑的问题 设计合适的备份策略 实战演练 使用cp进行备份 使用mysqldump+复 ...

  2. Linux 每天自动备份mysql数据库的方法

    Linux 每天自动备份mysql数据库的方法 作者: 字体:[增加 减小] 类型:转载   linux下为了安全有时候需要自动备份mysql数据库,下面是具体的实现步骤.   /usr/bin为my ...

  3. linux下使用crontab定时备份MYSQL数据库的方法:

    摘要 linux下使用crontab定时备份MYSQL数据库的方法: 只需按照下面3步做,一切都在你的掌控之下: 第一步:在服务器上配置备份目录代码: ------------------------ ...

  4. 实现定时备份mysql数据库并把备份数据库邮件发送

    一.先来看备份mysql数据库的命令 1 mysqldump -u root --password=root --database abcDataBase > c:/abc_backup.sql ...

  5. Linux下定时备份MySQL数据库的Shell脚本

    Linux下定时备份MySQL数据库的Shell脚本   对任何一个已经上线的网站站点来说,数据备份都是必须的.无论版本更新还是服务器迁移,备份数据的重要性不言而喻.人工备份数据的方式不单耗费大量时间 ...

  6. 在生产环境下实现每天自动备份mysql数据库

    1.描述 我相信很多朋友在工作都都会有这种需求,老板或领导让你每天都要备份mysql数据库,你该如何实现呢,是每天到一定的时间在服务器上敲一遍mysql的备份命令,还是想写个脚本,定时定点的自动备份呢 ...

  7. 备份MySQL数据库并上传到阿里云OSS存储

    1. 环境配置 要将本地文件上传到阿里云oss中, 必须使用阿里云提供的工具 ossutil, 有32位,也有64位的, Linux和Windows都有.具体可以到阿里云官网下载 官网及文档: htt ...

  8. 如何在生产环境下实现每天自动备份mysql数据库

    1.描述 通"shell脚本+定时任务"的方式来实现自动备份mysql数据库. 2.环境 备份路径:/data/mysqlbak/ 备份脚本:/data/mysqlbak/mysq ...

  9. 批处理命令 BAT备份MySQL数据库

    批处理命令 BAT备份MySQL数据库 作者: 字体:[增加 减小] 类型:转载 时间:2009-07-23我要评论 MySQL数据的备份工具也许有很多,在这我要给大家分享一下通过DOS批处理命令和M ...

随机推荐

  1. PHP面向对象-设计模式 单例模式 简单工厂模式 工厂方法模式

    1.单例模式 单例模式是一种常用的软件设计模式.在它的核心结构中只包含一个被称为单例的特殊类.通过单例模式可以保证系统中一个类只有一个实例.即一个类只有一个对象实例. 要实现每一个类只有一个实例,就需 ...

  2. Openstack_通用模块_Oslo_vmware 创建 vSS PortGroup

    目录 目录 vSS vSSPG vSphere SDK 中相关的网络对象 创建 vSS PortGroup vSS & vSSPG vSS(Standard vSwitch 标准交换机) 为在 ...

  3. 红帽虚拟化RHEV3.2创建虚拟机(图文Step by Step)

    目录 目录 前言 Install RHEV 创建Data CenterClusterHost 创建存储 创建虚拟机 前言 RHEV3.2的Web管理界面有了很大的改进,更加的简单和便捷,还可以使用中文 ...

  4. LoadRunner之关联

    一.什么是关联 关联就是将服务器动态返回变化的值保存为一个参数以供后面需要用到的地方使用. 二.什么时候需要关联 1.服务器返回中存在动态变化的值,一般是类似session.token这样的无规则数据 ...

  5. Java多线程学习——synchronized锁机制

    Java在多线程中使用同步锁机制时,一定要注意锁对对象,下面的例子就是没锁对对象(每个线程使用一个被锁住的对象时,得先看该对象的被锁住部分是否有人在使用) 例子:两个人操作同一个银行账户,丈夫在ATM ...

  6. 根据select的option文本选中对应的选项

    function selectByOptionTxt(obj,txt){ var optionArr = $(obj).find("option"); for(var i=0;i& ...

  7. [Vim] 01 凡人操作

    历史评价 编辑器之神 一个凡人的自我修养 成神是不可能成神的,只能是先入个门,然后一点一点学 Vim 官网 三种模式 插入模式(注意看光标) 命令模式(注意看光标) 编辑模式(注意看光标) 其实还有一 ...

  8. [19/10/14-星期一] Python中的对象和类

    一.面向对象 ## 什么是对象? - 对象是内存中专门用来存储数据的一块区域. - 对象中可以存放各种数据(比如:数字.布尔值.代码) - 对象由三部分组成: 1.对象的标识(id) 2.对象的类型( ...

  9. kubernetes(k8s)容器编排工具基础概念

    Kubernetes (K8s): 中文社区:https://www.kubernetes.org.cn/replication-controller-kubernetes 官网:https://ku ...

  10. selectnodes和selectSingleNode

    selectnodes: selectNodes和ChildNodes获取XML内容数组的差异性 我们在使用XML进行查询或者变更数据的时候,需要注意两个很相近但结果相差很大的用法,如下: 1: Xm ...