mysql恢复和备份

一、在这里先介绍一下LVM备份mysql数据库的优点:

1、在大多数情况下,这种方式几乎算得上是热备。它无需关闭服务,只需要设置只读或者类似这样的限制。

2、支持所有基于本地磁盘的存储引擎,比如MYISAM、InnoDB和BDB,还支持Solid、PrimeXT和Faction。

3、备份速度最快,因为你只需要拷贝相关的二进制数据文件即可。

4、由于只是简单的拷贝文件,因此对服务器开销非常低。

5、保存方式多种多样,你可以备份到磁带上、FTP服务器上、NFS服务器上或者其他什么网络服务器,以及使用各种网络备份软件来备份。做到这些很简单,说到底就是拷贝文件而已。

6、恢复速度很快。恢复所需要的时间等于你把数据拷贝回来的时间。你可以想出更多的方法让这个时间变得更短。

7、无需使用昂贵的商业软件。

二、前期准备-----LVM(逻辑分区管理)中的几个概念:

mysql恢复和备份
1、PV(physical volume):物理卷在逻辑卷管理系统最底层,可为整个物理硬盘或实际物理硬盘上的分区。
2、VG(volume group):卷组建立在物理卷上,一卷组中至少要包括一物理卷,卷组建立后可动态的添加卷到卷组中,一个逻辑卷管理系统工程中可有多个卷组。
3、LV(logical volume):逻辑卷建立在卷组基础上,卷组中未分配空间可用于建立新的逻辑卷,逻辑卷建立后可以动态扩展和缩小空间。
4、PE(physical extent):物理区域是物理卷中可用于分配的最小存储单元,物理区域大小在建立卷组时指定,一旦确定不能更改,同一卷组所有物理卷的物理区域大小需一致,新的pv加入到vg后,pe的大小自动更改为vg中定义的pe大小。
5、LE(logical extent):逻辑区域是逻辑卷中可用于分配的最小存储单元,逻辑区域的大小取决于逻辑卷所在卷组中的物理区域的大小。
6、卷组描述区域:卷组描述区域存在于每个物理卷中,用于描述物理卷本身、物理卷所属卷组、卷组中逻辑卷、逻辑卷中物理区域的分配等所有信息,它是在使用pvcreate建立物理卷时建立的。

三、介绍fdisk对物理磁盘分区知识。

1、通过df指令查阅磁盘的相关信息,主要查看磁盘名称,见下图红色部分。

mysql恢复和备份
2、或者采用fdisk -l指令查看整个磁盘的分区情况,如下:

mysql恢复和备份
3、采用fdisk指令换分磁盘

mysql恢复和备份
mysql恢复和备份
4、注意当我们分区完成后,按下W保存新划分的磁盘分区后,用fdisk -l查看,发现新的磁盘分区已经存在,但是在用pvcreate指令将分区转化为物理分区时,会提醒你磁盘分区还不存在,这是怎么会事情呢?如下:

mysql恢复和备份
虽然已经将分区写入了分割表,但是核心不能立刻捕获到分割表信息,此时可以通过使用reboot指令重启服务器,让内核重新加载分区表信息,也可以此阿勇partprobe这个指令,通知内核读取分区表。

四、将整个磁盘或者某一磁盘分区装换为逻辑磁盘(pv)
    创建物理卷PV(Physical Volumes) 物理卷(Physical Volumes)简称PV,是在磁盘的物理分区或与磁盘分区具有同样功能的设备(如RAID)上创建而来。它只是在物理分区中划出了一个特殊的区域,用于记载与LVM相关的管理参数。我利用fdisk命令,将磁盘分了一个新的分区, 通过fdisk的t指令指定分区为8e类型(Linux LVM) 。
    ①pvcreate 对应的磁盘分区(注意磁盘分区的类型应该为LVM,即fdisk -l中的system类型为 LVM)
    ②查看转换后的物理分区情况:pv和pvdisplay。
下面是一个例子,他装换了两个磁盘分区(sdb1和sdb2)为物理分区。并查看转换后的状态。

mysql恢复和备份
五、创建卷组VG(Volume Groups)。
    卷组(Volume Group)简称VG,它是一个或者多个物理卷的组合。卷组将多个物理卷组合在一起,形成一个可管理的单元,它类似于非LVM系统中的物理硬盘。 
   1、 创建卷组的命令为vgcreate,下面利用它创建了一个名为“lvmdisk”的卷组,该卷组包含/dev/sdb1、/dev/sdc1两个物理卷。 
  [root@li2 ~]# vgcreate lvmdisk /dev/sdb1 /dev/sdc1 
  Volume group "lvmdisk" successfully created 
 2、使用卷组查看命令vgdisplay显示卷组情况: 
  [root@li2 ~]# vgdisplay 
  --- Volume group --- 
  VG Name lvmdisk 
  System ID 
  Format lvm2 
  Metadata Areas 2 
  Metadata Sequence No 1 
  VG Access read/write 
  VG Status resizable 
  MAX LV 0 
  Cur LV 0 
  Open LV 0 
  Max PV 0 
  Cur PV 2 
  Act PV 2 
  VG Size 71.98 GB 
  PE Size 4.00 MB 
  Total PE 18428 
  Alloc PE / Size 0 / 0 
  Free PE / Size 18428 / 71.98 GB 
  VG UUID SARfuj-wAUI-od81-VWAc-A1nt-aaFN-JWaPVf 
  当多个物理卷组合成一个卷组后时,LVM会在所有的物理卷上做类似格式化的工作,将每个物理卷切成一块一块的空间,这一块一块的空间就称为PE(Physical Extent ),它的默认大小是4MB。 
  由于受内核限制的原因,一个逻辑卷(Logic Volume)最多只能包含65536个PE(Physical Extent),所以一个PE的大小就决定了逻辑卷的最大容量,4 MB 的PE决定了单个逻辑卷最大容量为 256 GB,若希望使用大于256G的逻辑卷,则创建卷组时需要指定更大的PE。在Red Hat Enterprise Linux AS 4中PE大小范围为8 KB 到 16GB,并且必须总是 2 的倍数。 
  例如,如果希望使用 64 MB 的PE创建卷组,这样逻辑卷最大容量就可以为4 TB。
六、创建逻辑卷LV(Logical Volumes)
      逻辑卷(Logical Volumes)简称LV,是在卷组中划分的一个逻辑区域,类似于非LVM系统中的硬盘分区。 
  创建逻辑卷的命令为lvcreate,通过下面的命令,我们在卷组lvmdisk上创建了一个名字为pldy1的逻辑卷,大小为15GB,其设备入口为/dev/lvmdisk/pldy1。 
  [root@li2 dev]# lvcreate -L 15G -n pldy1 lvmdisk 
  Logical volume "pldy1" created 
  也可以使用-l参数,通过指定PE数来设定逻辑分区大小。 
  例如,希望创建一个使用全部空间的逻辑卷,需要先查清卷组中的PE总数,通过上面的vgdisplay命令查得当前卷组PE总数为18428,命令如下: 
  # lvcreate -l 18428 -n pldy1 lvmdisk 
  当逻辑卷创建成功后,可以使用lvdisplay命令查看逻辑卷情况: 
  [root@li2 ~]# lvdisplay 
  --- Logical volume --- 
  LV Name /dev/lvmdisk/pldy1 
  VG Name lvmdisk 
  LV UUID FQcnm3-BMyq-NkJz-hykw-9xg1-Qy8d-8UeGCN 
  LV Write Access read/write 
  LV Status available 
  # open 0 
  LV Size 15.00 GB 
  Current LE 3840 
  Segments 1 
  Allocation inherit 
  Read ahead sectors 0 
  Block device 253:0 
  同卷组一样,逻辑卷在创建的过程中也被分成了一块一块的空间,这些空间称为LE(Logical Extents),在同一个卷组中,LE的大小和PE是相同的,并且一一对应。 
七、创建文件系统 
  在逻辑卷上创建ext3文件系统: 
  [root@li2 ~]# mkfs -t ext3 /dev/lvmdisk/pldy1 
  创建了文件系统以后,就可以加载并使用了: 
  [root@li2 ~]# mkdir /opt/Oracle 
  [root@li2 ~]# mount /dev/lvmdisk/pldy1 /opt/Oracle 
  为了在系统启动时自动加载文件系统,则还需要在/etc/fstab中添加内容: 
  /dev/lvmdisk/pldy1 /opt/Oracle ext3 defaults 1 2 
八、管理LVM 
  LVM的最大好处就是可以动态地调整分区大小,而无须重新启动机器,下面让我们来体验一下吧!继续上面的实例,现假设逻辑卷/dev/lvmdisk/pldy1空间不足,需要增加其大小,我们分两种情况讨论: 
  1.卷组中有剩余的空间 
  通过vgdisplay命令可以检查当前卷组空间使用情况: 
  [root@li2 ~]# vgdisplay 
  --- Volume group --- 
  VG Name lvmdisk 
  System ID 
  Format lvm2 
  Metadata Areas 2 
  Metadata Sequence No 2 
  VG Access read/write 
  VG Status resizable 
  MAX LV 0 
  Cur LV 1 
  Open LV 0 
  Max PV 0 
  Cur PV 2 
  Act PV 2 
  VG Size 71.98 GB 
  PE Size 4.00 MB 
  Total PE 18428 
  Alloc PE / Size 3840 / 15.00 GB 
  Free PE / Size 14588 / 56.98 GB 
  VG UUID SARfuj-wAUI-od81-VWAc-A1nt-aaFN-JWaPVf 
  确定当前卷组剩余空间56.98GB,剩余PE数量为14588个。在这里将所有的剩余空间全部增加给逻辑卷 /dev/lvmdisk/pldy1。 
  [root@li2 Oracle]# lvextend -l+14588 /dev/lvmdisk/pldy1 
  Extending logical volume pldy1 to 56.98 GB 
  Logical volume pldy1 successfully resized 
  上面的命令使用了-l+14588参数,它的意思是给指定的逻辑卷增加14588个PE。如果不是将全部空间都使用,还可使用其他形式的lvextend命令。 
  例如将逻辑卷/dev/lvmdisk/pldy1增加5GB的空间,使其空间达到20GB,可写成: “# lvextend -L+5G /dev/lvmdisk/pldy1”或“# lvextend -L20G /dev/lvmdisk/pldy1”。增加了逻辑卷容量后,就要通过ext2online命令修改文件系统的大小了。 
  [root@li2 ~]# ext2online /opt/Oracle/ 
  转换好后,让我们查看一下文件系统的当前状态: 
  [root@li2 ~]# df -lh 
  Filesystem 1k-blocks Used Available Use% Mounted on 
  /dev/sda1 7.4G 1.8G 5.3G 25% / 
  none 135M 0 135M 0% /dev/shm 
  /dev/mapper/lvmdisk-pldy1 71G 81M 68G 1% /opt/Oracle 
  2.卷组中空间不足 
  当卷组中没有足够的空间用于扩展逻辑卷的大小时,就需要增加卷组的容量,而增加卷组容量的惟一办法就是向卷组中添加新的物理卷。 
  首先是增加一块新硬盘(36GB SCSI 硬盘),并对其完成分区、创建物理卷等工作。接下来是利用vgextend命令将新的物理卷(/dev/sdd1)加入到卷组中。 
  扩展卷组的命令如下: 
  [root@li2 ~]# vgextend lvmdisk /dev/sdd1 
  Volume group "lvmdisk" successfully extended 
  利用vgdisplay命令查看卷组lvmdisk的情况: 
  [root@li2 ~]# vgdisplay 
  --- Volume group --- 
  VG Name lvmdisk 
  System ID 
  Format lvm2 
  Metadata Areas 3 
  Metadata Sequence No 3 
  VG Access read/write 
  VG Status resizable 
  MAX LV 0 
  Cur LV 1 
  Open LV 0 
  Max PV 0 
  Cur PV 3 
  Act PV 3 
  VG Size 107.97 GB 
  PE Size 4.00 MB 
  Total PE 27640 
  Alloc PE / Size 3840 / 15.00 GB 
  Free PE / Size 23800 / 92.97 GB 
  VG UUID l8YPvz-uD7h-oj1A-0qS5-TFcT-mbC7-QbjzCu 
  完成卷组的扩容后,就可以按照第一种情况的方法完成逻辑卷的扩容,最终实现分区的动态调整。
九、采用LVM完成对mysql的数据备份
    1、创建一个逻辑分区(lv),并格式化为ext3类型的文件系统。
    2、如果已经安装配置完mysql,并且mysql的数据存储区为mysql目录下的data文件夹。则关闭mysql服务,用tar指令打包备份data目录(tar -cvf  打包成的目标文件.tar 要打包的目录)。

    3、将格式化好的逻辑分区挂载到data目录下(mount /dev/volgroup/mysqldata /usr/local/mysql/data)。并将打包后的文件解压回data目录下(tar -xvf /root/databak/data.tar -C / 强制解压到data目录下)。然后重启mysql服务器。这样mysql以后的数据都会写入到逻辑分区中。
    4、备份数据库步骤如下:
    ①锁表:mysql> flush tables with read lock; \\防止创建快照过程中有数据写入 
    ② 查看position信号:mysql> show master status\G; \\查看当前的position信号,方便同步到slave的时候使用 
    ③ 创建快照:# lvcreate -n mysql-snap -L 100M -s /dev/mysqlvg1/mysqllv \\将逻辑卷中的数据创建为大小为100M的快照,这个速度非常快。 
    ④ 解锁:mysql> unlock tables;\\解锁 
    ⑤ 挂载创建快照:# mount /dev/mysqlvg1/mysql-snap  /mnt/ \\挂载快照,为备份做准备 
    ⑥ 读取快照进行备份(备份需要备份的即可):# tar cf mysql-01.tar.gz db1 db_2  \\备份快照信息到存储设备里面 
    ⑦ 卸载挂载的快照,然后删除快照:# umount /mnt/         # lvremove -f /dev/mysqlvg1/mysql-snap \\删除快照,节省空间到此,整个备份过程就算结束了。
    如果你想要将内容同步到slave机上的话,那么还需要多加几个步骤。
    1、把备份内容拷贝到slave的数据文件目录下。
    2、重启MySQL服务器,等待恢复完成。
    3、使用CHANGE MASTER TO 命令告诉slave新的二进制日志位置,并从那里开始同步,(就是我们刚刚记录下来的那个)例如:mysql> CHANGE master TO master_host=”192.168.100.109”,master_user=”slave”,master_password=”123.com”, master_log_file=”host-bin.000006″,master_log_pos=198;  

你可能感兴趣的:(mysql备份,虚拟文件系统,linux文件系统,LVM搭建)