MySQL备份与恢复之冷备(1)

作者:Wentasy 时间:2024-01-26 13:37:50 

        用一句话概括冷备,就是把数据库服务,比如MySQL,Oracle停下来,然后使用拷贝、打包或者压缩命令对数据目录进行备份。如果数据出现异常,则可以通过备份数据恢复。冷备一般需要定制计划,比如什么时候做备份,每次对哪些数据进行备份等等。但是由于这样的备份占用过多的空间,对大数据量的环境下不一定适合,故生产环境很少使用。

冷备示意图

MySQL备份与恢复之冷备(1) 

冷备实验

第一步,创建测试数据库,插入测试数据


mysql> use larrydb;
Database changed
mysql> show tables;
+-------------------+
| Tables_in_larrydb |
+-------------------+
| access  |
+-------------------+
1 row in set (0.00 sec)

mysql> drop table access;
Query OK, 0 rows affected (0.00 sec)

mysql> clear
mysql> show tables;
Empty set (0.00 sec)

mysql>
mysql> create table class(
-> cid int,
-> cname varchar(30));
Query OK, 0 rows affected (0.01 sec)

mysql> show create table class \G;
*************************** 1. row ***************************
Table: class
Create Table: CREATE TABLE `class` (
`cid` int(11) DEFAULT NULL,
`cname` varchar(30) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1
1 row in set (0.00 sec)

ERROR:
No query specified

mysql> create table stu(
-> sid int,
-> sname varchar(30),
-> cid int) engine=myisam;
Query OK, 0 rows affected (0.00 sec)

mysql> show create table stu \G;
*************************** 1. row ***************************
Table: stu
Create Table: CREATE TABLE `stu` (
`sid` int(11) DEFAULT NULL,
`sname` varchar(30) DEFAULT NULL,
`cid` int(11) DEFAULT NULL
) ENGINE=MyISAM DEFAULT CHARSET=utf8
1 row in set (0.00 sec)

ERROR:
No query specified

mysql> insert into class values(1,'linux'),(2,'oracle');
Query OK, 2 rows affected (0.00 sec)
Records: 2 Duplicates: 0 Warnings: 0

mysql> desc class;
+-------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| cid | int(11) | YES | | NULL | |
| cname | varchar(30) | YES | | NULL | |
+-------+-------------+------+-----+---------+-------+
2 rows in set (0.00 sec)

mysql> desc stu;
+-------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| sid | int(11) | YES | | NULL | |
| sname | varchar(30) | YES | | NULL | |
| cid | int(11) | YES | | NULL | |
+-------+-------------+------+-----+---------+-------+
3 rows in set (0.00 sec)

mysql> insert into stu values(1,'larry01',1),(2,'larry02',2);
Query OK, 2 rows affected (0.00 sec)
Records: 2 Duplicates: 0 Warnings: 0

mysql> select * from stu;
+------+---------+------+
| sid | sname | cid |
+------+---------+------+
| 1 | larry01 | 1 |
| 2 | larry02 | 2 |
+------+---------+------+

第二步,停掉MySQL


[root@serv01 ~]# /etc/init.d/mysqld stop
Shutting down MySQL... SUCCESS!

 
第三步,创建备份目录,并修改拥有者和所属组


[root@serv01 ~]# mkdir /databackup
[root@serv01 ~]# chown mysql.mysql /databackup/ -R
[root@serv01 ~]# ll /databackup/ -d
drwxr-xr-x. 2 mysql mysql 4096 Sep 10 17:46 /databackup/
[root@serv01 ~]# cd /databackup/

第四步,冷备(使用tar命令)


[root@serv01 databackup]# tar -cvPzf mysql01.tar.gz

 
第五步,测试冷备的数据是否正常,我们删除掉data下的所有数据


[root@serv01 databackup]# rm -rf /usr/local/mysql/data/*

 
第六步,删除所有数据后数据库不能启动


[root@serv01 databackup]# /etc/init.d/mysqld start
Starting MySQL.. ERROR! The server quit without updating PID file (/usr/local/mysql/data/serv01.host.com.pid).

 
第七步,恢复数据(使用tar命令)


[root@serv01 databackup]# tar -xvPf mysql01.tar.gz

 
第八步,启动MySQL,然后登录MySQL,查看数据是否丢失,如果数据正常代表冷备成功


[root@serv01 databackup]# /etc/init.d/mysqld start
Starting MySQL.. SUCCESS!

[root@serv01 ~]# mysql
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 1
Server version: 5.5.29-log Source distribution

Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> use larrydb;
Database changed
mysql> select * from class;
+------+--------+
| cid | cname |
+------+--------+
| 1 | linux |
| 2 | oracle |
+------+--------+
2 rows in set (0.00 sec)

mysql> select * from stu;
+------+---------+------+
| sid | sname | cid |
+------+---------+------+
| 1 | larry01 | 1 |
| 2 | larry02 | 2 |
+------+---------+------+
2 rows in set (0.00 sec)
标签:MySQL备份与恢复,冷备份
0
投稿

猜你喜欢

  • FrontPage2003 中网页布局功能的应用

    2007-11-18 14:43:00
  • php字符串截取函数mb_substr用法实例分析

    2024-05-02 17:35:09
  • MySQL笔记之触发器的应用

    2024-01-18 17:23:32
  • Python打印scrapy蜘蛛抓取树结构的方法

    2022-01-16 03:46:18
  • 利用python GDAL库读写geotiff格式的遥感影像方法

    2023-08-31 13:15:06
  • Python简单生成8位随机密码的方法

    2021-02-22 08:43:14
  • python 实现目录复制的三种小结

    2023-09-01 12:17:20
  • PyQt中实现自定义工具提示ToolTip的方法详解

    2023-11-09 13:34:56
  • CSS用relative和absolute实现的图片定位效果

    2008-10-06 21:37:00
  • vue 解决兄弟组件、跨组件深层次的通信操作

    2024-05-09 15:12:55
  • 在Internet Explorer中正确使用MSXML

    2009-02-22 18:41:00
  • Python获取江苏疫情实时数据及爬虫分析

    2022-09-19 02:12:30
  • Python高级特性切片(Slice)操作详解

    2022-04-07 20:28:02
  • 在MySQL中使用XML数据—数据格式化

    2009-12-29 10:26:00
  • python随机生成指定长度密码的方法

    2023-08-07 07:24:00
  • 原生js实现放大镜组件

    2024-05-11 09:06:05
  • python析构函数用法及注意事项

    2023-01-25 19:53:11
  • Oracle数据库及应用程序优化开发者网络Oracle

    2010-07-18 13:02:00
  • MySQL中查看数据库安装路径的方法

    2024-01-16 04:19:46
  • python读取excel数据绘制简单曲线图的完整步骤记录

    2022-04-27 10:52:18
  • asp之家 网络编程 m.aspxhome.com