《MySQL基础知识介绍8第五章》由会员分享,可在线阅读,更多相关《MySQL基础知识介绍8第五章(22页珍藏版)》请在金锄头文库上搜索。
1、本章要点: 数据库目录的内容 如何备份和恢复数据 如何使用日志 如何使用内建复制有多种可能会导致数据表的丢失或者服务器的崩溃,一个简单的 DROP TABLE 或者 DROP DATABASE 的语句,就会让你的数据表化为乌有。更危险的是DELETE * FROM tbl_name,可以轻易的清空你的数据表,而这样的错误是很容易的发生的。因此,拥有能够恢复的数据对于一个数据库系统来说是非常重要的。一般的说,MySQL 有三种保证数据安全的方法: 常规日志和更新日志通过保存执行的查询供你必要时恢复 数据库备份通过导出数据或者表文件的拷贝来保护数据 数据库复制MySQL 内部复制功能是建立在两个或
2、两个以上服务器之间,通过设定它们之间的主- 从关系来实现的。其中一个作为主服务器,其它的作为从服务器。这个复制功能是在 3.23.15 版以后才有的数数数 据据据 库库库 的的的 备备备 份份份 与与与 恢恢恢 复复复第第 5章章 5 数据库的备份与恢复 http:/ 1155.1 数据库目录数据库目录是 MySQL 数据库服务器存放数据文件的地方,不仅包括有关表的文件,还包括数据文件和 MySQL 的服务器选项文件。不同的分发,数据库目录的缺省位置是不同的。5.1.1 数据目录的位置 缺省的数据库位置缺省数据库的位置编译在服务器中。1、 如果您是在一个源程序分发包中安装 MySQL,典型的缺
3、省位置可能是 /usr/local/var;2、 如果在二进制分发包中安装 MySQL,则为 /usr/local/mysql/ data;3、 在 RPM 文件中安装,为 /var/lib/mysql。4、 对于 windwos 平台上的分发,其位置时 BASEDIRdata 数据目录的位置可以在启动服务器时通过-datadir = / path / to / dir 明确地指定。如果您想将数据目录放置在其他地方而非缺省的位置,则这个选项是有用的。 了解数据库目录的位置作为一名 MySQL 管理员,您应该知道数据目录在哪里。如果运行多个服务器,那么您应该掌握所有数据目录的位置。但是,如果不知
4、道目录的位置(或许您正在代替前一位管理员,而他留下的记录很糟糕),有几种方法可以用来查找它:1、 可使用 mysqladmin 变量直接从服务器中得到数据目录路径名。在 UNIX 中,输出结果类似于如下所示:$mysqladmin variables+-+-| Variable_name | Value +-+-| ansi_mode | OFF | back_log | 50 | basedir | /var/local | connect_timeout | 5 | concurrent_insert | ON | datadir | /usr/local/var 该输出结果指明了服务器主
5、机中数据目录的位置 /usr/local/var。在 Windows 中,输出结果类似于如下所示:c:mysqlbinmysqladmin variables M ySQL 金 典 培 训 教 程116 http:/+-+-| Variable_name | Value +-+-| ansi_mode | OFF | back_log | 50 | basedir | c:mysql | connect_timeout | 5 | concurrent_insert | ON | datadir | c:mysqldata 如果正在运行多个服务器,它们将监听不同的 TCP/IP 端口号和套接字
6、。可以通过提供合适的-port 或 -socket 选项连接到每个服务器监听的端口和套接字上:$mysqladmin port=port=port_num variables$mysqladmin socket=/path/to/socket variablesmysqladmin 命令可在您连接服务器的任何一台主机上运行。如果需要连接到远程主机上的服务器,则使用 -host = host_name 选项:$mysqladmin host=host_name varibles2、在 Unix 平台上,可使用 ps 来查看任何当前执行 mysql 进程的命令行。试一试下列的命令(根据您的系统所支
7、持的 ps 版本)并查找显示在输出结果中的这些命令的 -datadir:$ps au | grep mysqld如果系统运行多个服务器(因为一次发现了多个数据目录位置),则 ps 命令将会特别有用。它的缺点是:ps 必须运行在服务器的主机上,并且除非 -datadir 选项在 mysqld 命令行中明确指定,否则将产生无用的信息。3、 如果 MySQL 从源程序分发包中安装,可以检查其配置信息以确定数据目录的位置。例如,在最高级的 Makefile 中该位置是可用的。但是,要小心:位置是 Makefile 中的变量 localstatedir 的值,而不是 datadir 的值。同样,如果分发
8、包定位在 NFS 装配文件系统中,并且是用于为几个主机建立 MySQL 的,则配置信息反映最近建立分发包的主机。它可能不显示您感兴趣的主机的数据目录。4、 如果前面的任何方法都不成功,可使用 find 搜索数据库文件。下列命令将搜索 .frm(描述)文件,它是 MySQL 安装程序的组成部分:$find / -name “*.frm” print在 windows 平台上的搜索非常简单,本节就不给出例子了。在本章的这些例子中,笔者将 MySQL 数据目录的位置表示为 DATADIR。您可以将其解释成为您自己的机器中的数据目录的位置。5.1.2 数据库的表示法由 MySQL 管理的每个数据库都有
9、自己的数据库目录,它们是数据目录的子目录, 5 数据库的备份与恢复 http:/ 117与所表示的数据库有相同的名称。例如,数据库 my_db 对应于数据库目录 DATADIR/my_db。这个表示法使得几个数据库级的语句的实现是非常容易的。CREATE DATABASE db_name 使用只允许对 MySQL 服务器用户(服务器运行的 UNIX 用户)进行访问的所有权和方式,并在数据目录中创建一个空目录 db_name。这等价于以服务器主机中的服务器用户的身份通过执行下列命令手工创建数据库:$ mkdir DATADIR/db_name 创建数据库目录$ chmod 700 DATADIR
10、/db_name 使它仅对 MySQL 服务器用户可访问通过空目录表示新数据库的方法与其他数据库系统完全不同,那些数据库系统甚至要为“空”数据库创建许多控制文件或系统文件。DROP DATABASE 语句也很容易实现。 DROP DATABASE db_name 删除数据目录中的 db_name 目录以及其中的所有表文件。这个语句类似于下列命令:$rm -rf DATADIR/db_name其区别是,服务器只删除带有表的扩展名的文件。如果已经在该数据库目录中创建了其他的文件,服务器将使它们保持完整,并且不删除该目录本身。SHOW DATABASE 只不过是对应位于数据目录中的子目录名称的一个列
11、表。有些数据库系统需要保留一个列出所有需要维护的数据库的主表,但是,在 MySQL 中没有这样的结构。由于数据目录结构的简单性,数据库的列表是隐含在该数据目录的内容中的,像主表这样的表可能会引起不必要的开销。5.1.3 数据库表的表示法数据库中的每个表在数据库目录中都作为三个文件存在:一个格式(描述)文件、一个数据文件和一个索引文件。每个文件的基名是该表名,扩展名指明该文件的类型。扩展名如表 5-1 所示。数据和索引文件的扩展名指明该表是否使用较老的 ISAM 索引或较新的 MyISAM 索引。表 5-1 MySQL 文件类型文件类型 文件扩展名 文件内容格式文件 .frm 描述表的结构(列、
12、列类型、索引,等等)数据文件 .ISD(ISAM) 或.MYD(MyISAM)包含表的数据即它的行索引文件 ISD(ISAM) 或.MYI(MyISAM)包含数据文件中任何索引的索引树。无论该表有无索引,索引文件都存在当发布定义一个表结构的 CREATE TABLE tbl_name 语句时,服务器创建 tbl_name.frm 文件,它包含该结构的内部编码。该语句还创建空的数据文件和索引文件,这些文件的初始信息表明没有记录和索引(如果 CREATE TABLE 语句包含索引说明,则该索引文件将反映这些索引)。描述表的文件的所有权和方式被设置为只允许对 MySQL 服务器用户的访问。 M yS
13、QL 金 典 培 训 教 程118 http:/当发布 ALTER TABLE 语句时,服务器对 tbl_name.frm 重新编码并修改数据文件和索引文件的内容以反映由该语句表明的结构变化。对于 CREATE 和 DROP INDEX 也是如此,因为服务器认为它们等价于 ALTER TABLE 语句。DROP TABLE 删除代表该表的三个文件。尽管可以通过删除数据库目录中的对应某个表的三个文件来删除该表,但不能手工创建或更改表。例如,如果 my_db 是当前的数据库,DROP TABLE my_tbl 大致等价于下列命令:来自于 SHOW TABLES my_db 的输出结果正是 my_d
14、b 数据库目录中 .frm 文件基名的一个列表。某些数据库系统维护一个列出了数据库中的所有表的登记。但 MySQL 不这样做,因为没有必要,这个“登记”隐含在了数据目录的结构中。5.1.4 MySQL 的状态文件除数据库目录外,MySQL 数据目录还包含许多状态文件。表 10-3 概括介绍了这些文件。大多数状态文件的缺省名称从服务器主机名字中生成,在此表中表示为 HOSTNAME。表 5-2 MySQL 状态文件文件类型 缺省名 文件内容进程 ID HOSTNAME.pid 服务器进程 ID错误日志 HOSTNAME.err 启动和关闭事件和错误状态常规日志 HOSTNAME.log 连接/断开事件和查询信息更新日志 HOSTNAME.nn