从概念上讲,大多
" `0 z' N; v, b1 o' o/ J数关系数据库系统是相似的:它们有一系列数据库组成,每个数据库包含一系列数据库表,但每个系统有各自组织其管理的数据方式,MySQL也不例外。 4 l) B2 I( S* a `* S6 ]6 z
缺省地,所有由MySQL服务器mysqld管理的数据存储在一个称为MySQL数据目录的地方,所有数据库都存放在哪儿,也包括提供服务器操作信息的状态文件。如果你对一个MySQl安装执行管理任务,你应该熟知数据目录的布局及用途。
% k" y' S8 f. S# V3 ~ 本文介绍下列专题: : C2 A4 L- r$ s/ R6 ]! a, ~
如何确定数据目录的位置。
8 V' M$ F9 ~0 ^5 b 服务器如何组织并提供对数据库和它管理的表的访问。
0 [* ?1 w# M6 P. ]9 w8 Y9 @: N0 @ 在哪里找到由服务器生成的状态文件记忆它们包含什么内容。 . A4 f/ G9 a* ^" n4 m1 F' S
如何改变缺省地点或数据目录或单独数据库的组织结构。
5 e! x# Q1 a3 P! B/ n7 k7 j6 Y# I
9 {8 j* k) u8 y5 Q# d$ ^% m! M5 u 1、数据目录的位置
9 l# a9 s8 i2 [7 {" q: U 一个缺省数据目录被编译进了服务器,如果你从一个源代码分发安装MySQL,典型的缺省目录为/usr/local/var,如果从RPM文件安装则为/var/lib/mysql,如果从一个二进制分发安装则是/usr/local/mysql/data。 * e5 `* ?; n. ]" q
在你启动服务器,通过使用一个--datadir=/path/to/dir选项可以明确指定数据目录位置。如果你想把数据目录置于其它缺省位置外的某处,这很有用。
! p x2 w) u( M8 l 作为一名MySQL管理员,你应该知道你的数据目录在哪里。如果你运行多个服务器,你应该是到所有数据目录在哪里,但是如果你不知道确切的位置,由多种方法找到它:
: H5 i; Z4 R5 m6 s1 Z 使用mysqladmin variables从你的服务器直接获得数据目录路径名。查找datadir变量的值,在Unix上,其输出类似于:
( u! K0 A, {/ {; p# W! |%mysqladmin variables
. n& @6 o; X& J* F- _% a3 @ +----------------------+----------------------+
* B, O1 U b& F [9 R1 w/ [9 W) A) \| variable_name | Value | % c4 F& o7 L: @
+----------------------+----------------------+
# Q$ Q7 W) w @4 d| back_log | 5 | # z0 v) R: W3 y7 R0 H' [
| connect_timeout | 5 |
. |$ j! f, Y" f: y0 C' j' I- |1 ~| basedir | /var/local/ | 8 P$ l6 g# p, T
| datadir | /usr/local/var/ | ( z& O" @) a2 }: _' {& C# f
.... ; `- Y; }- ^- ~( k" t, y
在Windows上,输出可能看上去像这样: % a/ m4 \6 B5 F% \
c:\\\\mysqladmin variables . X8 b8 r# r( J! c; Z6 `
+----------------------+----------------------+
% F7 I* w* y' Z| variable_name | Value |
# ? ^7 o. E! B$ \7 f+----------------------+----------------------+
2 Y; d$ A: b/ R3 R| back_log | 5 |
& s/ j) s) K" S& `- R- ?7 V, [| connect_timeout | 5 |
2 z. U0 b7 |; V8 r5 Q! k% k n; ], Y| basedir | c:\\\\mysql\\\\ | 4 P( x$ c* \ k& ~0 i) G
| datadir | c:\\\\mysql\\\\data\\\\ | ) Z/ g0 Z0 K( g; n2 S j
.... " l' I! g ~- n
如果你有多个服务器在运行,它们将在不同的TCP/IP端口或套接字上监听,通过提供连接服务器正在监听的端口或套接字的--port或--socket选项,你可以轮流获得它们每一个的数据目录信息: # z1 P4 Y, _ G! i" Z
- J$ ^+ b% B4 `2 E
%msqladmin --port=port_name variables 7 }5 Z7 J! D' {+ s6 g
%mysqladmin --socket=/path/to/socket variables
* Z; w. r% r6 ?! z' w3 a mysqladmin命令可运行在任何你能从其连接服务器的主机上,如果你想在一个远程主机连接服务器,使用一个--host=host_name选项:
4 @: f0 G+ `1 Z %mysqladmin --host=host_name variables . a8 F/ } Z, ?$ x
在Windows上,你可以通过使用--pipe强制一个命令管道连接和--socket=pipe_name指定管道名来连接监听一个命令管道的NT服务器:
7 a- B0 A5 F- b: i" I7 c
* ^ Q6 M" z. [$ j; m4 p# |# b. [# C c:\\\\mysqladmin --pipe --socket=pipe_name variables
4 v" U" g i8 Q4 ^# q- }% X* V 你可以使用ps命令查看任何正在运行mysqld 进程的命令行。
( P( {' ^* J. E5 x1 T- _: ^# v& V试一下下列命令之一并寻找--datadir:
! t/ E3 y0 ?! W% c) e %ps axww | grep mysql BSD风格 ) ?% H$ q( _9 H' n& C8 C2 g
%ps -ef | grep mysqld System V风格
2 |; W: Z: t2 @ 如果你的系统运行多个服务器,ps命令可能特别有用,因为你能马上发现多个数据目录位置,缺点是必须在服务器上运行,而且可能没有有用的信息产生,除非在mysqld命令行上明确指定了--datadir选项。
& e2 V! B2 C' q+ n 如果MySQL是从一个源代码分发安装的,你可以检查其配置信息确定数据目录位置。例如,位置可从顶级Makefile中获得,但是注意,位置是Makefile中的localstatedir值,不是datadir,而且,如果分发位于一个NFS挂载的文件系统并用来为多个主机构建MySQL,配置信息反映了分发被最新构建的主机,这可能不能提供你感兴趣的主机的数据目录信息。 |