MySQL中文参考手册5(安装MySQL下)
转载 译者:晏子
〖返回〗〖转发〗
译者:晏子 (clyan@sohu.com)主页:http://linuxdb.yeah.net 4.12 Win32 注意事项 4.12.1 在Win32上安装MySQL 如果你准备从一些其他程序连接MySQL,你也可能需要MyODBC驱动程序。你可在MySQL下载页找到。 安装任何一个分发,在某个空目录解压缩它并且运行Setup.exe程序。 缺省地,MySQL-Win32被配置安装在“C:mysql”。如果你想要在其它地方安装MySQL,在“C:mysql”安装它,然后将安装移到你想要的地方。如果你真的移走MySQL,你必须通过提供选项给mysqld告诉mysqld那里的所有一切,使用C:mysqlinmysqld --help显示所有的选项目!例如,如果你移动MySQL分发到“D:programsmysql”,你必须用D:programsmysqlinmysqld --basedir D:programsmysql来启动mysqld。 用登记的MySQL版本,你也可以创建一个“C:my.cnf”文件来保存用于MySQL服务器的任何缺省选项。拷贝文件“mysqlmy-example.cnf”到“C:my.cnf”并且编辑它来适用于你的安装。注意你应该用"/"而不是""指定所有的路径。如果你使用“”,你需要指定两次(“”),因为在MySQL中“”是转义字符,见4.15.4 选项文件。 4.12.2 在Win95/Win98上启动MySQL 注意:如果你正在使用一个旧的Win95版本(例如OSR2),很有可能你有一个老的Winsock包!MySQL需要Winsock 2!你可从微软得到最新的Winsock。Win98有新的Winsock 2库作为缺省,这样上述不适用于Win98。 你能使用2个不同的MySQL服务器: mysqld 用完整调试和自动存储器分配检查编译 上面两个应该在任何 > = i386的Intel处理器上工作 。 为了启动mysqld服务器,你应该启动一个MSDOS窗口并键入: C:mysqlinmysqld 你可以这样杀死MySQL服务器,执行: C:mysqlinmysqladmin -u root shutdown 4.12.3 在NT上启动MySQL 为了是MySQL用TCP/IP工作,你必须安装服务包3(service pack 3)(或更新)! 对于NT,服务器名字是mysqld-nt。通常你应该在 NT 上安装MySQL作为一种服务: C:mysqlinmysqld-nt --install 你可以用下列命令启动和停止MySQL服务: NET START mysql 注意在这种情况下,你不能对mysqld-nt使用任何其他选项! 如果你需要用任何选项启动mysqld-nt,你也可以作为在NT上的一个独立程序运行mysqld-nt!如果你在NT上没有选项启动mysqld-nt,mysqld-nt尝试启动自己作为一种有默认选项的服务。如果你停止了mysqld-nt,你必须用NET START mysql启动它。 服务用MySql名字被安装,一旦安装,它必须使用服务控制管理器(SCM)实用程序启动服务(在控制面板中找到)或使用NET START MySQL命令。如果需要任何选项,在你启动MySQL服务前必须作为SCM实用程序的“启动参数”指定它们。一旦运行,可使用mysqladmin或从SCM实用程序或使用命令NET STOP MySQL停止mysqld-nt。如果你使用SCM停止mysqld-nt,SCM有一条关于mysqld shutdown normally奇怪的消息,当作为一种服务运行时,mysqld-nt没有控制台的存取权限,所以没有消息可以看见。 在NT上你可以得到下列服务错误消息: Permission Denied (权限拒绝) 意味着它不能找到mysqld-nt.exe 如果你作为一种服务安装mysqld-nt有问题,尝试用完整的路径启动它: C:mysqlinmysqld --install 如果你不想作为一种服务启动mysqld-nt,你可以如下启动它: C:mysqlinmysqld-nt --standalone C:mysqlinmysqld-nt --standalone --debug 4.12.4 在 Win32 上运行 MySQL 主机名 协议 通过指定命名管道--pipe选项,你可以强制一个MySQL客户使用命名管道。使用--socket选项指定管道的名字。 通过执行下列命令,你能测试MySQL是否正在工作: C:mysqlinmysqlshow 如果在Win95/Win98上mysqld很慢地回答连接,可能你的DNS有问题。在这种情况中下,用--skip-name-resolve启动mysqld并且在MySQL授权表中仅使用localhost和IP数字。在你连接运行在NT上一个mysqld-nt的MySQL服务器时,使用--pipe指定命名管道使用的参数,你也能避开DNS,对大多数MySQL客户是可行的。 有2个版本的MySQL命令行工具: mysql 用原生Win32编译,它提供很有有限的文本编辑能力。 如果你想使用mysqlc.exe,你必须拷贝“C:mysqllibcygwinb19.dll”到“windowssystem”(或类似的地方)。 在Win32上缺省的权限给所有本地用户以所有数据库的完全权限。为了使MySQL更安全,你应该为每个用户设置口令并删除mysql.user中有Host='localhost'和User=''的行。 你也应该为root用户增加一个口令:(下列例子通过删除匿名用户,允许任何人存取“测试”数据库) C:mysqlinmysql mysql 在你设置了口令以后,如果你想要关掉mysqld服务器, 你能使用这个命令做到: mysqladmin -- user=root -- password=your_password shutdown 对共享软件版本,你能如下设置root用户口令: C:mysqlinmysql mysql 有注册的MySQL版本,你能很容易地用GRANT和REVOKE命令增加新用户和更改权限,见7.26 GRANT和REVOKE句法。对Windows 的共享软件版本,必须使用INSERT、UPDATE和DELETE在mysql数据库中的一个表来管理用户和他们的权限,见6.13 存取拒绝(Access denied)的错误原因。 4.12.5 用SSH从Win32连接一个远程MySQL
搞定。它对一个直接的因特网连接工作得很好。我有些问题,SSH与我的Win95网络和Wingate有冲突 - 但是那将是张贴在其他软件公司的用户组的话题! 4.12.6 MySQL-Win32与Unix MySQL比较 Win95和线程 UDF函数 “ ”目录字符 Can't open named pipe错误 这是因为NT上MySQL正式版本缺省地使用命名管道。你能通过为新MySQL客户使用--host=localhost选项或创建一个包含下列信息的文件“C:my.cnf”来避免这个错误: [client] Access denied for user错误 制作一个单用户MYSQL.DLL服务器。这应该包括一个标准MySQL服务器的一切,除了线程创建外。这将使MySQL在不需要一个真正的客户机/服务器和不需要从其他主机存取服务器的应用程序时更容易使用。 4.13 OS/2 注意事项 SET EMXOPT=-c -n -h1024 File 'xxxx' not found (Errcode: 24) “INSTALL.CMD”脚本必须从OS/2'自己的“CMD.EXE”运行并且不能工作在替代品如“4OS2.EXE”。 “scripts/mysql-install-db”脚本已经被重新命名了:它现在调用“install.cmd”并且是一个 REXX 手迹,将安装缺省的MySQL安全配置并为MySQL创建WorkPlace Shell 图标。 动态模块支持通过编译但没有充分测试,动态模块应该使用Pthreads运行时刻库编译。 gcc -Zdll -Zmt -Zcrtdll=pthrdrtl -I../include -I../regex -I.. 注意:由于OS/2的限制,UDF模块名字的词干不能超过8个字符。模块被存储在“/mysql2/udf”目录;safe-mysqld.cmd脚本将把这个目录放在BEGINLIBPATH环境变量中。当使用UDF模块时,指定的扩展名被忽略--它被假定为“.udf”。例如,在 Unix上,共享模块可能被命名为“example.so”并且你可以象这样从它装载函数: CREATE FUNCTION metaphon RETURNS STRING SONAME "example.so"; 正是OS/2,模块将被命名为“example.udf”,但是你不指定模块扩展名: 这些分发用scripts/make_binary_distribution生成并且用下列编译器和选项配置: SunOS 4.1.4 2 sun4c with gcc 2.7.2.1 MySQL3.22以前的RPM分发是用户贡献的,自3.22开始,一些RPM是TcX 生成的。 4.15 安装后期的设置和测试 通常,对从源代码分发的安装,你象这样安装授权表并启动服务器: shell> ./scripts/mysql_install_db 对二进制分发,这样做: shell> cd mysql_installation_directory 测试在MySQL发行的顶级目录是最容易进行的。对二进制分发,这是你的安装目录(典型地类似“/usr/local/mysql”)。对源代码分发,这是你的MySQL源代码树的主目录。 在本小节和以后的小节中,下列命令中,BINDIR是到程序如mysqladmin和safe_mysqld被安装地点的路径。对二进制分发,是在分发内的“bin”目录。对源代码分发,BINDIR可能是“/usr/local/bin”,除非在你运行configure时指定了一个“ /usr/local”以外的安装目录。EXECDIR是mysqld服务器安装的地点,对二进制分发,这与BINDIR一样。对源代码分发,EXECDIR可能是“/usr/local/libexec”。 测试详细在下面描述: 如果必要,启动mysqld服务器并且建立初始MySQL授权表,包含决定用户如何被允许连接服务器的权限。这通常用mysql_install_db脚本做: 典型地,mysql_install_db仅在你第一次安装MySQL时需要运行,因此,如果你正在升级现有的安装,你可以跳过这一步。(然而,mysql_install_db的使用相当安全,并且将不更新已经存在的任何表,因此如果你是不能肯定做什么,你总是可以运行mysql_install_db。) mysql_install_db在mysql数据库里创建6个表(user、db、host、tables_priv、columns_priv和func),初始权限的描述在6.10 设置初始MySQL权限给出。简单地说,这些权限允许MySQL root用户做任何事情,并且允许任何人创建立或使用一个名字以'test'或'test_'开始的数据库。如果你不设置权限表,当你启动服务器时,下列错误将在日志文件出现: mysqld: Can't find file: 'host.frm' 如果你不是通过明显地执行./bin/safe_mysqld来启动MySQL,上述错误可能也发生在MySQL二进制代码分发!你可能需要作为root运行mysql_install_db,然而,如果你喜欢, 如果用户能在数据库目录读并且写文件,你可以作为一个非特权(非--root)用户运行MySQL服务器。作为一个非特权用户运行MySQL的指令在18.8 怎样作为一个一般用户运行 MySQL中给出。如果你有mysql_install_db的问题,见4.15.1 运行mysql_install_db的问题。因为mysql_install_db在MySQL发行中,还有一些其他方法运行它: 你可能想在运行mysql_install_db前编辑它,改变被安装到授权表中的初始权限。如果你想要在有相同权限的很多机器安装MySQL,这很有用。在这种情况下,你可能应该只需要增加几个额外的INSERT语句到mysql.user和mysql.db表中! 象这样启动MySQL服务器: 如果你启动服务器的问题,见4.15.2 启动MySQL服务器的问题. 使用mysqladmin证实服务器正在运行。下列命令提供简单的测试来检查服务器启动和连接的应答: 从mysqladmin version的输出根据你的平台和MySQL版本略有不同,但是应该类似如下显示: Server version 3.22.9-beta Running threads: 1 Questions: 20 Reloads: 2 Open tables: 3 为了感觉你能用BINDIR/mysqladmin做其他事情,用--help选项调用它。 证实你能关掉服务器: 证实你能重启服务器。使用safe_mysqld或直接调用mysqld进行,例如: 如果safe_mysqld失败,从MySQL安装目录尝试运行它(如果你已经不在那里)。如果还不工作,见4.15.2 启动MySQL服务器的问题。 运行一些简单的测试证实服务器正在工作。输出应该类似于下面所显示的: shell> BINDIR/mysqlshow mysql shell> BINDIR/mysql -e "select host,db,user from db" mysql 在“sql-bench”目录(在MySQL安装目录下)下还有基准测试套件,你能用来比较在不同的平台上MySQL表现如何。“ sql-bench/Results”目录包含对不同的数据库和平台许多运行结果。为了运行所有的测试,执行这些命令: shell> cd sql-bench 如果你没有“sql-bench”目录,你可能在对二进制分发使用一个RPM(源代码分发的RPM包括基准目录)。在这种情况下,在你能使用它以前,你必须首先安装基准套件。从MySQL 3.22开始,有名为“mysql-bench-VERSION-i386.rpm”的基准RPM包,它们包含基准代码和数据。如果你有源代码分发,你也可以在“tests”子目录下运行测试。例如,运行“auto_increment.tst”,这样做: shell> BINDIR/mysql -vvf test < ./tests/auto_increment.tst 期望的结果被显示在“ ./tests/auto_increment.res”文件中。 4.15.1 运行mysql_install_db的问题 mysql_install_db不安装授权表 在这种情况下,你应该很小心地检验日志文件!日志文件应该位于目录“XXXXXX”,用错误消息命名,并且应该指出为什么mysqld没启动。如果你不理解发生的事情,当你使用mysqlbug邮寄一份错误报告时,包含日志文件!见2.3 怎样报告错误或问题。 已经有一个mysqld守护程序在运行 在这以后,你应该编辑你的服务器引导脚本手迹用不同的套接字和端口启动两个守护进程。例如,它能调用safe_mysqld两次,但是对每次调用使用不同的--socket、--port和--basedir选项。 你没有“ /tmp ”的写权限 “some_tmp_dir”应该是你有写许可的某个目录的路径。在这以后,你应该能运行mysql_install_db并且这些命令启动服务器: shell> scripts/mysql_install_db mysqld立刻崩溃 从mysql,手工执行在mysql_install_db里面的SQL命令。保证你随后运行mysqladmin reload告诉服务器再装入授权表。 4.15.2 启动MySQL服务器的问题 通过调用mysql.server。这个脚本主要用于系统启动和关闭,更全面的描述在4.15.3 自动启动和停止MySQL。 shell> tail host_name.err 当mysqld守护进程启动时,它把目录改变到数据目录。这是它期望写日志文件和pid(进程ID)文件的地方,和它期望在那儿找到数据库。 数据目录地点是在分发编译时定死的。然而,如果mysqld期望它在你的系统上其他某个地方找到数据目录,它将工作不正常。如果你有不正确路径的问题,你可使用--help选项调用mysqld,找到mysqld允许什么选项和缺省路径设置是什么。你能通过指定正确的路径作为mysqld命令行参数来覆盖缺省值。(这些选择也能用于safe_mysqld。) 通常你应该只需要告诉mysqld基本目录,在它下面安装MySQL。你可以用--basedir选项做到,你也能使用--help检查改变路径选项的效果(注意,--help必须是mysqld命令的最后选项)。例如: shell> EXECDIR/mysqld --basedir=/usr/local --help 一旦你确定你想要的路径设置,不用--help选项启动服务器。 如果你得到下列错误,它意味着mysqld正在试图使用某些其他程序(或其他mysqld服务器)已经正在使用TCP/IP端口或套接字: Can't start server: Bind on TCP/IP port: Address already in use 使用ps保证你没有另外一个mysqld服务器正在运行。如果你不能发现其他运行的服务器,你可以尝试执行命令telnet your-host-name tcp-ip-port-number并且按几次RETURN键,如果你没有得到一个错误消息,像telnet: Unable to connect to remote host: Connection refused,某个东西正在使用mysqld正在试图使用的TCP/IP端口,见4.15.1 运行mysql_install_db的问题和19.3 在同一台机器上运行多个MySQL服务器。 safe_mysqld脚本被编写以便能正常地启动一个从MySQL源代码或二进制代码版本安装的服务器,就算这些在稍微不同的地点安装服务器。safe_mysqld希望这些条件之一是真的: 服务器和数据库能在相对safe_mysqld被调用的目录下找到。safe_mysqld在它的工作目录下面找“bin”和“data”目录(对二进制分发)或“libexec”和“var”目录(对源代码分发)。如果你从你的MySQL安装目录(例如,对二进制分发为“/usr/local/mysql”)执行safe_mysqld,这个条件应该满足。 shell> cd mysql_installation_directory 如果safe_mysqld失败,甚至在从MySQL安装目录调用时,你可以修改它以便使用到mysqld路径并且对你的系统的路径选项是正确的。注意,如果在将来你升级MySQL,你的safe_mysqld修改版本将被覆盖,因此你应该做一个你能重新安装的编辑过的版本的拷贝。 如果mysqld当前正在运行,通过执行这个命令,你能发现它正在使用什么路径设置: shell> mysqladmin variables 或 shell> mysqladmin -h 'your-host-name' variables 如果safe_mysqld启动服务器但是你不能与它连接,你应该保证你在“/etc/hosts”里面有一个条目,看起来像这样: 127.0.0.1 localhost 4.15.3 自动启动和停止MySQL shell> mysql.server start mysql.server可在MySQL安装目录下的“share/mysql”目录里找到,或在MySQL源代码树的“support-files”目录下找到。 在mysql.server启动服务器之前,它把目录改变到MySQL安装目录,然后调用safe_mysqld。如果你有在一个非标准的地点安装的二进制分发,你可能需要编辑mysql.server。修改它,运行safe_mysqld前,cd到正确的目录。如果你想要作为一些特定的用户运行服务器,你可以改变mysql_daemon_user=root行使用其他用户,你也能修改mysql.server把其他选项传给safe_mysqld。 mysql.server stop通过向服务器发出一个信号停止它。你可手工执行mysqladmin shutdown关闭服务器。 当你开始使用MySQL作为生产应用时,你可能想要增加这些启动并且停止命令到在你的“/etc/rc * 文件中适当的地方。注意如果你修改mysql.server,那么如果某个时候你升级MySQL时,你的修改版本将被覆盖,因此你应该做一个你可重新安装的编辑过的版本的拷贝。 如果你的系统使用“/etc/rc.local”启动外部脚本,你应该添加下列到其中: /bin/sh -c 'cd /usr/local/mysql ; ./bin/safe_mysqld &' mysqld] [mysql.server] mysql.server脚本使用下列变量:user、datadir、basedir、bindir和pid-file。 4.15.4 选项文件 在Unix上,MySQL从下列文件读取缺省选择: 文件名 用途 DATADIR是MySQL的数据目录(典型地对二进制安装是“/usr/local/mysql/data”或对源代码安装是“/usr/local/var”)。注意:这是在配置时间指定的目录,不是mysqld启动时用--datadir指定的目录!(--datadir在服务器寻找选项文件的地方无效,因为它以前寻找他们,它处理任何命令行参数。) MySQL在Win32上从下列文件读取缺省选项: 文件名 用途 注意,在Win32上你应该用/而不是指定所有的路径,如果你使用,你需要指定两个,因为在MySQL里面是转义字符。 MySQL试图以上述所列的顺序读取选项文件。如果存在多个选项文件,在一个后面文件读取的选项优先于在先前读取的一个文件中指定的同一个选项,在命令行上指定的选项优先于在任何选项文件指定了的选项。有些选择能使用环境变量指定,在命令行或在选项文件指定的选项优先于环境变量。 下列程序支持选项文件:mysql、mysqladmin、mysqld、mysqldump、mysqlimport、mysql.server、myisamchk和myisampack。 你能使用选项文件指定一个程序支持的任意长的选项!用--help选项运行程序可得到的可用选项的表。 一个选项文件可以包含下列形式的行: #comment 注意,对域选项和值,所有头部和尾部空白自动被删除。你可以在的值串中使用转义顺序“”、“ ”、“ 这是一个典型的全局选项文件: [client] [mysqldump] 这是典型的用户选项文件: [client] [mysql] 如果你有一个源代码分发,你将在“support-files”目录下找到一个名为“my-example.cnf”样品配置文件。如果你有二进制分发,在“DIR/share/mysql”目录下查找,在此DIR是MySQL安装目录的路径(一般是“/usr/local/mysql”)。你可以拷贝“my-example.cnf”到你的主目录(重新命名拷贝为“.my.cnf”)来试验。 为了告诉一个MySQL程序不读任何选项文件,在命令行上指定--no-defaults作为第一个选项。这必须是第一个选项,否则它将无效!如果你想检查使用哪个选项,你可以给出--print-defaults选项作为第一个选项。 如果你想要强制使用一个特定配置文件,你可以使用选项--defaults-file=full-path-to-default-file。如果你这样做,只有指定的文件将被读取。 开发者注意:选项文件的处理简单地通过处理所有在任何命令行前参数的匹配选项来实现(即,在适当的组里的选项),这对使用多次指定的一个选项的最后实例的程序工作的很好。如果你有这样一个处理多重指定选项但不读选项文件的旧程序, 你只需要增加2行给与它那种能力。检查任何标准的MySQL客户的源代码看怎样做。 4.16 升级/降级MySQL时有什么特别的事情要做? 如果你偏执于或担心新版本,你总能重新命名的旧mysqld为类似于mysqld-'old-version-number'。那么如果你的新mysqld做一些意外的事情,你可以简单地关掉它并重启你的旧mysqld! 当你做一个升级时,当然你也应该备份你的旧数据库。有时有点偏执狂是好的! 在升级后,如果你重新编译客户程遇到问题,像Commands out of sync或意外的核心倾倒,在编译你的程序时,你可能使用了一个旧的头文件或库文件。在这种情况下,你应该检查你的“mysql.h”文件和“libmysqlclient.a”库文件的日期以证实他们来自新的MySQL发行。如果不是,请重新编译你的程序! 如果你有些问题,新的mysqld服务器不想启动或你不能没有口令连接,检查你确实没有来自你的旧安装的一些旧的“my.cnf”文件!你可以用program-name --print-defaults检查。如果这输出任何非程序名字的任何东西,你有一个活跃my.cnf文件将可以影响一些事情! 无论何时你安装一个新版本的MySQL,重新构造并重新安装Msql-Mysql-modules分发是一个好主意,特别是在升级MySQL后,如果你注意到诸如你的所有DBI脚本倾倒核心症状。 4.16.1 从一个3.22版本升级到3.23 3.22和3.21客户将毫无问题地与一个3.23服务器一起工作。 当升级到3.23时,下面列出你必须注意的事情: INNER和DELAYED现在是保留字。 4.16.2 从一个3.21版本升级到3.22 在安装MySQL3.22 以后,你应该启动新的服务器并且然后运行mysql_fix_privilege_tables脚本。这将增加你使用GRANT命令所需的新权限。如果你忘记了这个,当你试着使用ALTER TABLE, CREATE INDEX或DROP INDEX时,你将得到Access denied。如果你的MySQL根用户要求一个口令,你应该把它作为一个参数给mysql_fix_privilege_tables。 mysql_real_connect()的C API接口改变了。如果你有一个旧的客户程序调用该函数,你必须放一个0作为新db参数(或为了快速连接重新编码发送的db单元的客户)。你在mysql_real_connect()前也必须调用mysql_init()!做这个改变允许新的mysql_options()函数在MYSQL处理程序结构中保存选项。 4.16.3 从一个3.20版本升级到3.21 你能用safe_mysqld --old-protocol启动mysqld3.21服务器从3.20分发的客户使用它。在这种情况下,新客户函数mysql_errno()将不返回任何服务器错误,而仅仅是CR_UNKNOWN_ERROR(但是它为客户错误服务)并且服务器使用旧的passwd() 检查而非新的一个。 如果你在而不是对mysqld使用--old-protocol选项,你将需要做下列改变: 所有的客户代码必须重新编译。如果你正在使用ODBC,你必须得到新的MyODBC 2.x驱动程序。 新的客户代码可与一个3.20.x 版的mysqld服务器一起工作,因此如果你遇到3.21.x的问题,你可以使用旧的3.20.x服务器而无须重新编译客户。 如果你对mysqld不使用--old-protocol选项,旧的客户将发出错误消息: ERROR: Protocol mismatch. Server Version = 10 Client Version = 9 新的Perl DBI/DBD接口也支持旧的mysqlperl接口。如果你使用mysqlperl,你必须做的唯一改变是改变到connect()函数的参数。新参数是:host、database、user、password(user和password参数改变了位置)。见20.5.2 DBI接口。 下列变化可能影响到旧的应用程序的查询: 现在HAVING必须在任何ORDER BY子句前被指定。 4.16.4 升级到其他体系结构 MySQL ISAM数据“ *.ISD”和索引文件“ *.ISM”文件是依赖于系统结构并在某些情况下依赖于OS。如果你想要移动你的应用程序到有与你当前系统不同的体系结构或OS的其他机器上,你不应该试图通过简单地拷贝文件到另外的机器上来移动一个数据库,相反使用mysqldump。 缺省地,mysqldump将创建一个满是SQL语句的文件,然后你可以把文件转移到其他机器上并且把它作为mysql客户的输入。 试一试mysqldump --help看可得到什么选项。如果你正在移动数据到一个更新的MySQL版本,你应该用得到的更新的版本使用mysqldump --opt得到一个快速、紧凑的倒出(dump)。 最容易(尽管不是最快)的在2台机器之间移动一个数据库的方法是在数据库所在的机器上运行下列命令: shell> mysqladmin -h 'other hostname' create db_name 如果你想要在一个慢的网络上从一台远程机器上拷贝一个数据库,你可以使用: shell> mysqladmin create db_name 你也可以在一个文件中存储结果, 然后把文件转移到目标机器并且在那里装载文件到数据库。例如,你能象这样在源机器上倾倒一个数据库到一个文件: shell> mysqldump --quick db_name | gzip > db_name.contents.gz (本例创建的文件被压缩) 转移包含数据库内容的文件到目标机器,并且在那里运行这些命令: shell> mysqladmin create db_name 你也可以使用mysqldump和mysqlimport完成数据库转移。对大数据库表,这比简单地使用mysqldump更快。在下列命令中,DUMPDIR代表你用来存储来自mysqldump的输出的目录的完整的路径。 首先,为输出文件和倾倒数据库创建目录: shell> mkdir DUMPDIR 然后转移在DUMPDIR目录下的文件到目标机器的一些相应目录并且在那里装载文件到MySQL: shell> mysqladmin create db_name # create database 另外,别忘记拷贝mysql数据库,因为那是授权表(user、db、host)被存储的地方。你可能必须作为MySQL root用户在新机器上运行命令,直到你让mysql数据库到位。 当你在新机器上导入mysql数据库后,执行mysqladmin flush-privileges以便服务器再次装入授权表信息。
责任编辑:eight(2001-06-06 21:48) |