MySQL数据目录结构
2008-02-23 07:41:12来源:互联网 阅读 ()
从概念上讲,大多数关系数据库系统是相似的:他们有一系列数据库组成,每个数据库包含一系列数据库表,但每个系统有各自组织其管理的数据方式,MySQL也不例外。
缺省地,任何由MySQL服务器mysqld管理的数据存储在一个称为MySQL数据目录的地方,任何数据库都存放在哪儿,也包括提供服务器操作信息的状态文档。假如您对一个MySQl安装执行管理任务,您应该熟知数据目录的布局及用途。
本文介绍下列专题:
- 如何确定数据目录的位置。
- 服务器如何组织并提供对数据库和他管理的表的访问。
- 在哪里找到由服务器生成的状态文档记忆他们包含什么内容。
- 如何改变缺省地点或数据目录或单独数据库的组织结构。
1、数据目录的位置
一个缺省数据目录被编译进了服务器,假如您从一个源代码分发安装MySQL,典型的缺省目录为/usr/local/var,假如从RPM文档安装则为/var/lib/mysql,假如从一个二进制分发安装则是/usr/local/mysql/data。
在您启动服务器,通过使用一个--datadir=/path/to/dir选项能够明确指定数据目录位置。假如您想把数据目录置于其他缺省位置外的某处,这很有用。
作为一名MySQL管理员,您应该知道您的数据目录在哪里。假如您运行多个服务器,您应该是到任何数据目录在哪里,但是假如您不知道确切的位置,由多种方法找到他:
- 使用mysqladmin variables从您的服务器直接获得数据目录路径名。查找datadir变量的值,在Unix上,其输出类似于:
%mysqladmin variables---------------------- ---------------------- | variable_name | Value | ---------------------- ---------------------- | back_log | 5 | | connect_timeout | 5 | | basedir | /var/local/ | | datadir | /usr/local/var/ | ....
在Windows上,输出可能看上去像这样:
c:\mysqladmin variables---------------------- ---------------------- | variable_name | Value | ---------------------- ---------------------- | back_log | 5 | | connect_timeout | 5 | | basedir | c:\mysql\ | | datadir | c:\mysql\data\ | ....
假如您有多个服务器在运行,他们将在不同的TCP/IP端口或套接字上监听,通过提供连接服务器正在监听的端口或套接字的--port或--socket选项,您能够轮流获得他们每一个的数据目录信息:
%msqladmin --port=port_name variables
%mysqladmin --socket=/path/to/socket variables
mysqladmin命令可运行在任何您能从其连接服务器的主机上,假如您想在一个远程主机连接服务器,使用一个--host=host_name选项:
%mysqladmin --host=host_name variables
在Windows上,您能够通过使用--pipe强制一个命令管道连接和--socket=pipe_name指定管道名来连接监听一个命令管道的NT服务器:
c:\mysqladmin --pipe --socket=pipe_name variables
- 您能够使用ps命令查看任何正在运行mysqld 进程的命令行。
试一下下列命令之一并寻找--datadir:
%ps axww | grep mysql BSD风格
%ps -ef | grep mysqld System V风格
假如您的系统运行多个服务器,ps命令可能特别有用,因为您能马上发现多个数据目录位置,缺点是必须在服务器上运行,而且可能没有有用的信息产生,除非在mysqld命令行上明确指定了--datadir选项。
- 假如MySQL是从一个源代码分发安装的,您能够检查其配置信息确定数据目录位置。例如,位置可从顶级Makefile中获得,但是注意,位置是Makefile中的localstatedir值,不是datadir,而且,假如分发位于一个NFS挂载的文档系统并用来为多个主机构建MySQL,配置信息反映了分发被最新构建的主机,这可能不能提供您感兴趣的主机的数据目录信息。
- 假如上述方式失败,您能够用find寻找数据库文档,下列命令寻找“.frm”文档,他是任何MySQL安装的一部分:
% find / -name ".frm" -print
在下文各例中,用DATADIR表示MySQL数据目录位置。
2、数据目录结构
MySQL数据目录包含了服务器管理的任何数据目录,这些文档被组织成一个树状结构,通过利用Unix或Windows文档系统的层次结构直接实现。
- 每个数据库对应于数据目录下的一个目录。
- 在一个数据库中的表对应于数据目录下的文档。
数据目录也包含由服务器产生的几个状态文档,如日志文档。这些文档提供了关于服务器操作的重要信息。对管理特别在出了问题而试图确定问题原因时很有价值。例如,假如某个特定查询杀死服务器,您能够通过检查日志文档判别捣乱的查询。
2.1 MySQL服务器怎样提供对数据的访问
在数据目录下的一切由一个单独的实体-MySQL服务器mysqld管理,客户程式绝不直接操作数据。相反,服务器提供数据可访问的切入点,他是客户程式和他们想使用的数据之间的中介。
当服务器启动时,假如有需要,他打开日志文档,然后通过监听网络连接位数据目录呈现一个网络接口。要访问数据,客户程式建立对服务器的一个连接,然后以MySQL查询传输请求来执行希望的操作。服务器执行每一个操作并将结果发回用户。服务器是多线程的并能服务多个同时的客户连接。然而,因为修改操作一个执行一个,实际效果是顺序化请求,以使两个客户决不能在同一时刻改变同一记录。
在正常的情况下,让服务器作为数据库访问的唯一仲裁者提供了避免可从同时访问数据库表的多个进程的破坏的确保。管理员应该知道有时服务器没有对数据目录的独裁控制。
- 当您在一个单个数据目录上运行多个服务器。一般倪云新一个服务器管理主机上的任何数据库,但是有可能运行多个服务器。假如这完成提供对多个单独数据目录的访问,没有相互影响的问题,但哟也能启动多个服务器并指向同一个目录。一般地,这不是个好主意。假如您试图这样,最好是您的系统提供良好的文档锁定功能,否则服务器将不能正确协作。假如您将多个服务器同时写入日志文档,您也冒着您的日志文档称为混乱的根源的风险。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇: MySQL数据库备份
下一篇: MySQL服务器的启动和停止
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash