MySQL数据目录的位置

数据库 MySQL
作为一个合格的DBA,应该知道MySQL数据目录在哪里,如果不知道确切的MySQL数据目录的位置,应该了解如何找到它的位置。

MySQL数据目录是MySQL数据库的重要部分,如何确定MySQL数据目录的位置是每一个DBA都需要掌握的知识,下面就让我们来一起了解一下确定MySQL数据目录的位置的方法。

一个缺省MySQL数据目录被编译进了服务器,如果你从一个源代码分发安装MySQL,典型的缺省目录为/usr/local/var,如果从RPM文件安装则为/var/lib/mysql,如果从一个二进制分发安装则是/usr/local/mysql/data。

在你启动服务器,通过使用一个--datadir=/path/to/dir选项可以明确指定MySQL数据目录位置。如果你想把数据目录置于其它缺省位置外的某处,这很有用。

作为一名MySQL管理员,你应该知道你的MySQL数据目录在哪里。如果你运行多个服务器,你应该是到所有数据目录在哪里,但是如果你不知道确切的位置,由多种方法找到它:

使用mysqladmin variables从你的服务器直接获得MySQL数据目录路径名。查找datadir变量的值,在Unix上,其输出类似于:
%mysqladmin variables

  1. +----------------------+----------------------+  
  2. | variable_name        | Value                |  
  3. +----------------------+----------------------+  
  4. | back_log             | 5                    |  
  5. | connect_timeout      | 5                    |  
  6. | basedir              | /var/local/          |  
  7. | datadir              | /usr/local/var/      |  
  8. .... 

在Windows上,输出可能看上去像这样:

  1. c:\mysqladmin variables  
  2.  
  3. +----------------------+----------------------+  
  4. | variable_name        | Value                |  
  5. +----------------------+----------------------+  
  6. | back_log             | 5                    |  
  7. | connect_timeout      | 5                    |  
  8. | basedir              | c:\mysql\            |  
  9. | datadir              | c:\mysql\data\       |  
  10. ....  

如果你有多个服务器在运行,它们将在不同的TCP/IP端口或套接字上监听,通过提供连接服务器正在监听的端口或套接字的--port或--socket选项,你可以轮流获得它们每一个的数据目录信息:

  1. %msqladmin --port=port_name variables  
  2.  
  3. %mysqladmin --socket=/path/to/socket variables  

mysqladmin命令可运行在任何你能从其连接服务器的主机上,如果你想在一个远程主机连接服务器,使用一个--host=host_name选项:

  1. %mysqladmin --host=host_name variables 

在Windows上,你可以通过使用--pipe强制一个命令管道连接和--socket=pipe_name指定管道名来连接监听一个命令管道的NT服务器:

  1. c:\mysqladmin --pipe --socket=pipe_name variables 

你可以使用ps命令查看任何正在运行mysqld 进程的命令行。
试一下下列命令之一并寻找--datadir:

  1. %ps axww | grep mysql        BSD风格  
  2.  
  3. %ps -ef | grep mysqld            System V风格  

如果你的系统运行多个服务器,ps命令可能特别有用,因为你能马上发现多个MySQL数据目录位置,缺点是必须在服务器上运行,而且可能没有有用的信息产生,除非在mysqld命令行上明确指定了--datadir选项。

如果MySQL是从一个源代码分发安装的,你可以检查其配置信息确定MySQL数据目录位置。例如,位置可从***Makefile中获得,但是注意,位置是Makefile中的localstatedir值,不是datadir,而且,如果分发位于一个NFS挂载的文件系统并用来为多个主机构建MySQL,配置信息反映了分发被***构建的主机,这可能不能提供你感兴趣的主机的数据目录信息。
如果上述方式失败,你可以用find寻找数据库文件,下列命令寻找“.frm”文件,它是任何MySQL安装的一部分:

  1. % find / -name ".frm" -print 

在下文各例中,用DATADIR表示MySQL数据目录位置。

 

 

【编辑推荐】

检查被破坏的MySQL数据文件的方法

MySQL修改表结构语句介绍

MySQL修改表结构中对索引的操作

10大常用MySQL命令行

通过索引优化MySQL语句的实例

责任编辑:段燃 来源: 互联网
相关推荐

2010-10-13 11:44:47

MySQL数据目录

2010-10-13 13:24:16

MySQL数据目录

2010-10-13 13:48:10

MySQL数据目录

2018-11-12 15:15:32

MySQL数据库命令

2010-06-01 15:46:52

MySQL数据库文件

2009-05-27 11:01:29

UbuntuMySQL存储

2010-06-01 14:17:44

MySQL重启命令

2018-01-24 16:32:01

数据目录数据蔓延企业

2021-08-15 16:29:45

数据企业机器学习

2009-08-26 17:11:03

MySQL临时文件

2010-10-13 11:33:50

MySQL数据目录

2010-11-26 16:37:41

MySQL日志文件

2020-08-19 17:25:23

MySQL空间函数位置

2011-08-03 18:18:37

MySQL数据库目录结构

2017-11-27 08:17:38

存储数据位置

2009-06-16 11:11:25

JBoss目录数据库连接

2024-01-29 17:02:10

数据治理大数据数据工程

2021-09-01 14:45:08

服务器数据PostgreSQL

2018-09-04 08:07:50

数据中心位置气候

2021-02-14 10:09:04

数据目录数据元数据
点赞
收藏

51CTO技术栈公众号