快照方式备份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. Git-Runoob:Git 基本操作

    ylbtech-Git-Runoob:Git 基本操作 1.返回顶部 1. Git 基本操作 Git 的工作就是创建和保存你项目的快照及与之后的快照进行对比.本章将对有关创建与提交你的项目快照的命令作 ...

  2. PostgreSQL 实现按月按年,按日统计 分组统计

    endtime 是 timestamp select to_char(endtime, 'YYYY-MM-DD') as d , count(objectid) FROM sde.polygon wh ...

  3. 阶段3 1.Mybatis_03.自定义Mybatis框架_5.自定义Mybatis的编码-创建两个默认实现类并分析类之间的关系

    把XMLConfigBuilder的包名补全 这样我们就可以调用里面的loadConfiguration方法了 创建工厂实现类 实现SqlSessionFactory的接口 实现接口里面的方法 把cf ...

  4. WebMvcConfigurer 与 WebMvcConfigurationSupport避坑指南

    我们知道,在Spring Boot 2.0后用自己的的配置类继承WebMvcConfigurerAdapter时,idea会提示这个类已经过时了. 通常情况下我们会采用下面两种代替方案: 实现WebM ...

  5. 修改jupyter notebook默认路径,亲测

    anaconda环境 任务栏中找到anaconda/jupyter notebook,鼠标右键属性 点击确认即可.

  6. VM CentOS建立共享文件夹实现VS Code在windows环境下go开发,在centos环境里编译

    简介 笔记本没办法更换系统,但是开发又必须在linux环境下进行,直接在vm界面环境下开发,卡的都蒙13.无奈之下想到这个法子,来解决现有尴尬的局面>>> 共分3个部分安装: (1) ...

  7. springboot项目中使用maven resources

    maven resource 组件可以把pom的变量替换到相关的resouces目录中的资源文件变量 示例项目:内容中心 (文章管理)  生成jar包,生成docker ,生成k8s文件 1.项目结构 ...

  8. Oracle 查看一个数据库实例下面所有的表大小

    1. 因为 oracle有一些 lob字段 在user_extents 里面取出来的结果不是表名, 所以需要与user_lobs 表做关联查询才可以 本来想通过 关联查询来实现, 发现字表查询更简单 ...

  9. 关于XML的一些事

    XML:可扩展标记语言! 01.很像HTML 02.着重点是数据的保存 03.无需预编译 04.符合W3C标准 可扩展:我们可以自定义,完全按照自己的规划来! 标记:计算机所能认识的信息符号! 比如: ...

  10. Python入门之format()方法

    在此列出format()方法的一些基本使用: >>> '{}{}{}'.format('圆周率是',3.1415926,'...') '圆周率是3.1415926...' >& ...