mysql精通辛星_辛星解读使用mysqldump来进行热备份

备份的重要性就不言而喻了,特别是对于数据库管理员来说,备份尤其重要。备份有好多种分法,这里我也并不是很像把他们全部说完,这里大致说一下热备份和冷备份。如果关闭服务的话,就可以进行冷备份了,如果是MyISAM引擎,则直接备份datadir里面的数据文件即可,一旦有了灾难,直接恢复数据即可,InnoDB的话需要处理的东西稍微多一些,比如ibdata文件、*.frm文件盒my.cnf(在windows下是my.ini),设置innodb_data_file_path来制定原先的ibdata路径。

上面简单介绍了下冷备份,再说一下热备份,如果大家去搜一下热备份,大部分搜到的都是主从备份和双机备份,我承认,这些技术都比较重要,但是,我们这里介绍的是本机备份,对于双机备份和主从备份,我们后面再介绍。

对于热备份工具,我们可以使用mysql自带的mysqldump,当然还可以借助xtrabackup等第三方备份工具,这种专门的备份工具就好用的多了,不过我们还是先了解下mysqldump。我们使用mysqldump进行备份的时候,它会进行锁表,我们的应用无法向数据库进行写操作,如果我们的MyISAM表比较多,我们使用mysqldump也是一个非常不错的选择,下面我们看一下这个命令应该怎么用:

C:\Users\Administrator>mysqldump -u root -proot mysql > D:\my.sql

mysqldump: [Warning] Using a password on the command line interface can be insecure.

C:\Users\Administrator>

这里我解释一下吧,这个mysqldump就是这个命令了,这里我们仍然需要使用用户和密码的,否则会报如下错误:

C:\Users\Administrator>mysqldump mysql > D:\an.sql

mysqldump: Got error: 1045: Access denied for user 'ODBC'@'localhost' (using password: NO) when trying to connect

它会提示我们权限不足,无法操作。我们第一个命令中使用了mysqldump之后使用root用户来备份,我们备份的是mysql数据库,然后使用>来吧数据写入到D盘下的my.sql中,这里的>是重定向的意思,而且是覆盖写,我想有Linux基础的这个应该都懂的吧。

然后我们会发现果然在D盘下多了一个my.sql文件,当然我这里的内容还是蛮多的,足足有562KB,下面我仅仅摘抄它的前几行内容,给大家看一下我们导出的都是些什么东西:

-- MySQL dump 10.13 Distrib 5.7.3-m13, for Win64 (x86_64)

--

-- Host: localhost Database: mysql

-- ------------------------------------------------------

-- Server version5.7.3-m13

/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;

/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;

/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;

/*!40101 SET NAMES utf8 */;

/*!40103 SET @OLD_TIME_ZONE=@@TIME_ZONE */;

/*!40103 SET TIME_ZONE='+00:00' */;

/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;

/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;

/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;

/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;

--

-- Table structure for table `columns_priv`

--

DROP TABLE IF EXISTS `columns_priv`;

/*!40101 SET @saved_cs_client = @@character_set_client */;

/*!40101 SET character_set_client = utf8 */;

CREATE TABLE `columns_priv` (

`Host` char(60) COLLATE utf8_bin NOT NULL DEFAULT '',

`Db` char(64) COLLATE utf8_bin NOT NULL DEFAULT '',

`User` char(16) COLLATE utf8_bin NOT NULL DEFAULT '',

`Table_name` char(64) COLLATE utf8_bin NOT NULL DEFAULT '',

`Column_name` char(64) COLLATE utf8_bin NOT NULL DEFAULT '',

`Timestamp` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,

`Column_priv` set('Select','Insert','Update','References') CHARACTER SET utf8 NOT NULL DEFAULT '',

PRIMARY KEY (`Host`,`Db`,`User`,`Table_name`,`Column_name`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='Column privileges';

/*!40101 SET character_set_client = @saved_cs_client */;

我们发现,其实导出的并不是纯数据,而是一些SQL语句,而且还带有注释。

当然了,我们喜欢敲命令行的都知道,它一般会可以跟好几个参数,没错,我们直接敲mysqldump然后回车可以看到它的常见用法:

C:\Users\Administrator>mysqldump

Usage: mysqldump [OPTIONS] database [tables]

OR mysqldump [OPTIONS] --databases [OPTIONS] DB1 [DB2 DB3...]

OR mysqldump [OPTIONS] --all-databases [OPTIONS]

For more options, use mysqldump --help

C:\Users\Administrator>

这里我怕大家理解不是很清楚,就特意来解释下吧,第一个是说我们可以导出一个数据库,也可以导出一个数据库下的表,第二个是说我们可以导出n多个数据库,但是需要加上--databases来说明,第三个则直接导出所有数据库。

既然有备份,就会有恢复,我们使用mysql命令即可,比如我创建一个an数据库,它使用咱们备份的文件中的数据,咱们看下面操作,我就不单个演示了,这里咱们的数据库an就拿到了我们的备份数据,顺便说一下,这个数据库an必须提前建好,它不具有自己创建新数据库的能力:

C:\Users\Administrator>mysql -u root -proot an < D:\my.sql

mysql: [Warning] Using a password on the command line interface can be insecure.

C:\Users\Administrator>mysql -u root -proot

mysql: [Warning] Using a password on the command line interface can be insecure.

Welcome to the MySQL monitor. Commands end with ; or \g.

Your MySQL connection id is 124

Server version: 5.7.3-m13 MySQL Community Server (GPL)

Copyright (c) 2000, 2013, 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 an

Database changed

mysql> show tables;

+---------------------------+

| Tables_in_an |

+---------------------------+

| columns_priv |

| db |

| event |

| func |

| general_log |

| help_category |

| help_keyword |

| help_relation |

| help_topic |

| innodb_index_stats |

| innodb_table_stats |

| ndb_binlog_index |

| plugin |

| proc |

| procs_priv |

| proxies_priv |

| servers |

| slave_master_info |

| slave_relay_log_info |

| slave_worker_info |

| slow_log |

| tables_priv |

| time_zone |

| time_zone_leap_second |

| time_zone_name |

| time_zone_transition |

| time_zone_transition_type |

| user |

+---------------------------+

28 rows in set (0.00 sec)

mysql>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值